@w5s/conventional-changelog 2.0.20 → 2.0.24

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/dist/index.js CHANGED
@@ -1,12 +1,331 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const git_raw_commit_opts_js_1 = require("./git-raw-commit-opts.js");
4
- const parser_opts_js_1 = require("./parser-opts.js");
5
- const recommended_bump_opts_js_1 = require("./recommended-bump-opts.js");
6
- const writer_opts_js_1 = require("./writer-opts.js");
7
- exports.default = {
8
- parserOpts: parser_opts_js_1.parserOpts,
9
- writerOpts: writer_opts_js_1.writerOpts,
10
- recommendedBumpOpts: recommended_bump_opts_js_1.recommendedBumpOpts,
11
- gitRawCommitOpts: git_raw_commit_opts_js_1.gitRawCommitOpts,
1
+ import emojiRegexp from 'emoji-regex';
2
+ import { gitmojis } from 'gitmojis';
3
+ import { readFileSync } from 'node:fs';
4
+ import { dirname, resolve } from 'node:path';
5
+ import { fileURLToPath } from 'node:url';
6
+
7
+ // src/git-raw-commit-opts.ts
8
+ var gitRawCommitOpts = {
9
+ format: "%B%n-hash-%n%H%n-gitTags-%n%d%n-committerDate-%n%ci%n-authorName-%n%an%n-authorEmail-%n%ae"
12
10
  };
11
+
12
+ // src/parser-opts.ts
13
+ var parserOpts = {
14
+ headerPattern: new RegExp(
15
+ // Type
16
+ `^(?<type>\\S*)? (?:\\((?<scope>.*)\\):? )?(?<subject>.*)$`,
17
+ "u"
18
+ ),
19
+ headerCorrespondence: ["type", "scope", "subject"],
20
+ revertPattern: /^(?:revert|revert:)\s"?([\S\s]+?)"?\s*this reverts commit (\w*)\./i,
21
+ noteKeywords: ["BREAKING CHANGE", "BREAKING CHANGES"],
22
+ // revertPattern: /revert:\s([\S\s]*?)\s*this reverts commit (\w*)\./i,
23
+ revertCorrespondence: [`header`, `hash`]
24
+ };
25
+
26
+ // src/data.ts
27
+ var CommitConventionalType = (() => {
28
+ const enumObject = Object.freeze({
29
+ Build: "build",
30
+ CI: "ci",
31
+ Docs: "docs",
32
+ Feat: "feat",
33
+ Fix: "fix",
34
+ Perf: "perf",
35
+ Refactor: "refactor",
36
+ Revert: "revert",
37
+ Style: "style",
38
+ Test: "test",
39
+ WIP: "wip",
40
+ Chore: "chore"
41
+ });
42
+ const enumValues = Object.freeze(Object.values(enumObject).sort());
43
+ const enumValuesSet = new Set(enumValues);
44
+ const typeData = {
45
+ feat: {
46
+ emoji: "\u2728",
47
+ "en-US": "Features",
48
+ changelog: true
49
+ },
50
+ fix: {
51
+ emoji: "\u{1F41B}",
52
+ "en-US": "Bug Fixes",
53
+ changelog: true
54
+ },
55
+ build: {
56
+ emoji: "\u{1F477}",
57
+ "en-US": "Build System",
58
+ changelog: false
59
+ },
60
+ chore: {
61
+ emoji: "\u{1F3AB}",
62
+ "en-US": "Chores",
63
+ changelog: false
64
+ },
65
+ ci: {
66
+ emoji: "\u{1F527}",
67
+ "en-US": "Continuous Integration",
68
+ changelog: false
69
+ },
70
+ docs: {
71
+ emoji: "\u{1F4DD}",
72
+ "en-US": "Documentation",
73
+ changelog: false
74
+ },
75
+ test: {
76
+ emoji: "\u2705",
77
+ "en-US": "Tests",
78
+ changelog: false
79
+ },
80
+ perf: {
81
+ emoji: "\u26A1",
82
+ "en-US": "Performance Improvements",
83
+ changelog: true
84
+ },
85
+ refactor: {
86
+ emoji: "\u267B",
87
+ "en-US": "Code Refactoring",
88
+ changelog: false
89
+ },
90
+ revert: {
91
+ emoji: "\u23EA",
92
+ "en-US": "Reverts",
93
+ changelog: true
94
+ },
95
+ style: {
96
+ emoji: "\u{1F484}",
97
+ "en-US": "Styles",
98
+ changelog: false
99
+ },
100
+ wip: {
101
+ emoji: "\u{1F6A7}",
102
+ "en-US": "Work in progress",
103
+ changelog: false
104
+ }
105
+ };
106
+ function hasInstance(anyValue) {
107
+ return typeof anyValue === "string" && enumValuesSet.has(anyValue);
108
+ }
109
+ function getData(commitType) {
110
+ return typeData[commitType];
111
+ }
112
+ function parse(anyValue) {
113
+ return hasInstance(anyValue) ? anyValue : void 0;
114
+ }
115
+ function values() {
116
+ return enumValues;
117
+ }
118
+ function findWhere(predicate) {
119
+ return enumValues.filter((enumValue) => predicate(getData(enumValue)));
120
+ }
121
+ return { ...enumObject, hasInstance, getData, values, parse, findWhere };
122
+ })();
123
+ var Emoji;
124
+ ((Emoji2) => {
125
+ Emoji2.reEmojiUnicode = emojiRegexp();
126
+ Emoji2.reEmojiText = /:\w*:/;
127
+ const reMatchOnly = (input) => new RegExp(`^${input.source}$`, "");
128
+ const _reEmojiUnicode = reMatchOnly(Emoji2.reEmojiUnicode);
129
+ const _reEmojiText = reMatchOnly(Emoji2.reEmojiText);
130
+ function isUnicode(anyValue) {
131
+ return _reEmojiUnicode.test(anyValue);
132
+ }
133
+ Emoji2.isUnicode = isUnicode;
134
+ function isText(anyValue) {
135
+ return _reEmojiText.test(anyValue);
136
+ }
137
+ Emoji2.isText = isText;
138
+ function hasInstance(anyValue) {
139
+ return isText(anyValue) || isUnicode(anyValue);
140
+ }
141
+ Emoji2.hasInstance = hasInstance;
142
+ })(Emoji || (Emoji = {}));
143
+ var GitmojiCode;
144
+ ((GitmojiCode2) => {
145
+ const allGitmojiCodes = new Set(
146
+ gitmojis.map((gitmoji) => gitmoji.code).concat(gitmojis.map((gitmoji) => gitmoji.emoji))
147
+ );
148
+ const index = {
149
+ // code: createIndex(gitmojis, 'code'),
150
+ emoji: createIndex(gitmojis, "emoji")
151
+ };
152
+ function createIndex(list, key) {
153
+ return new Map(list.map((gitmoji) => [gitmoji[key], gitmoji]));
154
+ }
155
+ function isValid(anyValue) {
156
+ return allGitmojiCodes.has(anyValue);
157
+ }
158
+ GitmojiCode2.isValid = isValid;
159
+ const defaultType = "chore";
160
+ const conversionMap = (() => {
161
+ const data = {
162
+ feat: ["\u2728", "\u267F\uFE0F", "\u{1F6B8}"],
163
+ fix: ["\u{1F41B}"],
164
+ docs: ["\u{1F4DD}"],
165
+ style: ["\u{1F3A8}", "\u{1F6A8}"],
166
+ refactor: ["\u267B\uFE0F", "\u{1F3D7}\uFE0F"],
167
+ test: ["\u2705", "\u{1F9EA}"],
168
+ perf: ["\u26A1\uFE0F"],
169
+ revert: ["\u23EA\uFE0F"],
170
+ ci: ["\u{1F477}", "\u{1F49A}"],
171
+ wip: ["\u{1F6A7}"],
172
+ build: [],
173
+ chore: ["\u{1F527}"]
174
+ };
175
+ const entries = Array.from(
176
+ // @ts-ignore entries are not well typed
177
+ Object.entries(data)
178
+ );
179
+ return new Map(
180
+ entries.reduce(
181
+ (acc, [commitType, gitmojiUnicodeArray]) => acc.concat(gitmojiUnicodeArray.map((gitmojiUnicode) => [gitmojiUnicode, commitType])).concat(
182
+ gitmojiUnicodeArray.map((gitmojiUnicode) => [
183
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion, @typescript-eslint/no-non-null-asserted-optional-chain
184
+ index.emoji.get(gitmojiUnicode)?.code,
185
+ commitType
186
+ ])
187
+ ),
188
+ []
189
+ )
190
+ );
191
+ })();
192
+ function toConventionalCommitType2(gitmoji) {
193
+ return conversionMap.get(gitmoji) ?? defaultType;
194
+ }
195
+ GitmojiCode2.toConventionalCommitType = toConventionalCommitType2;
196
+ })(GitmojiCode || (GitmojiCode = {}));
197
+
198
+ // src/recommended-bump-opts.ts
199
+ function toConventionalCommitType(text) {
200
+ return GitmojiCode.isValid(text) ? GitmojiCode.toConventionalCommitType(text) : CommitConventionalType.hasInstance(text) ? text : void 0;
201
+ }
202
+ var recommendedBumpOpts = {
203
+ parserOpts,
204
+ whatBump: (commits) => {
205
+ let level = 2;
206
+ let breakings = 0;
207
+ let features = 0;
208
+ for (const { type, notes } of commits) {
209
+ const conventionalType = type == null ? type : toConventionalCommitType(type);
210
+ if (notes.length > 0) {
211
+ breakings += notes.length;
212
+ level = 0;
213
+ } else if (conventionalType === CommitConventionalType.Feat) {
214
+ features += 1;
215
+ if (level === 2) {
216
+ level = 1;
217
+ }
218
+ }
219
+ }
220
+ return {
221
+ level,
222
+ reason: breakings === 1 ? `There is ${breakings} BREAKING CHANGE and ${features} features` : `There are ${breakings} BREAKING CHANGES and ${features} features`
223
+ };
224
+ }
225
+ };
226
+
227
+ // src/transform.ts
228
+ function displayScope(scope, scopeDisplayNameMap) {
229
+ return scope == null || scope.length === 0 ? scopeDisplayNameMap["*"] : scopeDisplayNameMap[scope] == null ? scope : scopeDisplayNameMap[scope];
230
+ }
231
+ function displayType(type, options = {}) {
232
+ const { withEmoji = true, language = "en-US" } = options;
233
+ if (CommitConventionalType.hasInstance(type)) {
234
+ const { emoji, [language]: title } = CommitConventionalType.getData(type);
235
+ return `${withEmoji ? `${emoji} ` : ""}${title}`;
236
+ }
237
+ return type;
238
+ }
239
+ function createTransform(config) {
240
+ const displayTypes = new Set(config.displayTypes == null ? CommitConventionalType.values() : config.displayTypes);
241
+ const ignoreType = (type) => type == null || !displayTypes.has(type);
242
+ const ignoreScope = (scope) => config.displayScopes == null ? false : scope != null && !config.displayScopes.includes(scope);
243
+ const transform = (commit, { repository, host, owner, repoUrl }) => {
244
+ const discard = commit.notes.length === 0;
245
+ const issues = /* @__PURE__ */ new Set();
246
+ const notes = commit.notes.map((note) => ({
247
+ ...note,
248
+ title: `${config.withEmoji === false ? "" : "\u{1F4A5} "}BREAKING CHANGES`
249
+ }));
250
+ const conventionalType = commit.type == null ? void 0 : CommitConventionalType.parse(commit.type) ?? (GitmojiCode.isValid(commit.type) ? GitmojiCode.toConventionalCommitType(commit.type) : void 0);
251
+ if (ignoreType(conventionalType) && discard) return false;
252
+ const type = conventionalType == null ? conventionalType : displayType(conventionalType, {
253
+ withEmoji: config.withEmoji
254
+ });
255
+ if (ignoreScope(commit.scope)) return false;
256
+ const scopeIntermediate = commit.scope === "*" ? "" : commit.scope;
257
+ const scope = config.scopeDisplayName == null ? scopeIntermediate : displayScope(scopeIntermediate, config.scopeDisplayName);
258
+ const hash = typeof commit.hash === "string" ? commit.hash.slice(0, 7) : commit.hash;
259
+ const subject = typeof commit.subject === "string" ? (() => {
260
+ let returnValue = commit.subject;
261
+ const url = repository == null ? repoUrl : [host, owner, repository].filter(Boolean).join("/");
262
+ if (url != null) {
263
+ const issueURL = `${url}/issues/`;
264
+ returnValue = returnValue.replace(/#(\d+)/g, (_, issue) => {
265
+ issues.add(issue);
266
+ return `[#${issue}](${issueURL}${issue})`;
267
+ });
268
+ }
269
+ if (host != null) {
270
+ returnValue = returnValue.replace(
271
+ /\B@([\da-z](?:-?[\d/a-z]){0,38})/g,
272
+ (_, username) => username.includes("/") ? `@${username}` : `[@${username}](${host}/${username})`
273
+ );
274
+ }
275
+ return returnValue;
276
+ })() : commit.subject;
277
+ const references = commit.references.filter((reference) => !issues.has(reference.issue));
278
+ return {
279
+ ...commit,
280
+ type,
281
+ hash,
282
+ scope,
283
+ subject,
284
+ references,
285
+ header: commit.header,
286
+ body: commit.body,
287
+ footer: commit.footer,
288
+ merge: commit.merge,
289
+ revert: commit.revert,
290
+ notes,
291
+ mentions: commit.mentions
292
+ };
293
+ };
294
+ return transform;
295
+ }
296
+
297
+ // src/writer-opts.ts
298
+ var _dirname = typeof __dirname === "undefined" ? dirname(fileURLToPath(import.meta.url)) : __dirname;
299
+ var basePath = resolve(dirname(_dirname), "./template");
300
+ var mainTemplate = readFileSync(`${basePath}/template.hbs`, "utf8");
301
+ var headerPartial = readFileSync(`${basePath}/header.hbs`, "utf8");
302
+ var commitPartial = readFileSync(`${basePath}/commit.hbs`, "utf8");
303
+ var footerPartial = readFileSync(`${basePath}/footer.hbs`, "utf8");
304
+ var author = readFileSync(`${basePath}/author.hbs`, "utf8");
305
+ var defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);
306
+ var writerOpts = {
307
+ transform: createTransform({
308
+ displayTypes: defaultDisplayTypes
309
+ }),
310
+ groupBy: "type",
311
+ commitGroupsSort: "title",
312
+ commitsSort: ["scope", "subject"],
313
+ noteGroupsSort: "title",
314
+ mainTemplate,
315
+ headerPartial,
316
+ // eslint-disable-next-line unicorn/prefer-string-replace-all
317
+ commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
318
+ footerPartial
319
+ };
320
+
321
+ // src/index.ts
322
+ var src_default = {
323
+ parserOpts,
324
+ writerOpts,
325
+ recommendedBumpOpts,
326
+ gitRawCommitOpts
327
+ };
328
+
329
+ export { Emoji, GitmojiCode, src_default as default };
330
+ //# sourceMappingURL=index.js.map
331
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/git-raw-commit-opts.ts","../src/parser-opts.ts","../src/data.ts","../src/gitmoji.ts","../src/recommended-bump-opts.ts","../src/transform.ts","../src/writer-opts.ts","../src/index.ts"],"names":["Emoji","GitmojiCode","toConventionalCommitType"],"mappings":"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","file":"index.js","sourcesContent":["export const gitRawCommitOpts = {\n format: '%B%n-hash-%n%H%n-gitTags-%n%d%n-committerDate-%n%ci%n-authorName-%n%an%n-authorEmail-%n%ae',\n};\n","import type { Options } from 'conventional-commits-parser';\n\nexport interface ParserOptions extends Options {}\n\nexport const parserOpts: ParserOptions = {\n headerPattern: new RegExp(\n // Type\n `^(?<type>\\\\S*)? ` +\n // Scope\n `(?:\\\\((?<scope>.*)\\\\):? )?` +\n // Subject\n `(?<subject>.*)$`,\n 'u'\n ),\n headerCorrespondence: ['type', 'scope', 'subject'],\n revertPattern: /^(?:revert|revert:)\\s\"?([\\S\\s]+?)\"?\\s*this reverts commit (\\w*)\\./i,\n noteKeywords: ['BREAKING CHANGE', 'BREAKING CHANGES'],\n // revertPattern: /revert:\\s([\\S\\s]*?)\\s*this reverts commit (\\w*)\\./i,\n revertCorrespondence: [`header`, `hash`],\n};\n","import type { Commit as CommitDefault } from 'conventional-commits-parser';\n\nexport type Commit = CommitDefault<never> & {\n hash?: string;\n};\n\nexport type CommitConventionalType =\n | 'build'\n | 'ci'\n | 'docs'\n | 'feat'\n | 'fix'\n | 'perf'\n | 'refactor'\n | 'revert'\n | 'style'\n | 'test'\n | 'wip'\n | 'chore';\n\nexport const CommitConventionalType = (() => {\n const enumObject = Object.freeze({\n Build: 'build',\n CI: 'ci',\n Docs: 'docs',\n Feat: 'feat',\n Fix: 'fix',\n Perf: 'perf',\n Refactor: 'refactor',\n Revert: 'revert',\n Style: 'style',\n Test: 'test',\n WIP: 'wip',\n Chore: 'chore',\n });\n const enumValues: readonly CommitConventionalType[] = Object.freeze(Object.values(enumObject).sort());\n const enumValuesSet = new Set(enumValues);\n\n const typeData: Record<CommitConventionalType, CommitConventionalTypeData> = {\n feat: {\n emoji: '✨',\n 'en-US': 'Features',\n changelog: true,\n },\n fix: {\n emoji: '🐛',\n 'en-US': 'Bug Fixes',\n changelog: true,\n },\n build: {\n emoji: '👷',\n 'en-US': 'Build System',\n changelog: false,\n },\n chore: {\n emoji: '🎫',\n 'en-US': 'Chores',\n changelog: false,\n },\n ci: {\n emoji: '🔧',\n 'en-US': 'Continuous Integration',\n changelog: false,\n },\n docs: {\n emoji: '📝',\n 'en-US': 'Documentation',\n changelog: false,\n },\n test: {\n emoji: '✅',\n 'en-US': 'Tests',\n changelog: false,\n },\n perf: {\n emoji: '⚡',\n 'en-US': 'Performance Improvements',\n changelog: true,\n },\n refactor: {\n emoji: '♻',\n 'en-US': 'Code Refactoring',\n changelog: false,\n },\n revert: {\n emoji: '⏪',\n 'en-US': 'Reverts',\n changelog: true,\n },\n style: {\n emoji: '💄',\n 'en-US': 'Styles',\n changelog: false,\n },\n wip: {\n emoji: '🚧',\n 'en-US': 'Work in progress',\n changelog: false,\n },\n };\n\n function hasInstance(anyValue: unknown): anyValue is CommitConventionalType {\n return typeof anyValue === 'string' && enumValuesSet.has(anyValue as unknown as CommitConventionalType);\n }\n\n function getData(commitType: CommitConventionalType): CommitConventionalTypeData {\n return typeData[commitType];\n }\n\n function parse(anyValue: string): CommitConventionalType | undefined {\n return hasInstance(anyValue) ? anyValue : undefined;\n }\n\n function values() {\n return enumValues;\n }\n\n function findWhere(predicate: (data: CommitConventionalTypeData) => boolean): CommitConventionalType[] {\n return enumValues.filter((enumValue) => predicate(getData(enumValue)));\n }\n\n return { ...enumObject, hasInstance, getData, values, parse, findWhere };\n})();\n\nexport interface CommitConventionalTypeData {\n emoji: string;\n 'en-US': string;\n changelog: boolean;\n}\n","import emojiRegexp from 'emoji-regex';\nimport { type Gitmoji, gitmojis } from 'gitmojis';\nimport type { CommitConventionalType } from './data.js';\n\nexport type Emoji = Emoji.Unicode | Emoji.Text;\nexport namespace Emoji {\n export const reEmojiUnicode = emojiRegexp();\n\n export const reEmojiText = /:\\w*:/;\n\n const reMatchOnly = (input: RegExp) => new RegExp(`^${input.source}$`, '');\n const _reEmojiUnicode = reMatchOnly(reEmojiUnicode);\n const _reEmojiText = reMatchOnly(reEmojiText);\n\n export type Unicode = string & { '@@EmojiStyle': 'unicode' };\n export type Text = string & { '@@EmojiStyle': 'text' };\n\n export function isUnicode(anyValue: string): anyValue is Unicode {\n return _reEmojiUnicode.test(anyValue);\n }\n\n export function isText(anyValue: string): anyValue is Text {\n return _reEmojiText.test(anyValue);\n }\n\n export function hasInstance(anyValue: string): anyValue is Emoji {\n return isText(anyValue) || isUnicode(anyValue);\n }\n}\n\nexport type GitmojiCode = Emoji & { '@@Gitmoji': true };\nexport namespace GitmojiCode {\n export type Unicode = Emoji.Unicode & { '@@Gitmoji': true };\n export type Emoji = Emoji.Text & { '@@Gitmoji': true };\n\n // export const reEmoji = emojiRegexp();\n\n const allGitmojiCodes = new Set(\n gitmojis\n .map((gitmoji) => gitmoji.code as GitmojiCode)\n .concat(gitmojis.map((gitmoji) => gitmoji.emoji as GitmojiCode))\n );\n const index = {\n // code: createIndex(gitmojis, 'code'),\n emoji: createIndex(gitmojis, 'emoji'),\n };\n\n function createIndex<K extends keyof Gitmoji>(list: readonly Gitmoji[], key: K): ReadonlyMap<Gitmoji[K], Gitmoji> {\n return new Map(list.map((gitmoji) => [gitmoji[key], gitmoji]));\n }\n\n export function isValid(anyValue: string): anyValue is GitmojiCode {\n return allGitmojiCodes.has(anyValue as GitmojiCode);\n }\n\n const defaultType = 'chore';\n const conversionMap: ReadonlyMap<GitmojiCode, CommitConventionalType> = (() => {\n const data: Record<CommitConventionalType, GitmojiCode.Unicode[]> = {\n feat: ['✨', '♿️', '🚸'] as GitmojiCode.Unicode[],\n fix: ['🐛'] as GitmojiCode.Unicode[],\n docs: ['📝'] as GitmojiCode.Unicode[],\n style: ['🎨', '🚨'] as GitmojiCode.Unicode[],\n refactor: ['♻️', '🏗️'] as GitmojiCode.Unicode[],\n test: ['✅', '🧪'] as GitmojiCode.Unicode[],\n perf: ['⚡️'] as GitmojiCode.Unicode[],\n revert: ['⏪️'] as GitmojiCode.Unicode[],\n ci: ['👷', '💚'] as GitmojiCode.Unicode[],\n wip: ['🚧'] as GitmojiCode.Unicode[],\n build: [] as GitmojiCode.Unicode[],\n chore: ['🔧'] as GitmojiCode.Unicode[],\n };\n\n const entries = Array.from<[CommitConventionalType, GitmojiCode.Unicode[]]>(\n // @ts-ignore entries are not well typed\n Object.entries(data)\n );\n return new Map(\n entries.reduce<Array<[GitmojiCode, CommitConventionalType]>>(\n (acc, [commitType, gitmojiUnicodeArray]) =>\n acc\n .concat(gitmojiUnicodeArray.map((gitmojiUnicode) => [gitmojiUnicode, commitType]))\n\n .concat(\n gitmojiUnicodeArray.map((gitmojiUnicode) => [\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion, @typescript-eslint/no-non-null-asserted-optional-chain\n index.emoji.get(gitmojiUnicode)?.code! as GitmojiCode,\n commitType,\n ])\n ),\n []\n )\n );\n })();\n\n export function toConventionalCommitType(gitmoji: GitmojiCode): CommitConventionalType {\n return conversionMap.get(gitmoji) ?? defaultType;\n }\n}\n","import type { Commit as CommitBase } from 'conventional-commits-parser';\nimport { parserOpts } from './parser-opts.js';\nimport { CommitConventionalType } from './data.js';\nimport { GitmojiCode } from './gitmoji.js';\n\nfunction toConventionalCommitType(text: string) {\n return GitmojiCode.isValid(text)\n ? GitmojiCode.toConventionalCommitType(text)\n : CommitConventionalType.hasInstance(text)\n ? text\n : undefined;\n}\n\nexport type Commit = CommitBase;\n\nexport const recommendedBumpOpts = {\n parserOpts,\n whatBump: (commits: ReadonlyArray<Commit>) => {\n let level = 2;\n let breakings = 0;\n let features = 0;\n\n for (const { type, notes } of commits) {\n const conventionalType = type == null ? type : toConventionalCommitType(type);\n if (notes.length > 0) {\n breakings += notes.length;\n level = 0;\n } else if (conventionalType === CommitConventionalType.Feat) {\n features += 1;\n if (level === 2) {\n level = 1;\n }\n }\n }\n\n return {\n level,\n reason:\n breakings === 1\n ? `There is ${breakings} BREAKING CHANGE and ${features} features`\n : `There are ${breakings} BREAKING CHANGES and ${features} features`,\n };\n },\n};\n","import type { Context, Options as WriterOptions } from 'conventional-changelog-writer';\nimport { CommitConventionalType, Commit } from './data.js';\nimport { GitmojiCode } from './gitmoji.js';\n\nexport type Language = 'en-US';\n\nexport interface TransformConfig {\n scopeDisplayName?: Record<string, string>;\n displayTypes?: CommitConventionalType[];\n displayScopes?: string[];\n showAuthor?: boolean;\n withEmoji?: boolean;\n language?: Language;\n}\n\nexport function displayScope(scope: string | null | undefined, scopeDisplayNameMap: Record<string, string>) {\n return scope == null || scope.length === 0\n ? scopeDisplayNameMap['*']\n : scopeDisplayNameMap[scope] == null\n ? scope\n : scopeDisplayNameMap[scope];\n}\n\nexport function displayType(type: string, options: displayType.Options = {}): string {\n const { withEmoji = true, language = 'en-US' } = options;\n\n if (CommitConventionalType.hasInstance(type)) {\n const { emoji, [language]: title } = CommitConventionalType.getData(type);\n return `${withEmoji ? `${emoji} ` : ''}${title}`;\n }\n\n return type;\n}\nexport namespace displayType {\n export interface Options {\n readonly withEmoji?: boolean;\n readonly language?: Language;\n }\n}\n\nexport function createTransform(config: TransformConfig): WriterOptions.Transform.Function {\n const displayTypes = new Set(config.displayTypes == null ? CommitConventionalType.values() : config.displayTypes);\n const ignoreType = (type: string | undefined) => type == null || !displayTypes.has(type as CommitConventionalType);\n const ignoreScope = (scope: string | undefined | null) =>\n config.displayScopes == null ? false : scope != null && !config.displayScopes.includes(scope);\n\n const transform = (commit: Commit, { repository, host, owner, repoUrl }: Context): Commit | false => {\n const discard = commit.notes.length === 0;\n const issues = new Set<string>();\n const notes = commit.notes.map((note) => ({\n ...note,\n title: `${config.withEmoji === false ? '' : '💥 '}BREAKING CHANGES`,\n }));\n const conventionalType =\n commit.type == null\n ? undefined\n : (CommitConventionalType.parse(commit.type) ??\n (GitmojiCode.isValid(commit.type) ? GitmojiCode.toConventionalCommitType(commit.type) : undefined));\n\n if (ignoreType(conventionalType) && discard) return false;\n\n const type =\n conventionalType == null\n ? conventionalType\n : displayType(conventionalType, {\n withEmoji: config.withEmoji,\n });\n\n if (ignoreScope(commit.scope)) return false;\n\n const scopeIntermediate = commit.scope === '*' ? '' : commit.scope;\n const scope =\n config.scopeDisplayName == null ? scopeIntermediate : displayScope(scopeIntermediate, config.scopeDisplayName);\n const hash = typeof commit.hash === 'string' ? commit.hash.slice(0, 7) : commit.hash;\n\n const subject =\n typeof commit.subject === 'string'\n ? (() => {\n let returnValue = commit.subject;\n const url = repository == null ? repoUrl : [host, owner, repository].filter(Boolean).join('/');\n if (url != null) {\n const issueURL = `${url}/issues/`;\n // Issue URLs.\n // eslint-disable-next-line unicorn/prefer-string-replace-all\n returnValue = returnValue.replace(/#(\\d+)/g, (_, issue: string) => {\n issues.add(issue);\n\n return `[#${issue}](${issueURL}${issue})`;\n });\n }\n if (host != null) {\n // User URLs.\n // eslint-disable-next-line unicorn/prefer-string-replace-all\n returnValue = returnValue.replace(/\\B@([\\da-z](?:-?[\\d/a-z]){0,38})/g, (_, username: string) =>\n username.includes('/') ? `@${username}` : `[@${username}](${host}/${username})`\n );\n }\n return returnValue;\n })()\n : commit.subject;\n\n // Remove references that already appear in the subject\n const references = commit.references.filter((reference) => !issues.has(reference.issue));\n\n return {\n ...commit,\n type,\n hash,\n scope,\n subject,\n references,\n header: commit.header,\n body: commit.body,\n footer: commit.footer,\n merge: commit.merge,\n revert: commit.revert,\n notes,\n mentions: commit.mentions,\n };\n };\n\n return transform as unknown as WriterOptions.Transform.Function;\n}\n","import { readFileSync } from 'node:fs';\nimport { resolve, dirname } from 'node:path';\nimport type { Options } from 'conventional-changelog-writer';\nimport { fileURLToPath } from 'node:url';\nimport { createTransform } from './transform.js';\nimport { CommitConventionalType } from './data.js';\n\nexport interface WriterOptions extends Options {}\n\nconst _dirname = typeof __dirname === 'undefined' ? dirname(fileURLToPath(import.meta.url)) : __dirname;\nconst basePath = resolve(dirname(_dirname), './template');\n\nconst mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');\nconst headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');\nconst commitPartial = readFileSync(`${basePath}/commit.hbs`, 'utf8');\nconst footerPartial = readFileSync(`${basePath}/footer.hbs`, 'utf8');\nconst author = readFileSync(`${basePath}/author.hbs`, 'utf8');\n\nexport const defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);\n\nexport const writerOpts: WriterOptions = {\n transform: createTransform({\n displayTypes: defaultDisplayTypes,\n }),\n groupBy: 'type',\n commitGroupsSort: 'title',\n commitsSort: ['scope', 'subject'],\n noteGroupsSort: 'title',\n mainTemplate,\n headerPartial,\n // eslint-disable-next-line unicorn/prefer-string-replace-all\n commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),\n footerPartial,\n};\n","import { gitRawCommitOpts } from './git-raw-commit-opts.js';\nimport { parserOpts } from './parser-opts.js';\nimport { recommendedBumpOpts } from './recommended-bump-opts.js';\nimport { writerOpts } from './writer-opts.js';\n\nexport * from './gitmoji.js';\n\nexport default {\n parserOpts,\n writerOpts,\n recommendedBumpOpts,\n gitRawCommitOpts,\n};\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@w5s/conventional-changelog",
3
- "version": "2.0.20",
3
+ "version": "2.0.24",
4
4
  "description": "Conventional changelog plugin for @w5s",
5
5
  "keywords": [],
6
6
  "homepage": "https://github.com/w5s/project-config/blob/main/packages/conventional-changelog#readme",
@@ -14,12 +14,20 @@
14
14
  },
15
15
  "license": "MIT",
16
16
  "author": "Julien Polo <julien.polo@gmail.com>",
17
- "type": "commonjs",
17
+ "type": "module",
18
18
  "exports": {
19
- ".": "./index.js",
19
+ ".": {
20
+ "require": {
21
+ "types": "./dist/index.d.cts",
22
+ "default": "./dist/index.cjs"
23
+ },
24
+ "import": {
25
+ "types": "./dist/index.d.ts",
26
+ "default": "./dist/index.js"
27
+ }
28
+ },
20
29
  "./dist/*": "./dist/*"
21
30
  },
22
- "typings": "./index.d.ts",
23
31
  "files": [
24
32
  "template/*",
25
33
  "dist/",
@@ -44,5 +52,5 @@
44
52
  "publishConfig": {
45
53
  "access": "public"
46
54
  },
47
- "gitHead": "114c1aa56da01c4ad5cc775ff4df717eb90614b4"
55
+ "gitHead": "966ebbb065df3e68092eb80c3ff2c15858989edb"
48
56
  }
package/src/index.ts CHANGED
@@ -3,6 +3,8 @@ import { parserOpts } from './parser-opts.js';
3
3
  import { recommendedBumpOpts } from './recommended-bump-opts.js';
4
4
  import { writerOpts } from './writer-opts.js';
5
5
 
6
+ export * from './gitmoji.js';
7
+
6
8
  export default {
7
9
  parserOpts,
8
10
  writerOpts,
@@ -1,12 +1,14 @@
1
1
  import { readFileSync } from 'node:fs';
2
2
  import { resolve, dirname } from 'node:path';
3
3
  import type { Options } from 'conventional-changelog-writer';
4
+ import { fileURLToPath } from 'node:url';
4
5
  import { createTransform } from './transform.js';
5
6
  import { CommitConventionalType } from './data.js';
6
7
 
7
8
  export interface WriterOptions extends Options {}
8
9
 
9
- const basePath = resolve(dirname(__dirname), './template');
10
+ const _dirname = typeof __dirname === 'undefined' ? dirname(fileURLToPath(import.meta.url)) : __dirname;
11
+ const basePath = resolve(dirname(_dirname), './template');
10
12
 
11
13
  const mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');
12
14
  const headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');
package/dist/data.d.ts DELETED
@@ -1,29 +0,0 @@
1
- import type { Commit as CommitDefault } from 'conventional-commits-parser';
2
- export type Commit = CommitDefault<never> & {
3
- hash?: string;
4
- };
5
- export type CommitConventionalType = 'build' | 'ci' | 'docs' | 'feat' | 'fix' | 'perf' | 'refactor' | 'revert' | 'style' | 'test' | 'wip' | 'chore';
6
- export declare const CommitConventionalType: {
7
- hasInstance: (anyValue: unknown) => anyValue is CommitConventionalType;
8
- getData: (commitType: CommitConventionalType) => CommitConventionalTypeData;
9
- values: () => readonly CommitConventionalType[];
10
- parse: (anyValue: string) => CommitConventionalType | undefined;
11
- findWhere: (predicate: (data: CommitConventionalTypeData) => boolean) => CommitConventionalType[];
12
- Build: "build";
13
- CI: "ci";
14
- Docs: "docs";
15
- Feat: "feat";
16
- Fix: "fix";
17
- Perf: "perf";
18
- Refactor: "refactor";
19
- Revert: "revert";
20
- Style: "style";
21
- Test: "test";
22
- WIP: "wip";
23
- Chore: "chore";
24
- };
25
- export interface CommitConventionalTypeData {
26
- emoji: string;
27
- 'en-US': string;
28
- changelog: boolean;
29
- }
package/dist/data.js DELETED
@@ -1,99 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CommitConventionalType = void 0;
4
- exports.CommitConventionalType = (() => {
5
- const enumObject = Object.freeze({
6
- Build: 'build',
7
- CI: 'ci',
8
- Docs: 'docs',
9
- Feat: 'feat',
10
- Fix: 'fix',
11
- Perf: 'perf',
12
- Refactor: 'refactor',
13
- Revert: 'revert',
14
- Style: 'style',
15
- Test: 'test',
16
- WIP: 'wip',
17
- Chore: 'chore',
18
- });
19
- const enumValues = Object.freeze(Object.values(enumObject).sort());
20
- const enumValuesSet = new Set(enumValues);
21
- const typeData = {
22
- feat: {
23
- emoji: '✨',
24
- 'en-US': 'Features',
25
- changelog: true,
26
- },
27
- fix: {
28
- emoji: '🐛',
29
- 'en-US': 'Bug Fixes',
30
- changelog: true,
31
- },
32
- build: {
33
- emoji: '👷',
34
- 'en-US': 'Build System',
35
- changelog: false,
36
- },
37
- chore: {
38
- emoji: '🎫',
39
- 'en-US': 'Chores',
40
- changelog: false,
41
- },
42
- ci: {
43
- emoji: '🔧',
44
- 'en-US': 'Continuous Integration',
45
- changelog: false,
46
- },
47
- docs: {
48
- emoji: '📝',
49
- 'en-US': 'Documentation',
50
- changelog: false,
51
- },
52
- test: {
53
- emoji: '✅',
54
- 'en-US': 'Tests',
55
- changelog: false,
56
- },
57
- perf: {
58
- emoji: '⚡',
59
- 'en-US': 'Performance Improvements',
60
- changelog: true,
61
- },
62
- refactor: {
63
- emoji: '♻',
64
- 'en-US': 'Code Refactoring',
65
- changelog: false,
66
- },
67
- revert: {
68
- emoji: '⏪',
69
- 'en-US': 'Reverts',
70
- changelog: true,
71
- },
72
- style: {
73
- emoji: '💄',
74
- 'en-US': 'Styles',
75
- changelog: false,
76
- },
77
- wip: {
78
- emoji: '🚧',
79
- 'en-US': 'Work in progress',
80
- changelog: false,
81
- },
82
- };
83
- function hasInstance(anyValue) {
84
- return typeof anyValue === 'string' && enumValuesSet.has(anyValue);
85
- }
86
- function getData(commitType) {
87
- return typeData[commitType];
88
- }
89
- function parse(anyValue) {
90
- return hasInstance(anyValue) ? anyValue : undefined;
91
- }
92
- function values() {
93
- return enumValues;
94
- }
95
- function findWhere(predicate) {
96
- return enumValues.filter((enumValue) => predicate(getData(enumValue)));
97
- }
98
- return { ...enumObject, hasInstance, getData, values, parse, findWhere };
99
- })();
@@ -1,3 +0,0 @@
1
- export declare const gitRawCommitOpts: {
2
- format: string;
3
- };
@@ -1,6 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.gitRawCommitOpts = void 0;
4
- exports.gitRawCommitOpts = {
5
- format: '%B%n-hash-%n%H%n-gitTags-%n%d%n-committerDate-%n%ci%n-authorName-%n%an%n-authorEmail-%n%ae',
6
- };
package/dist/gitmoji.d.ts DELETED
@@ -1,28 +0,0 @@
1
- import type { CommitConventionalType } from './data.js';
2
- export type Emoji = Emoji.Unicode | Emoji.Text;
3
- export declare namespace Emoji {
4
- const reEmojiUnicode: RegExp;
5
- const reEmojiText: RegExp;
6
- type Unicode = string & {
7
- '@@EmojiStyle': 'unicode';
8
- };
9
- type Text = string & {
10
- '@@EmojiStyle': 'text';
11
- };
12
- function isUnicode(anyValue: string): anyValue is Unicode;
13
- function isText(anyValue: string): anyValue is Text;
14
- function hasInstance(anyValue: string): anyValue is Emoji;
15
- }
16
- export type GitmojiCode = Emoji & {
17
- '@@Gitmoji': true;
18
- };
19
- export declare namespace GitmojiCode {
20
- type Unicode = Emoji.Unicode & {
21
- '@@Gitmoji': true;
22
- };
23
- type Emoji = Emoji.Text & {
24
- '@@Gitmoji': true;
25
- };
26
- function isValid(anyValue: string): anyValue is GitmojiCode;
27
- function toConventionalCommitType(gitmoji: GitmojiCode): CommitConventionalType;
28
- }