mirror of
https://github.com/actions/stale.git
synced 2025-12-28 02:58:17 +00:00
* 🎨 add message grouping * ⚗️ try output * 🔥 remove unnecessary code * ⬆️ bump deps * 🎨 build project * ⬆️ bump deps * 🎨 formatting code * ⬇️ revert bumps * 🎨 using logger service * 🎨 using package lock version 1 * 🎨 add engines keyword * ♻️ create processIssue method * ✨ add grouping method * 🎨 build project * 🎨 update engine declaration * 💚 fix merge conflicts
84 lines
2.1 KiB
TypeScript
84 lines
2.1 KiB
TypeScript
import {Issue} from '../issue';
|
|
import {Logger} from './logger';
|
|
import {LoggerService} from '../../services/logger.service';
|
|
|
|
/**
|
|
* @description
|
|
* Each log will prefix the message with the issue number
|
|
*
|
|
* @example
|
|
* warning('No stale') => "[#123] No stale"
|
|
*
|
|
* Each log method can have special tokens:
|
|
* - $$type => will replace this by either "pull request" or "issue" depending of the type of issue
|
|
*
|
|
* @example
|
|
* warning('The $$type will stale') => "The pull request will stale"
|
|
*/
|
|
export class IssueLogger extends Logger {
|
|
private readonly _issue: Issue;
|
|
|
|
constructor(issue: Issue) {
|
|
super();
|
|
this._issue = issue;
|
|
}
|
|
|
|
warning(...message: string[]): void {
|
|
super.warning(this._format(...message));
|
|
}
|
|
|
|
info(...message: string[]): void {
|
|
super.info(this._format(...message));
|
|
}
|
|
|
|
error(...message: string[]): void {
|
|
super.error(this._format(...message));
|
|
}
|
|
|
|
async grouping(message: string, fn: () => Promise<void>): Promise<void> {
|
|
return super.grouping(this._format(message), fn);
|
|
}
|
|
|
|
private _replaceTokens(message: Readonly<string>): string {
|
|
return this._replaceTypeToken(message);
|
|
}
|
|
|
|
private _replaceTypeToken(message: Readonly<string>): string {
|
|
return message
|
|
.replace(
|
|
/^\$\$type/,
|
|
this._issue.isPullRequest ? 'Pull request' : 'Issue'
|
|
)
|
|
.replace(
|
|
/\$\$type/g,
|
|
this._issue.isPullRequest ? 'pull request' : 'issue'
|
|
);
|
|
}
|
|
|
|
private _prefixWithIssueNumber(message: Readonly<string>): string {
|
|
return `${this._getPrefix()} ${message}`;
|
|
}
|
|
|
|
private _getIssueNumber(): number {
|
|
return this._issue.number;
|
|
}
|
|
|
|
private _format(...message: string[]): string {
|
|
return this._prefixWithIssueNumber(this._replaceTokens(message.join(' ')));
|
|
}
|
|
|
|
private _getPrefix(): string {
|
|
return this._issue.isPullRequest
|
|
? this._getPullRequestPrefix()
|
|
: this._getIssuePrefix();
|
|
}
|
|
|
|
private _getIssuePrefix(): string {
|
|
return LoggerService.red(`[#${this._getIssueNumber()}]`);
|
|
}
|
|
|
|
private _getPullRequestPrefix(): string {
|
|
return LoggerService.blue(`[#${this._getIssueNumber()}]`);
|
|
}
|
|
}
|