renovate 39.242.2 → 39.243.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,7 +1,11 @@
|
|
1
1
|
"use strict";
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.getPrConfigDescription = getPrConfigDescription;
|
4
|
+
const tslib_1 = require("tslib");
|
5
|
+
const croner_1 = require("croner");
|
6
|
+
const cronstrue_1 = tslib_1.__importDefault(require("cronstrue"));
|
4
7
|
const emoji_1 = require("../../../../../util/emoji");
|
8
|
+
const string_1 = require("../../../../../util/string");
|
5
9
|
function getPrConfigDescription(config) {
|
6
10
|
let prBody = `\n\n---\n\n### Configuration\n\n`;
|
7
11
|
prBody += (0, emoji_1.emojify)(`:date: **Schedule**: `);
|
@@ -46,7 +50,8 @@ function getPrConfigDescription(config) {
|
|
46
50
|
function scheduleToString(schedule, timezone) {
|
47
51
|
let scheduleString = '';
|
48
52
|
if (schedule && schedule[0] !== 'at any time') {
|
49
|
-
scheduleString
|
53
|
+
scheduleString =
|
54
|
+
getReadableCronSchedule(schedule) ?? `"${String(schedule)}"`;
|
50
55
|
if (timezone) {
|
51
56
|
scheduleString += ` in timezone ${timezone}`;
|
52
57
|
}
|
@@ -59,4 +64,24 @@ function scheduleToString(schedule, timezone) {
|
|
59
64
|
}
|
60
65
|
return scheduleString;
|
61
66
|
}
|
67
|
+
/**
|
68
|
+
* Return human-readable cron schedule summary if the schedule is a valid cron
|
69
|
+
* else return null
|
70
|
+
*/
|
71
|
+
function getReadableCronSchedule(scheduleText) {
|
72
|
+
// assuming if one schedule is cron the others in the array will be cron too
|
73
|
+
try {
|
74
|
+
new croner_1.CronPattern(scheduleText[0]); // validate cron
|
75
|
+
return scheduleText
|
76
|
+
.map((cron) => (0, string_1.capitalize)(cronstrue_1.default
|
77
|
+
.toString(cron, {
|
78
|
+
throwExceptionOnParseError: false,
|
79
|
+
})
|
80
|
+
.replace('Every minute, ', '')) + ` ( ${cron} )`)
|
81
|
+
.join(', ');
|
82
|
+
}
|
83
|
+
catch {
|
84
|
+
return null;
|
85
|
+
}
|
86
|
+
}
|
62
87
|
//# sourceMappingURL=config-description.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"config-description.js","sourceRoot":"","sources":["../../../../../../lib/workers/repository/update/pr/body/config-description.ts"],"names":[],"mappings":";;
|
1
|
+
{"version":3,"file":"config-description.js","sourceRoot":"","sources":["../../../../../../lib/workers/repository/update/pr/body/config-description.ts"],"names":[],"mappings":"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","sourcesContent":["import { CronPattern } from 'croner';\nimport cronstrue from 'cronstrue';\nimport { emojify } from '../../../../../util/emoji';\nimport { capitalize } from '../../../../../util/string';\nimport type { BranchConfig } from '../../../../types';\n\nexport function getPrConfigDescription(config: BranchConfig): string {\n let prBody = `\\n\\n---\\n\\n### Configuration\\n\\n`;\n prBody += emojify(`:date: **Schedule**: `);\n prBody +=\n 'Branch creation - ' + scheduleToString(config.schedule, config.timezone);\n prBody +=\n ', Automerge - ' +\n scheduleToString(config.automergeSchedule, config.timezone) +\n '.';\n\n prBody += '\\n\\n';\n prBody += emojify(':vertical_traffic_light: **Automerge**: ');\n if (config.automerge) {\n prBody += 'Enabled.';\n } else if (config.automergedPreviously) {\n prBody += 'Disabled because a matching PR was automerged previously.';\n } else {\n prBody +=\n 'Disabled by config. Please merge this manually once you are satisfied.';\n }\n prBody += '\\n\\n';\n prBody += emojify(':recycle: **Rebasing**: ');\n if (config.rebaseWhen === 'behind-base-branch') {\n prBody += 'Whenever PR is behind base branch';\n } else if (config.rebaseWhen === 'never' || config.stopUpdating) {\n prBody += 'Never';\n } else {\n prBody += 'Whenever PR becomes conflicted';\n }\n prBody += `, or you tick the rebase/retry checkbox.\\n\\n`;\n if (config.recreateClosed) {\n prBody += emojify(\n `:ghost: **Immortal**: This PR will be recreated if closed unmerged. Get [config help](${config.productLinks?.help}) if that's undesired.\\n\\n`,\n );\n } else {\n prBody += emojify(\n `:no_bell: **Ignore**: Close this PR and you won't be reminded about ${\n config.upgrades.length === 1 ? 'this update' : 'these updates'\n } again.\\n\\n`,\n );\n }\n return prBody;\n}\n\nfunction scheduleToString(\n schedule: string[] | undefined,\n timezone: string | undefined,\n): string {\n let scheduleString = '';\n if (schedule && schedule[0] !== 'at any time') {\n scheduleString =\n getReadableCronSchedule(schedule) ?? `\"${String(schedule)}\"`;\n if (timezone) {\n scheduleString += ` in timezone ${timezone}`;\n } else {\n scheduleString += ` (UTC)`;\n }\n } else {\n scheduleString += 'At any time (no schedule defined)';\n }\n return scheduleString;\n}\n\n/**\n * Return human-readable cron schedule summary if the schedule is a valid cron\n * else return null\n */\nfunction getReadableCronSchedule(scheduleText: string[]): string | null {\n // assuming if one schedule is cron the others in the array will be cron too\n try {\n new CronPattern(scheduleText[0]); // validate cron\n return scheduleText\n .map(\n (cron) =>\n capitalize(\n cronstrue\n .toString(cron, {\n throwExceptionOnParseError: false,\n })\n .replace('Every minute, ', ''),\n ) + ` ( ${cron} )`,\n )\n .join(', ');\n } catch {\n return null;\n }\n}\n"]}
|