@w5s/conventional-changelog 2.2.2 → 2.2.4

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.cjs CHANGED
@@ -1,5 +1,7 @@
1
1
  'use strict';
2
2
 
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
3
5
  var emojiRegexp = require('emoji-regex');
4
6
  var gitmojis = require('gitmojis');
5
7
  var fs = require('fs');
@@ -17,8 +19,8 @@ var gitRawCommitOpts = {
17
19
  format: "%B%n-hash-%n%H%n-gitTags-%n%d%n-committerDate-%n%ci%n-authorName-%n%an%n-authorEmail-%n%ae"
18
20
  };
19
21
 
20
- // src/parser-opts.ts
21
- var parserOpts = {
22
+ // src/parser.ts
23
+ var createParserOpts = () => ({
22
24
  headerPattern: new RegExp(
23
25
  // Type
24
26
  `^(?<type>\\S*)? (?:\\((?<scope>.*)\\):? )?(?<subject>.*)$`,
@@ -29,7 +31,7 @@ var parserOpts = {
29
31
  noteKeywords: ["BREAKING CHANGE", "BREAKING CHANGES"],
30
32
  // revertPattern: /revert:\s([\S\s]*?)\s*this reverts commit (\w*)\./i,
31
33
  revertCorrespondence: [`header`, `hash`]
32
- };
34
+ });
33
35
 
34
36
  // src/data.ts
35
37
  var CommitConventionalType = (() => {
@@ -128,7 +130,7 @@ var CommitConventionalType = (() => {
128
130
  }
129
131
  return { ...enumObject, hasInstance, getData, values, parse, findWhere };
130
132
  })();
131
- var Emoji;
133
+ exports.Emoji = void 0;
132
134
  ((Emoji2) => {
133
135
  Emoji2.reEmojiUnicode = emojiRegexp__default.default();
134
136
  Emoji2.reEmojiText = /:\w*:/;
@@ -147,8 +149,8 @@ var Emoji;
147
149
  return isText(anyValue) || isUnicode(anyValue);
148
150
  }
149
151
  Emoji2.hasInstance = hasInstance;
150
- })(Emoji || (Emoji = {}));
151
- var GitmojiCode;
152
+ })(exports.Emoji || (exports.Emoji = {}));
153
+ exports.GitmojiCode = void 0;
152
154
  ((GitmojiCode2) => {
153
155
  const allGitmojiCodes = new Set(
154
156
  gitmojis.gitmojis.map((gitmoji) => gitmoji.code).concat(gitmojis.gitmojis.map((gitmoji) => gitmoji.emoji))
@@ -201,35 +203,32 @@ var GitmojiCode;
201
203
  return conversionMap.get(gitmoji) ?? defaultType;
202
204
  }
203
205
  GitmojiCode2.toConventionalCommitType = toConventionalCommitType2;
204
- })(GitmojiCode || (GitmojiCode = {}));
206
+ })(exports.GitmojiCode || (exports.GitmojiCode = {}));
205
207
 
206
- // src/recommended-bump-opts.ts
208
+ // src/whatBump.ts
207
209
  function toConventionalCommitType(text) {
208
- return GitmojiCode.isValid(text) ? GitmojiCode.toConventionalCommitType(text) : CommitConventionalType.hasInstance(text) ? text : void 0;
210
+ return exports.GitmojiCode.isValid(text) ? exports.GitmojiCode.toConventionalCommitType(text) : CommitConventionalType.hasInstance(text) ? text : void 0;
209
211
  }
210
- var recommendedBumpOpts = {
211
- parserOpts,
212
- whatBump: (commits) => {
213
- let level = 2;
214
- let breakings = 0;
215
- let features = 0;
216
- for (const { type, notes } of commits) {
217
- const conventionalType = type == null ? type : toConventionalCommitType(type);
218
- if (notes.length > 0) {
219
- breakings += notes.length;
220
- level = 0;
221
- } else if (conventionalType === CommitConventionalType.Feat) {
222
- features += 1;
223
- if (level === 2) {
224
- level = 1;
225
- }
212
+ var whatBump = (commits) => {
213
+ let level = 2;
214
+ let breakings = 0;
215
+ let features = 0;
216
+ for (const { type, notes } of commits) {
217
+ const conventionalType = type == null ? type : toConventionalCommitType(type);
218
+ if (notes.length > 0) {
219
+ breakings += notes.length;
220
+ level = 0;
221
+ } else if (conventionalType === CommitConventionalType.Feat) {
222
+ features += 1;
223
+ if (level === 2) {
224
+ level = 1;
226
225
  }
227
226
  }
228
- return {
229
- level,
230
- reason: breakings === 1 ? `There is ${breakings} BREAKING CHANGE and ${features} features` : `There are ${breakings} BREAKING CHANGES and ${features} features`
231
- };
232
227
  }
228
+ return {
229
+ level,
230
+ reason: breakings === 1 ? `There is ${breakings} BREAKING CHANGE and ${features} features` : `There are ${breakings} BREAKING CHANGES and ${features} features`
231
+ };
233
232
  };
234
233
 
235
234
  // src/transform.ts
@@ -255,14 +254,14 @@ function createTransform(config) {
255
254
  ...note,
256
255
  title: `${config.withEmoji === false ? "" : "\u{1F4A5} "}BREAKING CHANGES`
257
256
  }));
258
- const conventionalType = commit.type == null ? void 0 : CommitConventionalType.parse(commit.type) ?? (GitmojiCode.isValid(commit.type) ? GitmojiCode.toConventionalCommitType(commit.type) : void 0);
257
+ const conventionalType = commit.type == null ? void 0 : CommitConventionalType.parse(commit.type) ?? (exports.GitmojiCode.isValid(commit.type) ? exports.GitmojiCode.toConventionalCommitType(commit.type) : void 0);
259
258
  if (ignoreType(conventionalType) && discard) return false;
260
- const type = conventionalType == null ? conventionalType : displayType(conventionalType, {
259
+ const type = conventionalType == null ? null : displayType(conventionalType, {
261
260
  withEmoji: config.withEmoji
262
261
  });
263
262
  if (ignoreScope(commit.scope)) return false;
264
263
  const scopeIntermediate = commit.scope === "*" ? "" : commit.scope;
265
- const scope = config.scopeDisplayName == null ? scopeIntermediate : displayScope(scopeIntermediate, config.scopeDisplayName);
264
+ const scope = config.scopeDisplayName == null ? null : displayScope(scopeIntermediate, config.scopeDisplayName) ?? null;
266
265
  const hash = typeof commit.hash === "string" ? commit.hash.slice(0, 7) : commit.hash;
267
266
  const subject = typeof commit.subject === "string" ? (() => {
268
267
  let returnValue = commit.subject;
@@ -302,40 +301,43 @@ function createTransform(config) {
302
301
  return transform;
303
302
  }
304
303
 
305
- // src/writer-opts.ts
304
+ // src/writer.ts
306
305
  var _dirname = typeof __dirname === "undefined" ? nodePath__default.default.dirname(url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('index.cjs', document.baseURI).href)))) : __dirname;
307
306
  var basePath = nodePath__default.default.resolve(nodePath__default.default.dirname(_dirname), "./template");
308
- var mainTemplate = fs.readFileSync(`${basePath}/template.hbs`, "utf8");
309
- var headerPartial = fs.readFileSync(`${basePath}/header.hbs`, "utf8");
310
- var commitPartial = fs.readFileSync(`${basePath}/commit.hbs`, "utf8");
311
- var footerPartial = fs.readFileSync(`${basePath}/footer.hbs`, "utf8");
312
- var author = fs.readFileSync(`${basePath}/author.hbs`, "utf8");
313
307
  var defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);
314
- var writerOpts = {
315
- transform: createTransform({
316
- displayTypes: defaultDisplayTypes
317
- }),
318
- groupBy: "type",
319
- commitGroupsSort: "title",
320
- commitsSort: ["scope", "subject"],
321
- noteGroupsSort: "title",
322
- mainTemplate,
323
- headerPartial,
324
- // eslint-disable-next-line unicorn/prefer-string-replace-all
325
- commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
326
- footerPartial
308
+ var createWriterOpts = async () => {
309
+ const mainTemplate = fs.readFileSync(`${basePath}/template.hbs`, "utf8");
310
+ const headerPartial = fs.readFileSync(`${basePath}/header.hbs`, "utf8");
311
+ const commitPartial = fs.readFileSync(`${basePath}/commit.hbs`, "utf8");
312
+ const footerPartial = fs.readFileSync(`${basePath}/footer.hbs`, "utf8");
313
+ const author = fs.readFileSync(`${basePath}/author.hbs`, "utf8");
314
+ return {
315
+ transform: createTransform({
316
+ displayTypes: defaultDisplayTypes
317
+ }),
318
+ groupBy: "type",
319
+ commitGroupsSort: "title",
320
+ // @ts-ignore
321
+ commitsSort: ["scope", "subject"],
322
+ noteGroupsSort: "title",
323
+ mainTemplate,
324
+ headerPartial,
325
+ // eslint-disable-next-line unicorn/prefer-string-replace-all
326
+ commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
327
+ footerPartial
328
+ };
327
329
  };
328
330
 
329
331
  // src/index.ts
330
- var index_default = {
331
- Emoji,
332
- GitmojiCode,
333
- parserOpts,
334
- writerOpts,
335
- recommendedBumpOpts,
336
- gitRawCommitOpts
337
- };
332
+ async function createPreset() {
333
+ return {
334
+ gitRawCommitOpts,
335
+ parser: createParserOpts(),
336
+ writer: await createWriterOpts(),
337
+ whatBump
338
+ };
339
+ }
338
340
 
339
- module.exports = index_default;
341
+ exports.default = createPreset;
340
342
  //# sourceMappingURL=index.cjs.map
341
343
  //# sourceMappingURL=index.cjs.map
@@ -1 +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","emojiRegexp","GitmojiCode","gitmojis","toConventionalCommitType","nodePath","fileURLToPath","readFileSync"],"mappings":"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","file":"index.cjs","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","/* eslint-disable n/no-sync */\nimport { readFileSync } from 'node:fs';\nimport nodePath 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' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;\nconst basePath = nodePath.resolve(nodePath.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';\nimport { Emoji, GitmojiCode } from './gitmoji.js';\n\n// eslint-disable-next-line import/no-default-export\nexport default {\n Emoji,\n GitmojiCode,\n parserOpts,\n writerOpts,\n recommendedBumpOpts,\n gitRawCommitOpts,\n};\n"]}
1
+ {"version":3,"sources":["../src/git-raw-commit-opts.ts","../src/parser.ts","../src/data.ts","../src/gitmoji.ts","../src/whatBump.ts","../src/transform.ts","../src/writer.ts","../src/index.ts"],"names":["Emoji","emojiRegexp","GitmojiCode","gitmojis","toConventionalCommitType","nodePath","fileURLToPath","readFileSync"],"mappings":"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","file":"index.cjs","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 { ParserOptions as ParserOptionsDefault } from 'conventional-commits-parser';\n\nexport interface ParserOptions extends ParserOptionsDefault {}\n\nexport const createParserOpts = (): 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 & {\n type: string | null;\n subject: string | null;\n scope: string | null;\n hash: string | null;\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 { 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 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","import type { CommitTransformFunction, Context } 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 | undefined;\n readonly language?: Language;\n }\n}\n\nexport function createTransform(config: TransformConfig): CommitTransformFunction<Commit> {\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 ? null\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 ? null : (displayScope(scopeIntermediate, config.scopeDisplayName) ?? null);\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 // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\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 } as Commit;\n };\n\n return transform as unknown as CommitTransformFunction<Commit>;\n}\n","/* eslint-disable n/no-sync */\nimport { readFileSync } from 'node:fs';\nimport nodePath from 'node:path';\nimport type { Options } from 'conventional-changelog-writer';\nimport { fileURLToPath } from 'node:url';\nimport { createTransform } from './transform.js';\nimport { Commit, CommitConventionalType } from './data.js';\n\nexport interface WriterOptions extends Options<Commit> {}\n\nconst _dirname = typeof __dirname === 'undefined' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;\nconst basePath = nodePath.resolve(nodePath.dirname(_dirname), './template');\n\nexport const defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);\n\nexport const createWriterOpts = async (): Promise<WriterOptions> => {\n const mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');\n const headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');\n const commitPartial = readFileSync(`${basePath}/commit.hbs`, 'utf8');\n const footerPartial = readFileSync(`${basePath}/footer.hbs`, 'utf8');\n const author = readFileSync(`${basePath}/author.hbs`, 'utf8');\n\n return {\n transform: createTransform({\n displayTypes: defaultDisplayTypes,\n }),\n groupBy: 'type',\n commitGroupsSort: 'title',\n // @ts-ignore\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};\n","import { gitRawCommitOpts } from './git-raw-commit-opts.js';\nimport { createParserOpts } from './parser.js';\nimport { whatBump } from './whatBump.js';\nimport { createWriterOpts } from './writer.js';\n\nexport { Emoji, GitmojiCode } from './gitmoji.js';\n\n// eslint-disable-next-line import/no-default-export\nexport default async function createPreset() {\n return {\n gitRawCommitOpts,\n parser: createParserOpts(),\n writer: await createWriterOpts(),\n whatBump,\n };\n}\n"]}
package/dist/index.d.cts CHANGED
@@ -1,11 +1,14 @@
1
- import { Options, Commit as Commit$1 } from 'conventional-commits-parser';
2
- import { Options as Options$1 } from 'conventional-changelog-writer';
1
+ import { Commit as Commit$2, ParserOptions as ParserOptions$1 } from 'conventional-commits-parser';
2
+ import { Options } from 'conventional-changelog-writer';
3
3
 
4
- interface ParserOptions extends Options {
5
- }
6
-
7
- type Commit = Commit$1;
4
+ type Commit$1 = Commit$2;
8
5
 
6
+ type Commit = Commit$2 & {
7
+ type: string | null;
8
+ subject: string | null;
9
+ scope: string | null;
10
+ hash: string | null;
11
+ };
9
12
  type CommitConventionalType = 'build' | 'ci' | 'docs' | 'feat' | 'fix' | 'perf' | 'refactor' | 'revert' | 'style' | 'test' | 'wip' | 'chore';
10
13
  declare const CommitConventionalType: {
11
14
  hasInstance: (anyValue: unknown) => anyValue is CommitConventionalType;
@@ -32,7 +35,10 @@ interface CommitConventionalTypeData {
32
35
  changelog: boolean;
33
36
  }
34
37
 
35
- interface WriterOptions extends Options$1 {
38
+ interface WriterOptions extends Options<Commit> {
39
+ }
40
+
41
+ interface ParserOptions extends ParserOptions$1 {
36
42
  }
37
43
 
38
44
  type Emoji = Emoji.Unicode | Emoji.Text;
@@ -63,21 +69,16 @@ declare namespace GitmojiCode {
63
69
  function toConventionalCommitType(gitmoji: GitmojiCode): CommitConventionalType;
64
70
  }
65
71
 
66
- declare const _default: {
67
- Emoji: typeof Emoji;
68
- GitmojiCode: typeof GitmojiCode;
69
- parserOpts: ParserOptions;
70
- writerOpts: WriterOptions;
71
- recommendedBumpOpts: {
72
- parserOpts: ParserOptions;
73
- whatBump: (commits: ReadonlyArray<Commit>) => {
74
- level: number;
75
- reason: string;
76
- };
77
- };
72
+ declare function createPreset(): Promise<{
78
73
  gitRawCommitOpts: {
79
74
  format: string;
80
75
  };
81
- };
76
+ parser: ParserOptions;
77
+ writer: WriterOptions;
78
+ whatBump: (commits: ReadonlyArray<Commit$1>) => {
79
+ level: number;
80
+ reason: string;
81
+ };
82
+ }>;
82
83
 
83
- export { _default as default };
84
+ export { Emoji, GitmojiCode, createPreset as default };
package/dist/index.d.ts CHANGED
@@ -1,11 +1,14 @@
1
- import { Options, Commit as Commit$1 } from 'conventional-commits-parser';
2
- import { Options as Options$1 } from 'conventional-changelog-writer';
1
+ import { Commit as Commit$2, ParserOptions as ParserOptions$1 } from 'conventional-commits-parser';
2
+ import { Options } from 'conventional-changelog-writer';
3
3
 
4
- interface ParserOptions extends Options {
5
- }
6
-
7
- type Commit = Commit$1;
4
+ type Commit$1 = Commit$2;
8
5
 
6
+ type Commit = Commit$2 & {
7
+ type: string | null;
8
+ subject: string | null;
9
+ scope: string | null;
10
+ hash: string | null;
11
+ };
9
12
  type CommitConventionalType = 'build' | 'ci' | 'docs' | 'feat' | 'fix' | 'perf' | 'refactor' | 'revert' | 'style' | 'test' | 'wip' | 'chore';
10
13
  declare const CommitConventionalType: {
11
14
  hasInstance: (anyValue: unknown) => anyValue is CommitConventionalType;
@@ -32,7 +35,10 @@ interface CommitConventionalTypeData {
32
35
  changelog: boolean;
33
36
  }
34
37
 
35
- interface WriterOptions extends Options$1 {
38
+ interface WriterOptions extends Options<Commit> {
39
+ }
40
+
41
+ interface ParserOptions extends ParserOptions$1 {
36
42
  }
37
43
 
38
44
  type Emoji = Emoji.Unicode | Emoji.Text;
@@ -63,21 +69,16 @@ declare namespace GitmojiCode {
63
69
  function toConventionalCommitType(gitmoji: GitmojiCode): CommitConventionalType;
64
70
  }
65
71
 
66
- declare const _default: {
67
- Emoji: typeof Emoji;
68
- GitmojiCode: typeof GitmojiCode;
69
- parserOpts: ParserOptions;
70
- writerOpts: WriterOptions;
71
- recommendedBumpOpts: {
72
- parserOpts: ParserOptions;
73
- whatBump: (commits: ReadonlyArray<Commit>) => {
74
- level: number;
75
- reason: string;
76
- };
77
- };
72
+ declare function createPreset(): Promise<{
78
73
  gitRawCommitOpts: {
79
74
  format: string;
80
75
  };
81
- };
76
+ parser: ParserOptions;
77
+ writer: WriterOptions;
78
+ whatBump: (commits: ReadonlyArray<Commit$1>) => {
79
+ level: number;
80
+ reason: string;
81
+ };
82
+ }>;
82
83
 
83
- export { _default as default };
84
+ export { Emoji, GitmojiCode, createPreset as default };
package/dist/index.js CHANGED
@@ -1,16 +1,16 @@
1
1
  import emojiRegexp from 'emoji-regex';
2
2
  import { gitmojis } from 'gitmojis';
3
- import { readFileSync } from 'node:fs';
4
- import nodePath from 'node:path';
5
- import { fileURLToPath } from 'node:url';
3
+ import { readFileSync } from 'fs';
4
+ import nodePath from 'path';
5
+ import { fileURLToPath } from 'url';
6
6
 
7
7
  // src/git-raw-commit-opts.ts
8
8
  var gitRawCommitOpts = {
9
9
  format: "%B%n-hash-%n%H%n-gitTags-%n%d%n-committerDate-%n%ci%n-authorName-%n%an%n-authorEmail-%n%ae"
10
10
  };
11
11
 
12
- // src/parser-opts.ts
13
- var parserOpts = {
12
+ // src/parser.ts
13
+ var createParserOpts = () => ({
14
14
  headerPattern: new RegExp(
15
15
  // Type
16
16
  `^(?<type>\\S*)? (?:\\((?<scope>.*)\\):? )?(?<subject>.*)$`,
@@ -21,7 +21,7 @@ var parserOpts = {
21
21
  noteKeywords: ["BREAKING CHANGE", "BREAKING CHANGES"],
22
22
  // revertPattern: /revert:\s([\S\s]*?)\s*this reverts commit (\w*)\./i,
23
23
  revertCorrespondence: [`header`, `hash`]
24
- };
24
+ });
25
25
 
26
26
  // src/data.ts
27
27
  var CommitConventionalType = (() => {
@@ -195,33 +195,30 @@ var GitmojiCode;
195
195
  GitmojiCode2.toConventionalCommitType = toConventionalCommitType2;
196
196
  })(GitmojiCode || (GitmojiCode = {}));
197
197
 
198
- // src/recommended-bump-opts.ts
198
+ // src/whatBump.ts
199
199
  function toConventionalCommitType(text) {
200
200
  return GitmojiCode.isValid(text) ? GitmojiCode.toConventionalCommitType(text) : CommitConventionalType.hasInstance(text) ? text : void 0;
201
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
- }
202
+ var whatBump = (commits) => {
203
+ let level = 2;
204
+ let breakings = 0;
205
+ let features = 0;
206
+ for (const { type, notes } of commits) {
207
+ const conventionalType = type == null ? type : toConventionalCommitType(type);
208
+ if (notes.length > 0) {
209
+ breakings += notes.length;
210
+ level = 0;
211
+ } else if (conventionalType === CommitConventionalType.Feat) {
212
+ features += 1;
213
+ if (level === 2) {
214
+ level = 1;
218
215
  }
219
216
  }
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
217
  }
218
+ return {
219
+ level,
220
+ reason: breakings === 1 ? `There is ${breakings} BREAKING CHANGE and ${features} features` : `There are ${breakings} BREAKING CHANGES and ${features} features`
221
+ };
225
222
  };
226
223
 
227
224
  // src/transform.ts
@@ -249,12 +246,12 @@ function createTransform(config) {
249
246
  }));
250
247
  const conventionalType = commit.type == null ? void 0 : CommitConventionalType.parse(commit.type) ?? (GitmojiCode.isValid(commit.type) ? GitmojiCode.toConventionalCommitType(commit.type) : void 0);
251
248
  if (ignoreType(conventionalType) && discard) return false;
252
- const type = conventionalType == null ? conventionalType : displayType(conventionalType, {
249
+ const type = conventionalType == null ? null : displayType(conventionalType, {
253
250
  withEmoji: config.withEmoji
254
251
  });
255
252
  if (ignoreScope(commit.scope)) return false;
256
253
  const scopeIntermediate = commit.scope === "*" ? "" : commit.scope;
257
- const scope = config.scopeDisplayName == null ? scopeIntermediate : displayScope(scopeIntermediate, config.scopeDisplayName);
254
+ const scope = config.scopeDisplayName == null ? null : displayScope(scopeIntermediate, config.scopeDisplayName) ?? null;
258
255
  const hash = typeof commit.hash === "string" ? commit.hash.slice(0, 7) : commit.hash;
259
256
  const subject = typeof commit.subject === "string" ? (() => {
260
257
  let returnValue = commit.subject;
@@ -294,40 +291,43 @@ function createTransform(config) {
294
291
  return transform;
295
292
  }
296
293
 
297
- // src/writer-opts.ts
294
+ // src/writer.ts
298
295
  var _dirname = typeof __dirname === "undefined" ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;
299
296
  var basePath = nodePath.resolve(nodePath.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
297
  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
298
+ var createWriterOpts = async () => {
299
+ const mainTemplate = readFileSync(`${basePath}/template.hbs`, "utf8");
300
+ const headerPartial = readFileSync(`${basePath}/header.hbs`, "utf8");
301
+ const commitPartial = readFileSync(`${basePath}/commit.hbs`, "utf8");
302
+ const footerPartial = readFileSync(`${basePath}/footer.hbs`, "utf8");
303
+ const author = readFileSync(`${basePath}/author.hbs`, "utf8");
304
+ return {
305
+ transform: createTransform({
306
+ displayTypes: defaultDisplayTypes
307
+ }),
308
+ groupBy: "type",
309
+ commitGroupsSort: "title",
310
+ // @ts-ignore
311
+ commitsSort: ["scope", "subject"],
312
+ noteGroupsSort: "title",
313
+ mainTemplate,
314
+ headerPartial,
315
+ // eslint-disable-next-line unicorn/prefer-string-replace-all
316
+ commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
317
+ footerPartial
318
+ };
319
319
  };
320
320
 
321
321
  // src/index.ts
322
- var index_default = {
323
- Emoji,
324
- GitmojiCode,
325
- parserOpts,
326
- writerOpts,
327
- recommendedBumpOpts,
328
- gitRawCommitOpts
329
- };
322
+ async function createPreset() {
323
+ return {
324
+ gitRawCommitOpts,
325
+ parser: createParserOpts(),
326
+ writer: await createWriterOpts(),
327
+ whatBump
328
+ };
329
+ }
330
330
 
331
- export { index_default as default };
331
+ export { Emoji, GitmojiCode, createPreset as default };
332
332
  //# sourceMappingURL=index.js.map
333
333
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +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","/* eslint-disable n/no-sync */\nimport { readFileSync } from 'node:fs';\nimport nodePath 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' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;\nconst basePath = nodePath.resolve(nodePath.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';\nimport { Emoji, GitmojiCode } from './gitmoji.js';\n\n// eslint-disable-next-line import/no-default-export\nexport default {\n Emoji,\n GitmojiCode,\n parserOpts,\n writerOpts,\n recommendedBumpOpts,\n gitRawCommitOpts,\n};\n"]}
1
+ {"version":3,"sources":["../src/git-raw-commit-opts.ts","../src/parser.ts","../src/data.ts","../src/gitmoji.ts","../src/whatBump.ts","../src/transform.ts","../src/writer.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 { ParserOptions as ParserOptionsDefault } from 'conventional-commits-parser';\n\nexport interface ParserOptions extends ParserOptionsDefault {}\n\nexport const createParserOpts = (): 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 & {\n type: string | null;\n subject: string | null;\n scope: string | null;\n hash: string | null;\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 { 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 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","import type { CommitTransformFunction, Context } 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 | undefined;\n readonly language?: Language;\n }\n}\n\nexport function createTransform(config: TransformConfig): CommitTransformFunction<Commit> {\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 ? null\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 ? null : (displayScope(scopeIntermediate, config.scopeDisplayName) ?? null);\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 // eslint-disable-next-line @typescript-eslint/consistent-type-assertions\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 } as Commit;\n };\n\n return transform as unknown as CommitTransformFunction<Commit>;\n}\n","/* eslint-disable n/no-sync */\nimport { readFileSync } from 'node:fs';\nimport nodePath from 'node:path';\nimport type { Options } from 'conventional-changelog-writer';\nimport { fileURLToPath } from 'node:url';\nimport { createTransform } from './transform.js';\nimport { Commit, CommitConventionalType } from './data.js';\n\nexport interface WriterOptions extends Options<Commit> {}\n\nconst _dirname = typeof __dirname === 'undefined' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;\nconst basePath = nodePath.resolve(nodePath.dirname(_dirname), './template');\n\nexport const defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);\n\nexport const createWriterOpts = async (): Promise<WriterOptions> => {\n const mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');\n const headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');\n const commitPartial = readFileSync(`${basePath}/commit.hbs`, 'utf8');\n const footerPartial = readFileSync(`${basePath}/footer.hbs`, 'utf8');\n const author = readFileSync(`${basePath}/author.hbs`, 'utf8');\n\n return {\n transform: createTransform({\n displayTypes: defaultDisplayTypes,\n }),\n groupBy: 'type',\n commitGroupsSort: 'title',\n // @ts-ignore\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};\n","import { gitRawCommitOpts } from './git-raw-commit-opts.js';\nimport { createParserOpts } from './parser.js';\nimport { whatBump } from './whatBump.js';\nimport { createWriterOpts } from './writer.js';\n\nexport { Emoji, GitmojiCode } from './gitmoji.js';\n\n// eslint-disable-next-line import/no-default-export\nexport default async function createPreset() {\n return {\n gitRawCommitOpts,\n parser: createParserOpts(),\n writer: await createWriterOpts(),\n whatBump,\n };\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@w5s/conventional-changelog",
3
- "version": "2.2.2",
3
+ "version": "2.2.4",
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",
@@ -53,5 +53,5 @@
53
53
  "access": "public"
54
54
  },
55
55
  "sideEffect": false,
56
- "gitHead": "4617d8f7fa8546c928dcb225e5a2735302ce1c85"
56
+ "gitHead": "e50ce223ae442c3c06efe68aae22809092184290"
57
57
  }
package/src/data.ts CHANGED
@@ -1,7 +1,10 @@
1
1
  import type { Commit as CommitDefault } from 'conventional-commits-parser';
2
2
 
3
- export type Commit = CommitDefault<never> & {
4
- hash?: string;
3
+ export type Commit = CommitDefault & {
4
+ type: string | null;
5
+ subject: string | null;
6
+ scope: string | null;
7
+ hash: string | null;
5
8
  };
6
9
 
7
10
  export type CommitConventionalType =
package/src/index.ts CHANGED
@@ -1,15 +1,16 @@
1
1
  import { gitRawCommitOpts } from './git-raw-commit-opts.js';
2
- import { parserOpts } from './parser-opts.js';
3
- import { recommendedBumpOpts } from './recommended-bump-opts.js';
4
- import { writerOpts } from './writer-opts.js';
5
- import { Emoji, GitmojiCode } from './gitmoji.js';
2
+ import { createParserOpts } from './parser.js';
3
+ import { whatBump } from './whatBump.js';
4
+ import { createWriterOpts } from './writer.js';
5
+
6
+ export { Emoji, GitmojiCode } from './gitmoji.js';
6
7
 
7
8
  // eslint-disable-next-line import/no-default-export
8
- export default {
9
- Emoji,
10
- GitmojiCode,
11
- parserOpts,
12
- writerOpts,
13
- recommendedBumpOpts,
14
- gitRawCommitOpts,
15
- };
9
+ export default async function createPreset() {
10
+ return {
11
+ gitRawCommitOpts,
12
+ parser: createParserOpts(),
13
+ writer: await createWriterOpts(),
14
+ whatBump,
15
+ };
16
+ }
@@ -1,8 +1,8 @@
1
- import type { Options } from 'conventional-commits-parser';
1
+ import type { ParserOptions as ParserOptionsDefault } from 'conventional-commits-parser';
2
2
 
3
- export interface ParserOptions extends Options {}
3
+ export interface ParserOptions extends ParserOptionsDefault {}
4
4
 
5
- export const parserOpts: ParserOptions = {
5
+ export const createParserOpts = (): ParserOptions => ({
6
6
  headerPattern: new RegExp(
7
7
  // Type
8
8
  `^(?<type>\\S*)? ` +
@@ -17,4 +17,4 @@ export const parserOpts: ParserOptions = {
17
17
  noteKeywords: ['BREAKING CHANGE', 'BREAKING CHANGES'],
18
18
  // revertPattern: /revert:\s([\S\s]*?)\s*this reverts commit (\w*)\./i,
19
19
  revertCorrespondence: [`header`, `hash`],
20
- };
20
+ });
package/src/transform.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { Context, Options as WriterOptions } from 'conventional-changelog-writer';
1
+ import type { CommitTransformFunction, Context } from 'conventional-changelog-writer';
2
2
  import { CommitConventionalType, Commit } from './data.js';
3
3
  import { GitmojiCode } from './gitmoji.js';
4
4
 
@@ -33,12 +33,12 @@ export function displayType(type: string, options: displayType.Options = {}): st
33
33
  }
34
34
  export namespace displayType {
35
35
  export interface Options {
36
- readonly withEmoji?: boolean;
36
+ readonly withEmoji?: boolean | undefined;
37
37
  readonly language?: Language;
38
38
  }
39
39
  }
40
40
 
41
- export function createTransform(config: TransformConfig): WriterOptions.Transform.Function {
41
+ export function createTransform(config: TransformConfig): CommitTransformFunction<Commit> {
42
42
  const displayTypes = new Set(config.displayTypes == null ? CommitConventionalType.values() : config.displayTypes);
43
43
  const ignoreType = (type: string | undefined) => type == null || !displayTypes.has(type as CommitConventionalType);
44
44
  const ignoreScope = (scope: string | undefined | null) =>
@@ -61,7 +61,7 @@ export function createTransform(config: TransformConfig): WriterOptions.Transfor
61
61
 
62
62
  const type =
63
63
  conventionalType == null
64
- ? conventionalType
64
+ ? null
65
65
  : displayType(conventionalType, {
66
66
  withEmoji: config.withEmoji,
67
67
  });
@@ -70,7 +70,7 @@ export function createTransform(config: TransformConfig): WriterOptions.Transfor
70
70
 
71
71
  const scopeIntermediate = commit.scope === '*' ? '' : commit.scope;
72
72
  const scope =
73
- config.scopeDisplayName == null ? scopeIntermediate : displayScope(scopeIntermediate, config.scopeDisplayName);
73
+ config.scopeDisplayName == null ? null : (displayScope(scopeIntermediate, config.scopeDisplayName) ?? null);
74
74
  const hash = typeof commit.hash === 'string' ? commit.hash.slice(0, 7) : commit.hash;
75
75
 
76
76
  const subject =
@@ -102,6 +102,7 @@ export function createTransform(config: TransformConfig): WriterOptions.Transfor
102
102
  // Remove references that already appear in the subject
103
103
  const references = commit.references.filter((reference) => !issues.has(reference.issue));
104
104
 
105
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
105
106
  return {
106
107
  ...commit,
107
108
  type,
@@ -116,8 +117,8 @@ export function createTransform(config: TransformConfig): WriterOptions.Transfor
116
117
  revert: commit.revert,
117
118
  notes,
118
119
  mentions: commit.mentions,
119
- };
120
+ } as Commit;
120
121
  };
121
122
 
122
- return transform as unknown as WriterOptions.Transform.Function;
123
+ return transform as unknown as CommitTransformFunction<Commit>;
123
124
  }
@@ -0,0 +1,40 @@
1
+ import type { Commit as CommitBase } from 'conventional-commits-parser';
2
+ import { CommitConventionalType } from './data.js';
3
+ import { GitmojiCode } from './gitmoji.js';
4
+
5
+ function toConventionalCommitType(text: string) {
6
+ return GitmojiCode.isValid(text)
7
+ ? GitmojiCode.toConventionalCommitType(text)
8
+ : CommitConventionalType.hasInstance(text)
9
+ ? text
10
+ : undefined;
11
+ }
12
+
13
+ export type Commit = CommitBase;
14
+
15
+ export const whatBump = (commits: ReadonlyArray<Commit>) => {
16
+ let level = 2;
17
+ let breakings = 0;
18
+ let features = 0;
19
+
20
+ for (const { type, notes } of commits) {
21
+ const conventionalType = type == null ? type : toConventionalCommitType(type);
22
+ if (notes.length > 0) {
23
+ breakings += notes.length;
24
+ level = 0;
25
+ } else if (conventionalType === CommitConventionalType.Feat) {
26
+ features += 1;
27
+ if (level === 2) {
28
+ level = 1;
29
+ }
30
+ }
31
+ }
32
+
33
+ return {
34
+ level,
35
+ reason:
36
+ breakings === 1
37
+ ? `There is ${breakings} BREAKING CHANGE and ${features} features`
38
+ : `There are ${breakings} BREAKING CHANGES and ${features} features`,
39
+ };
40
+ };
package/src/writer.ts ADDED
@@ -0,0 +1,38 @@
1
+ /* eslint-disable n/no-sync */
2
+ import { readFileSync } from 'node:fs';
3
+ import nodePath from 'node:path';
4
+ import type { Options } from 'conventional-changelog-writer';
5
+ import { fileURLToPath } from 'node:url';
6
+ import { createTransform } from './transform.js';
7
+ import { Commit, CommitConventionalType } from './data.js';
8
+
9
+ export interface WriterOptions extends Options<Commit> {}
10
+
11
+ const _dirname = typeof __dirname === 'undefined' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;
12
+ const basePath = nodePath.resolve(nodePath.dirname(_dirname), './template');
13
+
14
+ export const defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);
15
+
16
+ export const createWriterOpts = async (): Promise<WriterOptions> => {
17
+ const mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');
18
+ const headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');
19
+ const commitPartial = readFileSync(`${basePath}/commit.hbs`, 'utf8');
20
+ const footerPartial = readFileSync(`${basePath}/footer.hbs`, 'utf8');
21
+ const author = readFileSync(`${basePath}/author.hbs`, 'utf8');
22
+
23
+ return {
24
+ transform: createTransform({
25
+ displayTypes: defaultDisplayTypes,
26
+ }),
27
+ groupBy: 'type',
28
+ commitGroupsSort: 'title',
29
+ // @ts-ignore
30
+ commitsSort: ['scope', 'subject'],
31
+ noteGroupsSort: 'title',
32
+ mainTemplate,
33
+ headerPartial,
34
+ // eslint-disable-next-line unicorn/prefer-string-replace-all
35
+ commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
36
+ footerPartial,
37
+ };
38
+ };
@@ -1,44 +0,0 @@
1
- import type { Commit as CommitBase } from 'conventional-commits-parser';
2
- import { parserOpts } from './parser-opts.js';
3
- import { CommitConventionalType } from './data.js';
4
- import { GitmojiCode } from './gitmoji.js';
5
-
6
- function toConventionalCommitType(text: string) {
7
- return GitmojiCode.isValid(text)
8
- ? GitmojiCode.toConventionalCommitType(text)
9
- : CommitConventionalType.hasInstance(text)
10
- ? text
11
- : undefined;
12
- }
13
-
14
- export type Commit = CommitBase;
15
-
16
- export const recommendedBumpOpts = {
17
- parserOpts,
18
- whatBump: (commits: ReadonlyArray<Commit>) => {
19
- let level = 2;
20
- let breakings = 0;
21
- let features = 0;
22
-
23
- for (const { type, notes } of commits) {
24
- const conventionalType = type == null ? type : toConventionalCommitType(type);
25
- if (notes.length > 0) {
26
- breakings += notes.length;
27
- level = 0;
28
- } else if (conventionalType === CommitConventionalType.Feat) {
29
- features += 1;
30
- if (level === 2) {
31
- level = 1;
32
- }
33
- }
34
- }
35
-
36
- return {
37
- level,
38
- reason:
39
- breakings === 1
40
- ? `There is ${breakings} BREAKING CHANGE and ${features} features`
41
- : `There are ${breakings} BREAKING CHANGES and ${features} features`,
42
- };
43
- },
44
- };
@@ -1,35 +0,0 @@
1
- /* eslint-disable n/no-sync */
2
- import { readFileSync } from 'node:fs';
3
- import nodePath from 'node:path';
4
- import type { Options } from 'conventional-changelog-writer';
5
- import { fileURLToPath } from 'node:url';
6
- import { createTransform } from './transform.js';
7
- import { CommitConventionalType } from './data.js';
8
-
9
- export interface WriterOptions extends Options {}
10
-
11
- const _dirname = typeof __dirname === 'undefined' ? nodePath.dirname(fileURLToPath(import.meta.url)) : __dirname;
12
- const basePath = nodePath.resolve(nodePath.dirname(_dirname), './template');
13
-
14
- const mainTemplate = readFileSync(`${basePath}/template.hbs`, 'utf8');
15
- const headerPartial = readFileSync(`${basePath}/header.hbs`, 'utf8');
16
- const commitPartial = readFileSync(`${basePath}/commit.hbs`, 'utf8');
17
- const footerPartial = readFileSync(`${basePath}/footer.hbs`, 'utf8');
18
- const author = readFileSync(`${basePath}/author.hbs`, 'utf8');
19
-
20
- export const defaultDisplayTypes = CommitConventionalType.findWhere((_) => _.changelog);
21
-
22
- export const writerOpts: WriterOptions = {
23
- transform: createTransform({
24
- displayTypes: defaultDisplayTypes,
25
- }),
26
- groupBy: 'type',
27
- commitGroupsSort: 'title',
28
- commitsSort: ['scope', 'subject'],
29
- noteGroupsSort: 'title',
30
- mainTemplate,
31
- headerPartial,
32
- // eslint-disable-next-line unicorn/prefer-string-replace-all
33
- commitPartial: commitPartial.replace(/{{gitUserInfo}}/g, author),
34
- footerPartial,
35
- };