mirror of
https://github.com/louislam/uptime-kuma.git
synced 2025-01-01 00:47:29 -08:00
Merge pull request #2812 from louislam/remove-translate-keys
Remove untranslatable keys and notification list optimization
This commit is contained in:
commit
81a829bda7
|
@ -13,7 +13,10 @@
|
||||||
<div class="mb-3">
|
<div class="mb-3">
|
||||||
<label for="notification-type" class="form-label">{{ $t("Notification Type") }}</label>
|
<label for="notification-type" class="form-label">{{ $t("Notification Type") }}</label>
|
||||||
<select id="notification-type" v-model="notification.type" class="form-select">
|
<select id="notification-type" v-model="notification.type" class="form-select">
|
||||||
<option v-for="type in notificationTypes" :key="type" :value="type">{{ $t(type) }}</option>
|
<option v-for="(name, type) in notificationNameList.regularList" :key="type" :value="type">{{ name }}</option>
|
||||||
|
<optgroup :label="$t('notificationRegional')">
|
||||||
|
<option v-for="(name, type) in notificationNameList.regionalList" :key="type" :value="type">{{ name }}</option>
|
||||||
|
</optgroup>
|
||||||
</select>
|
</select>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
@ -67,7 +70,7 @@
|
||||||
</Confirm>
|
</Confirm>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script>
|
||||||
import { Modal } from "bootstrap";
|
import { Modal } from "bootstrap";
|
||||||
|
|
||||||
import Confirm from "./Confirm.vue";
|
import Confirm from "./Confirm.vue";
|
||||||
|
@ -103,7 +106,91 @@ export default {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return NotificationFormList[this.notification.type];
|
return NotificationFormList[this.notification.type];
|
||||||
|
},
|
||||||
|
|
||||||
|
notificationNameList() {
|
||||||
|
let regularList = {
|
||||||
|
"alerta": "Alerta",
|
||||||
|
"AlertNow": "AlertNow",
|
||||||
|
"apprise": this.$t("apprise"),
|
||||||
|
"Bark": "Bark",
|
||||||
|
"clicksendsms": "ClickSend SMS",
|
||||||
|
"discord": "Discord",
|
||||||
|
"GoogleChat": "Google Chat (Google Workspace)",
|
||||||
|
"gorush": "Gorush",
|
||||||
|
"gotify": "Gotify",
|
||||||
|
"HomeAssistant": "Home Assistant",
|
||||||
|
"Kook": "Kook",
|
||||||
|
"line": "LINE Messenger",
|
||||||
|
"LineNotify": "LINE Notify",
|
||||||
|
"lunasea": "LunaSea",
|
||||||
|
"matrix": "Matrix",
|
||||||
|
"mattermost": "Mattermost",
|
||||||
|
"ntfy": "Ntfy",
|
||||||
|
"octopush": "Octopush",
|
||||||
|
"OneBot": "OneBot",
|
||||||
|
"PagerDuty": "PagerDuty",
|
||||||
|
"pushbullet": "Pushbullet",
|
||||||
|
"PushByTechulus": "Push by Techulus",
|
||||||
|
"pushover": "Pushover",
|
||||||
|
"pushy": "Pushy",
|
||||||
|
"rocket.chat": "Rocket.Chat",
|
||||||
|
"signal": "Signal",
|
||||||
|
"slack": "Slack",
|
||||||
|
"squadcast": "SquadCast",
|
||||||
|
"SMSEagle": "SMSEagle",
|
||||||
|
"smtp": this.$t("smtp"),
|
||||||
|
"stackfield": "Stackfield",
|
||||||
|
"teams": "Microsoft Teams",
|
||||||
|
"telegram": "Telegram",
|
||||||
|
"Splunk": "Splunk",
|
||||||
|
"webhook": "Webhook",
|
||||||
|
"GoAlert": "GoAlert",
|
||||||
|
"ZohoCliq": "ZohoCliq"
|
||||||
|
};
|
||||||
|
|
||||||
|
// Put notifications here if it's not supported in most regions or its documentation is not in English
|
||||||
|
let regionalList = {
|
||||||
|
"AliyunSMS": "AliyunSMS (阿里云短信服务)",
|
||||||
|
"DingDing": "DingDing (钉钉自定义机器人)",
|
||||||
|
"Feishu": "Feishu (飞书)",
|
||||||
|
"FreeMobile": "FreeMobile (mobile.free.fr)",
|
||||||
|
"PushDeer": "PushDeer",
|
||||||
|
"promosms": "PromoSMS",
|
||||||
|
"serwersms": "SerwerSMS.pl",
|
||||||
|
"SMSManager": "SmsManager (smsmanager.cz)",
|
||||||
|
"WeCom": "WeCom (企业微信群机器人)",
|
||||||
|
"ServerChan": "ServerChan (Server酱)",
|
||||||
|
};
|
||||||
|
|
||||||
|
// Sort by notification name
|
||||||
|
// No idea how, but it works
|
||||||
|
// https://stackoverflow.com/questions/1069666/sorting-object-property-by-values
|
||||||
|
let sort = (list2) => {
|
||||||
|
return Object.entries(list2)
|
||||||
|
.sort(([ , a ], [ , b ]) => a.localeCompare(b))
|
||||||
|
.reduce((r, [ k, v ]) => ({
|
||||||
|
...r,
|
||||||
|
[k]: v
|
||||||
|
}), {});
|
||||||
|
};
|
||||||
|
|
||||||
|
return {
|
||||||
|
regularList: sort(regularList),
|
||||||
|
regionalList: sort(regionalList),
|
||||||
|
};
|
||||||
|
},
|
||||||
|
|
||||||
|
notificationFullNameList() {
|
||||||
|
let list = {};
|
||||||
|
for (let [ key, value ] of Object.entries(this.notificationNameList.regularList)) {
|
||||||
|
list[key] = value;
|
||||||
}
|
}
|
||||||
|
for (let [ key, value ] of Object.entries(this.notificationNameList.regionalList)) {
|
||||||
|
list[key] = value;
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
watch: {
|
watch: {
|
||||||
|
@ -203,11 +290,12 @@ export default {
|
||||||
* @return {string}
|
* @return {string}
|
||||||
*/
|
*/
|
||||||
getUniqueDefaultName(notificationKey) {
|
getUniqueDefaultName(notificationKey) {
|
||||||
|
|
||||||
let index = 1;
|
let index = 1;
|
||||||
let name = "";
|
let name = "";
|
||||||
do {
|
do {
|
||||||
name = this.$t("defaultNotificationName", {
|
name = this.$t("defaultNotificationName", {
|
||||||
notification: this.$t(notificationKey).replace(/\(.+\)/, "").trim(),
|
notification: this.notificationFullNameList[notificationKey].replace(/\(.+\)/, "").trim(),
|
||||||
number: index++
|
number: index++
|
||||||
});
|
});
|
||||||
} while (this.$root.notificationList.find(it => it.name === name));
|
} while (this.$root.notificationList.find(it => it.name === name));
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
<div class="mb-3">
|
<div class="mb-3">
|
||||||
<label for="gorush-platform" class="form-label">{{ $t("Platform") }}</label><span style="color: red;"><sup>*</sup></span>
|
<label for="gorush-platform" class="form-label">{{ $t("Platform") }}</label><span style="color: red;"><sup>*</sup></span>
|
||||||
<select id="gorush-platform" v-model="$parent.notification.gorushPlatform" class="form-select">
|
<select id="gorush-platform" v-model="$parent.notification.gorushPlatform" class="form-select">
|
||||||
<option value="ios">{{ $t("iOS") }}</option>
|
<option value="ios">iOS</option>
|
||||||
<option value="android">{{ $t("Android") }}</option>
|
<option value="android">{{ $t("Android") }}</option>
|
||||||
<option value="huawei">{{ $t("Huawei") }}</option>
|
<option value="huawei">{{ $t("Huawei") }}</option>
|
||||||
</select>
|
</select>
|
||||||
|
|
|
@ -186,7 +186,6 @@
|
||||||
"defaultNotificationName": "My {notification} Alert ({number})",
|
"defaultNotificationName": "My {notification} Alert ({number})",
|
||||||
"here": "here",
|
"here": "here",
|
||||||
"Required": "Required",
|
"Required": "Required",
|
||||||
"webhook": "Webhook",
|
|
||||||
"Post URL": "Post URL",
|
"Post URL": "Post URL",
|
||||||
"Content Type": "Content Type",
|
"Content Type": "Content Type",
|
||||||
"webhookJsonDesc": "{0} is good for any modern HTTP servers such as Express.js",
|
"webhookJsonDesc": "{0} is good for any modern HTTP servers such as Express.js",
|
||||||
|
@ -359,8 +358,6 @@
|
||||||
"Domain": "Domain",
|
"Domain": "Domain",
|
||||||
"Workstation": "Workstation",
|
"Workstation": "Workstation",
|
||||||
"Packet Size": "Packet Size",
|
"Packet Size": "Packet Size",
|
||||||
"telegram": "Telegram",
|
|
||||||
"ZohoCliq": "ZohoCliq",
|
|
||||||
"Bot Token": "Bot Token",
|
"Bot Token": "Bot Token",
|
||||||
"wayToGetTelegramToken": "You can get a token from {0}.",
|
"wayToGetTelegramToken": "You can get a token from {0}.",
|
||||||
"Chat ID": "Chat ID",
|
"Chat ID": "Chat ID",
|
||||||
|
@ -388,7 +385,6 @@
|
||||||
"backupOutdatedWarning": "Deprecated: Since a lot of features were added and this backup feature is a bit unmaintained, it cannot generate or restore a complete backup.",
|
"backupOutdatedWarning": "Deprecated: Since a lot of features were added and this backup feature is a bit unmaintained, it cannot generate or restore a complete backup.",
|
||||||
"backupRecommend": "Please backup the volume or the data folder (./data/) directly instead.",
|
"backupRecommend": "Please backup the volume or the data folder (./data/) directly instead.",
|
||||||
"Optional": "Optional",
|
"Optional": "Optional",
|
||||||
"squadcast": "Squadcast",
|
|
||||||
"or": "or",
|
"or": "or",
|
||||||
"recurringInterval": "Interval",
|
"recurringInterval": "Interval",
|
||||||
"Recurring": "Recurring",
|
"Recurring": "Recurring",
|
||||||
|
@ -436,6 +432,7 @@
|
||||||
"uninstall": "Uninstall",
|
"uninstall": "Uninstall",
|
||||||
"uninstalling": "Uninstalling",
|
"uninstalling": "Uninstalling",
|
||||||
"confirmUninstallPlugin": "Are you sure want to uninstall this plugin?",
|
"confirmUninstallPlugin": "Are you sure want to uninstall this plugin?",
|
||||||
|
"notificationRegional": "Regional",
|
||||||
"smtp": "Email (SMTP)",
|
"smtp": "Email (SMTP)",
|
||||||
"secureOptionNone": "None / STARTTLS (25, 587)",
|
"secureOptionNone": "None / STARTTLS (25, 587)",
|
||||||
"secureOptionTLS": "TLS (465)",
|
"secureOptionTLS": "TLS (465)",
|
||||||
|
@ -530,28 +527,11 @@
|
||||||
"pushoversounds none": "None (silent)",
|
"pushoversounds none": "None (silent)",
|
||||||
"pushyAPIKey": "Secret API Key",
|
"pushyAPIKey": "Secret API Key",
|
||||||
"pushyToken": "Device token",
|
"pushyToken": "Device token",
|
||||||
"discord": "Discord",
|
|
||||||
"teams": "Microsoft Teams",
|
|
||||||
"signal": "Signal",
|
|
||||||
"gotify": "Gotify",
|
|
||||||
"slack": "Slack",
|
|
||||||
"rocket.chat": "Rocket.Chat",
|
|
||||||
"pushover": "Pushover",
|
|
||||||
"pushy": "Pushy",
|
|
||||||
"PushByTechulus": "Push by Techulus",
|
|
||||||
"octopush": "Octopush",
|
|
||||||
"promosms": "PromoSMS",
|
|
||||||
"clicksendsms": "ClickSend SMS",
|
|
||||||
"lunasea": "LunaSea",
|
|
||||||
"apprise": "Apprise (Support 50+ Notification services)",
|
"apprise": "Apprise (Support 50+ Notification services)",
|
||||||
"GoogleChat": "Google Chat (Google Workspace only)",
|
"GoogleChat": "Google Chat (Google Workspace only)",
|
||||||
"pushbullet": "Pushbullet",
|
|
||||||
"Kook": "Kook",
|
|
||||||
"wayToGetKookBotToken": "Create application and get your bot token at {0}",
|
"wayToGetKookBotToken": "Create application and get your bot token at {0}",
|
||||||
"wayToGetKookGuildID": "Switch on 'Developer Mode' in Kook setting, and right click the guild to get its ID",
|
"wayToGetKookGuildID": "Switch on 'Developer Mode' in Kook setting, and right click the guild to get its ID",
|
||||||
"Guild ID": "Guild ID",
|
"Guild ID": "Guild ID",
|
||||||
"line": "Line Messenger",
|
|
||||||
"mattermost": "Mattermost",
|
|
||||||
"User Key": "User Key",
|
"User Key": "User Key",
|
||||||
"Device": "Device",
|
"Device": "Device",
|
||||||
"Message Title": "Message Title",
|
"Message Title": "Message Title",
|
||||||
|
@ -586,12 +566,10 @@
|
||||||
"SendKey": "SendKey",
|
"SendKey": "SendKey",
|
||||||
"SMSManager API Docs": "SMSManager API Docs ",
|
"SMSManager API Docs": "SMSManager API Docs ",
|
||||||
"Gateway Type": "Gateway Type",
|
"Gateway Type": "Gateway Type",
|
||||||
"SMSManager": "SMSManager",
|
|
||||||
"You can divide numbers with": "You can divide numbers with",
|
"You can divide numbers with": "You can divide numbers with",
|
||||||
"Base URL": "Base URL",
|
"Base URL": "Base URL",
|
||||||
"goAlertInfo": "GoAlert is a An open source application for on-call scheduling, automated escalations and notifications (like SMS or voice calls). Automatically engage the right person, the right way, and at the right time! {0}",
|
"goAlertInfo": "GoAlert is a An open source application for on-call scheduling, automated escalations and notifications (like SMS or voice calls). Automatically engage the right person, the right way, and at the right time! {0}",
|
||||||
"goAlertIntegrationKeyInfo": "Get generic API integration key for the service in this format \"aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee\" usually the value of token parameter of copied URL.",
|
"goAlertIntegrationKeyInfo": "Get generic API integration key for the service in this format \"aaaaaaaa-bbbb-cccc-dddd-eeeeeeeeeeee\" usually the value of token parameter of copied URL.",
|
||||||
"goAlert": "GoAlert",
|
|
||||||
"AccessKeyId": "AccessKey ID",
|
"AccessKeyId": "AccessKey ID",
|
||||||
"SecretAccessKey": "AccessKey Secret",
|
"SecretAccessKey": "AccessKey Secret",
|
||||||
"PhoneNumbers": "PhoneNumbers",
|
"PhoneNumbers": "PhoneNumbers",
|
||||||
|
@ -606,7 +584,6 @@
|
||||||
"For safety, must use secret key": "For safety, must use secret key",
|
"For safety, must use secret key": "For safety, must use secret key",
|
||||||
"Device Token": "Device Token",
|
"Device Token": "Device Token",
|
||||||
"Platform": "Platform",
|
"Platform": "Platform",
|
||||||
"iOS": "iOS",
|
|
||||||
"Android": "Android",
|
"Android": "Android",
|
||||||
"Huawei": "Huawei",
|
"Huawei": "Huawei",
|
||||||
"High": "High",
|
"High": "High",
|
||||||
|
@ -617,7 +594,6 @@
|
||||||
"Proxy Protocol": "Proxy Protocol",
|
"Proxy Protocol": "Proxy Protocol",
|
||||||
"Proxy Server": "Proxy Server",
|
"Proxy Server": "Proxy Server",
|
||||||
"Proxy server has authentication": "Proxy server has authentication",
|
"Proxy server has authentication": "Proxy server has authentication",
|
||||||
"matrix": "Matrix",
|
|
||||||
"promosmsTypeEco": "SMS ECO - cheap but slow and often overloaded. Limited only to Polish recipients.",
|
"promosmsTypeEco": "SMS ECO - cheap but slow and often overloaded. Limited only to Polish recipients.",
|
||||||
"promosmsTypeFlash": "SMS FLASH - Message will automatically show on recipient device. Limited only to Polish recipients.",
|
"promosmsTypeFlash": "SMS FLASH - Message will automatically show on recipient device. Limited only to Polish recipients.",
|
||||||
"promosmsTypeFull": "SMS FULL - Premium tier of SMS, You can use your Sender Name (You need to register name first). Reliable for alerts.",
|
"promosmsTypeFull": "SMS FULL - Premium tier of SMS, You can use your Sender Name (You need to register name first). Reliable for alerts.",
|
||||||
|
@ -653,19 +629,15 @@
|
||||||
"do nothing": "do nothing",
|
"do nothing": "do nothing",
|
||||||
"auto acknowledged": "auto acknowledged",
|
"auto acknowledged": "auto acknowledged",
|
||||||
"auto resolve": "auto resolve",
|
"auto resolve": "auto resolve",
|
||||||
"gorush": "Gorush",
|
|
||||||
"alerta": "Alerta",
|
|
||||||
"alertaApiEndpoint": "API Endpoint",
|
"alertaApiEndpoint": "API Endpoint",
|
||||||
"alertaEnvironment": "Environment",
|
"alertaEnvironment": "Environment",
|
||||||
"alertaApiKey": "API Key",
|
"alertaApiKey": "API Key",
|
||||||
"alertaAlertState": "Alert State",
|
"alertaAlertState": "Alert State",
|
||||||
"alertaRecoverState": "Recover State",
|
"alertaRecoverState": "Recover State",
|
||||||
"serwersms": "SerwerSMS.pl",
|
|
||||||
"serwersmsAPIUser": "API Username (incl. webapi_ prefix)",
|
"serwersmsAPIUser": "API Username (incl. webapi_ prefix)",
|
||||||
"serwersmsAPIPassword": "API Password",
|
"serwersmsAPIPassword": "API Password",
|
||||||
"serwersmsPhoneNumber": "Phone number",
|
"serwersmsPhoneNumber": "Phone number",
|
||||||
"serwersmsSenderName": "SMS Sender Name (registered via customer portal)",
|
"serwersmsSenderName": "SMS Sender Name (registered via customer portal)",
|
||||||
"smseagle": "SMSEagle",
|
|
||||||
"smseagleTo": "Phone number(s)",
|
"smseagleTo": "Phone number(s)",
|
||||||
"smseagleGroup": "Phonebook group name(s)",
|
"smseagleGroup": "Phonebook group name(s)",
|
||||||
"smseagleContact": "Phonebook contact name(s)",
|
"smseagleContact": "Phonebook contact name(s)",
|
||||||
|
@ -675,14 +647,12 @@
|
||||||
"smseagleUrl": "Your SMSEagle device URL",
|
"smseagleUrl": "Your SMSEagle device URL",
|
||||||
"smseagleEncoding": "Send as Unicode",
|
"smseagleEncoding": "Send as Unicode",
|
||||||
"smseaglePriority": "Message priority (0-9, default = 0)",
|
"smseaglePriority": "Message priority (0-9, default = 0)",
|
||||||
"stackfield": "Stackfield",
|
|
||||||
"Recipient Number": "Recipient Number",
|
"Recipient Number": "Recipient Number",
|
||||||
"From Name/Number": "From Name/Number",
|
"From Name/Number": "From Name/Number",
|
||||||
"Leave blank to use a shared sender number.": "Leave blank to use a shared sender number.",
|
"Leave blank to use a shared sender number.": "Leave blank to use a shared sender number.",
|
||||||
"Octopush API Version": "Octopush API Version",
|
"Octopush API Version": "Octopush API Version",
|
||||||
"Legacy Octopush-DM": "Legacy Octopush-DM",
|
"Legacy Octopush-DM": "Legacy Octopush-DM",
|
||||||
"ntfy Topic": "ntfy Topic",
|
"ntfy Topic": "ntfy Topic",
|
||||||
"HomeAssistant": "Home Assistant",
|
|
||||||
"onebotHttpAddress": "OneBot HTTP Address",
|
"onebotHttpAddress": "OneBot HTTP Address",
|
||||||
"onebotMessageType": "OneBot Message Type",
|
"onebotMessageType": "OneBot Message Type",
|
||||||
"onebotGroupMessage": "Group",
|
"onebotGroupMessage": "Group",
|
||||||
|
|
|
@ -272,7 +272,6 @@
|
||||||
"apprise": "Apprise (支持 50+ 种通知服务)",
|
"apprise": "Apprise (支持 50+ 种通知服务)",
|
||||||
"GoogleChat": "Google Chat(仅 Google Workspace)",
|
"GoogleChat": "Google Chat(仅 Google Workspace)",
|
||||||
"pushbullet": "Pushbullet",
|
"pushbullet": "Pushbullet",
|
||||||
"AliyunSMS": "阿里云短信服务",
|
|
||||||
"Kook": "Kook",
|
"Kook": "Kook",
|
||||||
"wayToGetKookBotToken": "在 {0} 创建应用并获取机器人 Token",
|
"wayToGetKookBotToken": "在 {0} 创建应用并获取机器人 Token",
|
||||||
"wayToGetKookGuildID": "在 Kook 设置中打开“开发者模式”,然后右键点击频道可获取其 ID",
|
"wayToGetKookGuildID": "在 Kook 设置中打开“开发者模式”,然后右键点击频道可获取其 ID",
|
||||||
|
@ -448,7 +447,6 @@
|
||||||
"Bark Endpoint": "Bark 接入点",
|
"Bark Endpoint": "Bark 接入点",
|
||||||
"Bark Group": "Bark 群组",
|
"Bark Group": "Bark 群组",
|
||||||
"Bark Sound": "Bark 铃声",
|
"Bark Sound": "Bark 铃声",
|
||||||
"DingDing": "钉钉自定义机器人",
|
|
||||||
"WebHookUrl": "钉钉自定义机器人 Webhook 地址",
|
"WebHookUrl": "钉钉自定义机器人 Webhook 地址",
|
||||||
"SecretKey": "钉钉自定义机器人加签密钥",
|
"SecretKey": "钉钉自定义机器人加签密钥",
|
||||||
"For safety, must use secret key": "出于安全考虑,必须使用加签密钥",
|
"For safety, must use secret key": "出于安全考虑,必须使用加签密钥",
|
||||||
|
|
Loading…
Reference in a new issue