This commit is contained in:
Mirco Wittrien 2020-12-21 20:30:41 +01:00
parent 7e163e1fa5
commit 371e96129f
3 changed files with 54 additions and 50 deletions

View File

@ -721,13 +721,6 @@ module.exports = (_ => {
}; };
BDFDB.PluginUtils.checkChangeLog = function (plugin) { BDFDB.PluginUtils.checkChangeLog = function (plugin) {
if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ObjectUtils.is(plugin.changeLog)) return; if (!BDFDB.ObjectUtils.is(plugin) || !BDFDB.ObjectUtils.is(plugin.changeLog)) return;
// REMOVE 14.11.2020
let changeLog = BDFDB.DataUtils.load(plugin, "changeLog");
if (changeLog && changeLog.version) {
BDFDB.DataUtils.remove(plugin, "changelog");
BDFDB.DataUtils.remove(plugin, "changeLog");
changeLogs[plugin.name] = changeLog.version;
}
if (!changeLogs[plugin.name] || BDFDB.NumberUtils.compareVersions(plugin.version, changeLogs[plugin.name])) { if (!changeLogs[plugin.name] || BDFDB.NumberUtils.compareVersions(plugin.version, changeLogs[plugin.name])) {
changeLogs[plugin.name] = plugin.version; changeLogs[plugin.name] = plugin.version;
BDFDB.DataUtils.save(changeLogs, BDFDB, "changeLogs"); BDFDB.DataUtils.save(changeLogs, BDFDB, "changeLogs");

View File

@ -14,12 +14,12 @@ module.exports = (_ => {
"info": { "info": {
"name": "CompleteTimestamps", "name": "CompleteTimestamps",
"author": "DevilBro", "author": "DevilBro",
"version": "1.5.0", "version": "1.5.1",
"description": "Replace all timestamps with complete timestamps" "description": "Replace all timestamps with complete timestamps"
}, },
"changeLog": { "changeLog": {
"fixed": { "added": {
"Spoiler Embed Crash": "No longer crashes on spoilered embeds" "Format for Tooltips": "Added an option to set up and select a custom format for timestamps inside tooltips"
} }
} }
}; };
@ -81,10 +81,12 @@ module.exports = (_ => {
otherOrder: {value: false, description: "Show the time before the date"} otherOrder: {value: false, description: "Show the time before the date"}
}, },
choices: { choices: {
timestampLang: {value: "$discord", description: "Timestamp Format"} timestampLang: {value: "$discord", description: "Chat Timestamp Format"},
timestampToolLang: {value: "$discord", description: "Tooltip Timestamp Format"}
}, },
formats: { formats: {
ownFormat: {value: "$hour: $minute: $second, $day.$month.$year", description: "Own Format"} ownFormat: {value: "$hour:$minute:$second, $day.$month.$year", description: "Own Chat Format"},
ownFormatTool: {value: "$hour:$minute:$second, $day.$month.$year", description: "Own Tooltip Format"}
}, },
amounts: { amounts: {
maxDaysAgo: {value: 0, min: 0, description: "Maximum count of days displayed in the $daysago placeholder", note: "0 equals no limit"} maxDaysAgo: {value: 0, min: 0, description: "Maximum count of days displayed in the $daysago placeholder", note: "0 equals no limit"}
@ -110,6 +112,15 @@ module.exports = (_ => {
} }
}, BDFDB.LanguageUtils.languages); }, BDFDB.LanguageUtils.languages);
// REMOVE 21.12.2020
let oC = BDFDB.DataUtils.load(this, "choices"), oF = BDFDB.DataUtils.load(this, "formats");
if (!oC.timestampToolLang || !oF.ownFormatTool) {
oC.timestampToolLang = oC.timestampLang;
oF.ownFormatTool = oF.ownFormat;
BDFDB.DataUtils.save(oC, this, "choices");
BDFDB.DataUtils.save(oF, this, "formats");
}
this.forceUpdateAll(); this.forceUpdateAll();
} }
@ -146,7 +157,7 @@ module.exports = (_ => {
plugin: this, plugin: this,
keys: ["choices", key], keys: ["choices", key],
label: this.defaults.choices[key].description, label: this.defaults.choices[key].description,
basis: "70%", basis: "65%",
value: choices[key], value: choices[key],
options: BDFDB.ObjectUtils.toArray(BDFDB.ObjectUtils.map(languages, (lang, id) => {return {value: id, label: lang.name}})), options: BDFDB.ObjectUtils.toArray(BDFDB.ObjectUtils.map(languages, (lang, id) => {return {value: id, label: lang.name}})),
searchable: true, searchable: true,
@ -164,7 +175,7 @@ module.exports = (_ => {
grow: 0, grow: 0,
shrink: 0, shrink: 0,
basis: "60%", basis: "60%",
children: this.getTimestamp(languages[lang.value].id) children: this.getTimestamp(languages[lang.value].id, null, key == "timestampToolLang")
}) })
] ]
}); });
@ -182,7 +193,7 @@ module.exports = (_ => {
grow: 1, grow: 1,
shrink: 0, shrink: 0,
basis: "70%", basis: "70%",
children: this.getTimestamp(languages[lang.value].id) children: this.getTimestamp(languages[lang.value].id, null, key == "timestampToolLang")
}) })
] ]
}); });
@ -194,7 +205,7 @@ module.exports = (_ => {
plugin: this, plugin: this,
keys: ["formats", key], keys: ["formats", key],
label: this.defaults.formats[key].description, label: this.defaults.formats[key].description,
basis: "70%", basis: "65%",
value: formats[key], value: formats[key],
onChange: (value, instance) => { onChange: (value, instance) => {
formats[key] = value; formats[key] = value;
@ -322,11 +333,11 @@ module.exports = (_ => {
if (tooltipWrapper) { if (tooltipWrapper) {
let timestamp = this.getTimestamp(languages[choices.timestampLang].id, parent[index].props.timestamp._i); let timestamp = this.getTimestamp(languages[choices.timestampLang].id, parent[index].props.timestamp._i);
if (change.tooltip) { if (change.tooltip) {
tooltipWrapper.props.text = timestamp; tooltipWrapper.props.text = this.getTimestamp(languages[choices.timestampToolLang].id, parent[index].props.timestamp._i, true);
tooltipWrapper.props.delay = 0; tooltipWrapper.props.delay = 0;
} }
if (change.child && typeof tooltipWrapper.props.children == "function") { if (change.child && typeof tooltipWrapper.props.children == "function") {
tooltipWrapper.props.delay = 99999999999999999999; if (choices.timestampLang == choices.timestampToolLang && formats.ownFormat == formats.ownFormatTool) tooltipWrapper.props.delay = 99999999999999999999;
let renderChildren = tooltipWrapper.props.children; let renderChildren = tooltipWrapper.props.children;
tooltipWrapper.props.children = (...args) => { tooltipWrapper.props.children = (...args) => {
let renderedChildren = renderChildren(...args); let renderedChildren = renderChildren(...args);
@ -339,7 +350,7 @@ module.exports = (_ => {
parent[index] = stamp; parent[index] = stamp;
} }
getTimestamp (languageId, time) { getTimestamp (languageId, time, isTooltip) {
let timeObj = time || new Date(); let timeObj = time || new Date();
if (typeof time == "string" || typeof time == "number") timeObj = new Date(time); if (typeof time == "string" || typeof time == "number") timeObj = new Date(time);
if (timeObj.toString() == "Invalid Date") timeObj = new Date(parseInt(time)); if (timeObj.toString() == "Invalid Date") timeObj = new Date(parseInt(time));
@ -357,12 +368,12 @@ module.exports = (_ => {
languageId = BDFDB.LanguageUtils.getLanguage().id; languageId = BDFDB.LanguageUtils.getLanguage().id;
let now = new Date(); let now = new Date();
let hour = timeObj.getHours(), minute = timeObj.getMinutes(), second = timeObj.getSeconds(), msecond = timeObj.getMilliseconds(), day = timeObj.getDate(), month = timeObj.getMonth()+1, timemode = "", daysago = Math.round((Date.UTC(now.getFullYear(), now.getMonth(), now.getDate()) - Date.UTC(timeObj.getFullYear(), timeObj.getMonth(), timeObj.getDate()))/(1000*60*60*24)); let hour = timeObj.getHours(), minute = timeObj.getMinutes(), second = timeObj.getSeconds(), msecond = timeObj.getMilliseconds(), day = timeObj.getDate(), month = timeObj.getMonth()+1, timemode = "", daysago = Math.round((Date.UTC(now.getFullYear(), now.getMonth(), now.getDate()) - Date.UTC(timeObj.getFullYear(), timeObj.getMonth(), timeObj.getDate()))/(1000*60*60*24));
if (formats.ownFormat.indexOf("$timemode") > -1) { if (formats[isTooltip ? "ownFormatTool" : "ownFormat"].indexOf("$timemode") > -1) {
timemode = hour >= 12 ? "PM" : "AM"; timemode = hour >= 12 ? "PM" : "AM";
hour = hour % 12; hour = hour % 12;
hour = hour ? hour : 12; hour = hour ? hour : 12;
} }
timeString = formats.ownFormat timeString = formats[isTooltip ? "ownFormatTool" : "ownFormat"]
.replace(/\$hour/g, settings.forceZeros && hour < 10 ? "0" + hour : hour) .replace(/\$hour/g, settings.forceZeros && hour < 10 ? "0" + hour : hour)
.replace(/\$minute/g, minute < 10 ? "0" + minute : minute) .replace(/\$minute/g, minute < 10 ? "0" + minute : minute)
.replace(/\$second/g, second < 10 ? "0" + second : second) .replace(/\$second/g, second < 10 ? "0" + second : second)

View File

@ -522,7 +522,7 @@ module.exports = (_ => {
let [children, index] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "devmode-copy-id", group: true}); let [children, index] = BDFDB.ContextMenuUtils.findItem(e.returnvalue, {id: "devmode-copy-id", group: true});
children.splice(index > -1 ? index : children.length, 0, BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuGroup, { children.splice(index > -1 ? index : children.length, 0, BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuGroup, {
children: BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { children: BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, {
label: BDFDB.LanguageUtils.LanguageStrings.IMAGE, label: BDFDB.LanguageUtils.LanguageStrings.IMAGE + " " + BDFDB.LanguageUtils.LanguageStrings.ACTIONS,
id: BDFDB.ContextMenuUtils.createItemId(this.name, "main-subitem"), id: BDFDB.ContextMenuUtils.createItemId(this.name, "main-subitem"),
children: validUrls.length == 1 ? this.createUrlMenu(e, validUrls[0].url) : validUrls.map((urlData, i) => BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, { children: validUrls.length == 1 ? this.createUrlMenu(e, validUrls[0].url) : validUrls.map((urlData, i) => BDFDB.ContextMenuUtils.createItem(BDFDB.LibraryComponents.MenuItems.MenuItem, {
label: urlData.type.toUpperCase(), label: urlData.type.toUpperCase(),
@ -1125,8 +1125,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Копирането на изображението в клипборда не бе успешно", toast_copyimage_failed: "Копирането на изображението в клипборда не бе успешно",
toast_copyimage_success: "Копирано изображение в клипборда", toast_copyimage_success: "Копирано изображение в клипборда",
toast_copyimagelink_success: "Копирана връзка към изображение в клипборда", toast_copyimagelink_success: "Копирана връзка към изображение в клипборда",
toast_saveimage_failed: "Запазването на изображението в „{{path}}“ не бе успешно", toast_saveimage_failed: "Запазването на изображението в '{{path}}' не бе успешно",
toast_saveimage_success: "Запазено изображение в „{{path}}“" toast_saveimage_success: "Запазено изображение в '{{path}}'"
}; };
case "da": // Danish case "da": // Danish
return { return {
@ -1170,8 +1170,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Αποτυχία αντιγραφής εικόνας στο Πρόχειρο", toast_copyimage_failed: "Αποτυχία αντιγραφής εικόνας στο Πρόχειρο",
toast_copyimage_success: "Αντιγράφηκε η εικόνα στο Πρόχειρο", toast_copyimage_success: "Αντιγράφηκε η εικόνα στο Πρόχειρο",
toast_copyimagelink_success: "Αντιγράφηκε σύνδεσμος εικόνας στο Πρόχειρο", toast_copyimagelink_success: "Αντιγράφηκε σύνδεσμος εικόνας στο Πρόχειρο",
toast_saveimage_failed: "Αποτυχία αποθήκευσης εικόνας στο "{{path}}"", toast_saveimage_failed: "Αποτυχία αποθήκευσης εικόνας στο '{{path}}'",
toast_saveimage_success: "Αποθηκευμένη εικόνα στο "{{path}}"" toast_saveimage_success: "Αποθηκευμένη εικόνα στο '{{path}}'"
}; };
case "es": // Spanish case "es": // Spanish
return { return {
@ -1185,8 +1185,8 @@ module.exports = (_ => {
toast_copyimage_failed: "No se pudo copiar la imagen al portapapeles", toast_copyimage_failed: "No se pudo copiar la imagen al portapapeles",
toast_copyimage_success: "Imagen copiada al portapapeles", toast_copyimage_success: "Imagen copiada al portapapeles",
toast_copyimagelink_success: "Enlace de imagen copiado al portapapeles", toast_copyimagelink_success: "Enlace de imagen copiado al portapapeles",
toast_saveimage_failed: "No se pudo guardar la imagen en '{{ruta}}'", toast_saveimage_failed: "No se pudo guardar la imagen en '{{path}}'",
toast_saveimage_success: "Imagen guardada en '{{ruta}}'" toast_saveimage_success: "Imagen guardada en '{{path}}'"
}; };
case "fi": // Finnish case "fi": // Finnish
return { return {
@ -1200,8 +1200,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Kuvan kopioiminen leikepöydälle epäonnistui", toast_copyimage_failed: "Kuvan kopioiminen leikepöydälle epäonnistui",
toast_copyimage_success: "Kopioitu kuva leikepöydälle", toast_copyimage_success: "Kopioitu kuva leikepöydälle",
toast_copyimagelink_success: "Kopioitu kuvalinkki leikepöydälle", toast_copyimagelink_success: "Kopioitu kuvalinkki leikepöydälle",
toast_saveimage_failed: "Kuvan tallentaminen kohteeseen {{path}} epäonnistui", toast_saveimage_failed: "Kuvan tallentaminen kohteeseen '{{path}}' epäonnistui",
toast_saveimage_success: "Tallennettu kuva kansioon {{path}}" toast_saveimage_success: "Tallennettu kuva kansioon '{{path}}'"
}; };
case "fr": // French case "fr": // French
return { return {
@ -1215,8 +1215,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Échec de la copie de l'image dans le presse-papiers", toast_copyimage_failed: "Échec de la copie de l'image dans le presse-papiers",
toast_copyimage_success: "Image copiée dans le presse-papiers", toast_copyimage_success: "Image copiée dans le presse-papiers",
toast_copyimagelink_success: "Lien d'image copié vers le presse-papiers", toast_copyimagelink_success: "Lien d'image copié vers le presse-papiers",
toast_saveimage_failed: "Échec de l'enregistrement de l'image dans «{{path}}»", toast_saveimage_failed: "Échec de l'enregistrement de l'image dans '{{path}}'",
toast_saveimage_success: "Image enregistrée dans "{{path}}"" toast_saveimage_success: "Image enregistrée dans '{{path}}'"
}; };
case "hr": // Croatian case "hr": // Croatian
return { return {
@ -1230,8 +1230,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Kopiranje slike u međuspremnik nije uspjelo", toast_copyimage_failed: "Kopiranje slike u međuspremnik nije uspjelo",
toast_copyimage_success: "Kopirana slika u međuspremnik", toast_copyimage_success: "Kopirana slika u međuspremnik",
toast_copyimagelink_success: "Veza slike kopirana je u međuspremnik", toast_copyimagelink_success: "Veza slike kopirana je u međuspremnik",
toast_saveimage_failed: "Spremanje slike u "{{path}}" nije uspjelo", toast_saveimage_failed: "Spremanje slike u '{{path}}' nije uspjelo",
toast_saveimage_success: "Spremljena slika na "{{path}}"" toast_saveimage_success: "Spremljena slika na '{{path}}'"
}; };
case "hu": // Hungarian case "hu": // Hungarian
return { return {
@ -1245,8 +1245,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Nem sikerült másolni a képet a vágólapra", toast_copyimage_failed: "Nem sikerült másolni a képet a vágólapra",
toast_copyimage_success: "Kép másolása a vágólapra", toast_copyimage_success: "Kép másolása a vágólapra",
toast_copyimagelink_success: "Képlink linkre másolva a vágólapra", toast_copyimagelink_success: "Képlink linkre másolva a vágólapra",
toast_saveimage_failed: "Nem sikerült menteni a képet a (z) {{path}}” mappába", toast_saveimage_failed: "Nem sikerült menteni a képet a (z) '{{path}}” mappába",
toast_saveimage_success: "Mentett kép itt: {{path}}”" toast_saveimage_success: "Mentett kép itt: '{{path}}”"
}; };
case "it": // Italian case "it": // Italian
return { return {
@ -1260,8 +1260,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Impossibile copiare l'immagine negli Appunti", toast_copyimage_failed: "Impossibile copiare l'immagine negli Appunti",
toast_copyimage_success: "Immagine copiata negli Appunti", toast_copyimage_success: "Immagine copiata negli Appunti",
toast_copyimagelink_success: "Collegamento immagine copiato negli Appunti", toast_copyimagelink_success: "Collegamento immagine copiato negli Appunti",
toast_saveimage_failed: "Impossibile salvare l'immagine in "{{path}}"", toast_saveimage_failed: "Impossibile salvare l'immagine in '{{path}}'",
toast_saveimage_success: "Immagine salvata in "{{path}}"" toast_saveimage_success: "Immagine salvata in '{{path}}'"
}; };
case "ja": // Japanese case "ja": // Japanese
return { return {
@ -1305,8 +1305,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Nepavyko nukopijuoti vaizdo į iškarpinę", toast_copyimage_failed: "Nepavyko nukopijuoti vaizdo į iškarpinę",
toast_copyimage_success: "Nukopijuotas vaizdas į mainų sritį", toast_copyimage_success: "Nukopijuotas vaizdas į mainų sritį",
toast_copyimagelink_success: "Nukopijuota vaizdo nuoroda į iškarpinę", toast_copyimagelink_success: "Nukopijuota vaizdo nuoroda į iškarpinę",
toast_saveimage_failed: "Nepavyko išsaugoti vaizdo „{{path}}“", toast_saveimage_failed: "Nepavyko išsaugoti vaizdo '{{path}}'",
toast_saveimage_success: "Išsaugotas vaizdas „{{path}}“" toast_saveimage_success: "Išsaugotas vaizdas '{{path}}'"
}; };
case "nl": // Dutch case "nl": // Dutch
return { return {
@ -1350,8 +1350,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Nie udało się skopiować obrazu do schowka", toast_copyimage_failed: "Nie udało się skopiować obrazu do schowka",
toast_copyimage_success: "Skopiowany obraz do schowka", toast_copyimage_success: "Skopiowany obraz do schowka",
toast_copyimagelink_success: "Link do skopiowanego obrazu do schowka", toast_copyimagelink_success: "Link do skopiowanego obrazu do schowka",
toast_saveimage_failed: "Nie udało się zapisać obrazu w {{path}}”", toast_saveimage_failed: "Nie udało się zapisać obrazu w '{{path}}”",
toast_saveimage_success: "Zapisany obraz w {{path}}”" toast_saveimage_success: "Zapisany obraz w '{{path}}”"
}; };
case "pt-BR": // Portuguese (Brazil) case "pt-BR": // Portuguese (Brazil)
return { return {
@ -1380,8 +1380,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Copierea imaginii în clipboard nu a reușit", toast_copyimage_failed: "Copierea imaginii în clipboard nu a reușit",
toast_copyimage_success: "Copiat imaginea în Clipboard", toast_copyimage_success: "Copiat imaginea în Clipboard",
toast_copyimagelink_success: "Link copiat pentru imagine în Clipboard", toast_copyimagelink_success: "Link copiat pentru imagine în Clipboard",
toast_saveimage_failed: "Salvarea imaginii în {{path}}” nu a reușit", toast_saveimage_failed: "Salvarea imaginii în '{{path}}” nu a reușit",
toast_saveimage_success: "Imagine salvată în {{path}}”" toast_saveimage_success: "Imagine salvată în '{{path}}”"
}; };
case "ru": // Russian case "ru": // Russian
return { return {
@ -1410,8 +1410,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Det gick inte att kopiera bilden till Urklipp", toast_copyimage_failed: "Det gick inte att kopiera bilden till Urklipp",
toast_copyimage_success: "Kopierad bild till Urklipp", toast_copyimage_success: "Kopierad bild till Urklipp",
toast_copyimagelink_success: "Kopierad bildlänk till Urklipp", toast_copyimagelink_success: "Kopierad bildlänk till Urklipp",
toast_saveimage_failed: "Det gick inte att spara bilden i "{{path}}"", toast_saveimage_failed: "Det gick inte att spara bilden i '{{path}}'",
toast_saveimage_success: "Sparad bild i "{{path}}"" toast_saveimage_success: "Sparad bild i '{{path}}'"
}; };
case "th": // Thai case "th": // Thai
return { return {
@ -1425,8 +1425,8 @@ module.exports = (_ => {
toast_copyimage_failed: "คัดลอกรูปภาพไปยังคลิปบอร์ดไม่สำเร็จ", toast_copyimage_failed: "คัดลอกรูปภาพไปยังคลิปบอร์ดไม่สำเร็จ",
toast_copyimage_success: "คัดลอกรูปภาพไปยังคลิปบอร์ดแล้ว", toast_copyimage_success: "คัดลอกรูปภาพไปยังคลิปบอร์ดแล้ว",
toast_copyimagelink_success: "ลิงก์รูปภาพที่คัดลอกไปยังคลิปบอร์ด", toast_copyimagelink_success: "ลิงก์รูปภาพที่คัดลอกไปยังคลิปบอร์ด",
toast_saveimage_failed: "บันทึกภาพใน "{{path}}" ไม่สำเร็จ", toast_saveimage_failed: "บันทึกภาพใน '{{path}}' ไม่สำเร็จ",
toast_saveimage_success: "ภาพที่บันทึกไว้ใน "{{path}}"" toast_saveimage_success: "ภาพที่บันทึกไว้ใน '{{path}}'"
}; };
case "tr": // Turkish case "tr": // Turkish
return { return {
@ -1455,8 +1455,8 @@ module.exports = (_ => {
toast_copyimage_failed: "Не вдалося скопіювати зображення в буфер обміну", toast_copyimage_failed: "Не вдалося скопіювати зображення в буфер обміну",
toast_copyimage_success: "Скопійовано зображення в буфер обміну", toast_copyimage_success: "Скопійовано зображення в буфер обміну",
toast_copyimagelink_success: "Скопійовано посилання на зображення в буфер обміну", toast_copyimagelink_success: "Скопійовано посилання на зображення в буфер обміну",
toast_saveimage_failed: "Не вдалося зберегти зображення у "{{path}}"", toast_saveimage_failed: "Не вдалося зберегти зображення у '{{path}}'",
toast_saveimage_success: "Збережене зображення у "{{path}}"" toast_saveimage_success: "Збережене зображення у '{{path}}'"
}; };
case "vi": // Vietnamese case "vi": // Vietnamese
return { return {