mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-26 00:19:21 +08:00 
			
		
		
		
	1.23.14 to 2.0.0 (#4886)
This commit is contained in:
		| @@ -1,53 +1,63 @@ | |||||||
| <template> | <template> | ||||||
|     <div> |     <div> | ||||||
|         <div class="add-btn"> |         <div | ||||||
|             <button class="btn btn-primary me-2" type="button" @click="$refs.apiKeyDialog.show()"> |             v-if="settings.disableAuth" | ||||||
|                 <font-awesome-icon icon="plus" /> {{ $t("Add API Key") }} |             class="mt-5 d-flex align-items-center justify-content-center my-3" | ||||||
|             </button> |         > | ||||||
|  |             {{ $t("apiKeysDisabledMsg") }} | ||||||
|         </div> |         </div> | ||||||
|  |         <div v-else> | ||||||
|  |             <div class="add-btn"> | ||||||
|  |                 <button class="btn btn-primary me-2" type="button" @click="$refs.apiKeyDialog.show()"> | ||||||
|  |                     <font-awesome-icon icon="plus" /> {{ $t("Add API Key") }} | ||||||
|  |                 </button> | ||||||
|  |             </div> | ||||||
|  |  | ||||||
|         <div> |             <div> | ||||||
|             <span v-if="Object.keys(keyList).length === 0" class="d-flex align-items-center justify-content-center my-3"> |                 <span | ||||||
|                 {{ $t("No API Keys") }} |                     v-if="Object.keys(keyList).length === 0" | ||||||
|             </span> |                     class="d-flex align-items-center justify-content-center my-3" | ||||||
|  |                 > | ||||||
|  |                     {{ $t("No API Keys") }} | ||||||
|  |                 </span> | ||||||
|  |  | ||||||
|             <div |                 <div | ||||||
|                 v-for="(item, index) in keyList" |                     v-for="(item, index) in keyList" | ||||||
|                 :key="index" |                     :key="index" | ||||||
|                 class="item" |                     class="item" | ||||||
|                 :class="item.status" |                     :class="item.status" | ||||||
|             > |                 > | ||||||
|                 <div class="left-part"> |                     <div class="left-part"> | ||||||
|                     <div |                         <div class="circle"></div> | ||||||
|                         class="circle" |                         <div class="info"> | ||||||
|                     ></div> |                             <div class="title">{{ item.name }}</div> | ||||||
|                     <div class="info"> |                             <div class="status"> | ||||||
|                         <div class="title">{{ item.name }}</div> |                                 {{ $t("apiKey-" + item.status) }} | ||||||
|                         <div class="status"> |                             </div> | ||||||
|                             {{ $t("apiKey-" + item.status) }} |                             <div class="date"> | ||||||
|                         </div> |                                 {{ $t("Created") }}: {{ item.createdDate }} | ||||||
|                         <div class="date"> |                             </div> | ||||||
|                             {{ $t("Created") }}: {{ item.createdDate }} |                             <div class="date"> | ||||||
|                         </div> |                                 {{ $t("Expires") }}: | ||||||
|                         <div class="date"> |                                 {{ item.expires || $t("Never") }} | ||||||
|                             {{ $t("Expires") }}: {{ item.expires || $t("Never") }} |                             </div> | ||||||
|                         </div> |                         </div> | ||||||
|                     </div> |                     </div> | ||||||
|                 </div> |  | ||||||
|  |  | ||||||
|                 <div class="buttons"> |                     <div class="buttons"> | ||||||
|                     <div class="btn-group" role="group"> |                         <div class="btn-group" role="group"> | ||||||
|                         <button v-if="item.active" class="btn btn-normal" @click="disableDialog(item.id)"> |                             <button v-if="item.active" class="btn btn-normal" @click="disableDialog(item.id)"> | ||||||
|                             <font-awesome-icon icon="pause" /> {{ $t("Disable") }} |                                 <font-awesome-icon icon="pause" /> {{ $t("Disable") }} | ||||||
|                         </button> |                             </button> | ||||||
|  |  | ||||||
|                         <button v-if="!item.active" class="btn btn-primary" @click="enableKey(item.id)"> |                             <button v-if="!item.active" class="btn btn-primary" @click="enableKey(item.id)"> | ||||||
|                             <font-awesome-icon icon="play" /> {{ $t("Enable") }} |                                 <font-awesome-icon icon="play" /> {{ $t("Enable") }} | ||||||
|                         </button> |                             </button> | ||||||
|  |  | ||||||
|                         <button class="btn btn-danger" @click="deleteDialog(item.id)"> |                             <button class="btn btn-danger" @click="deleteDialog(item.id)"> | ||||||
|                             <font-awesome-icon icon="trash" /> {{ $t("Delete") }} |                                 <font-awesome-icon icon="trash" /> {{ $t("Delete") }} | ||||||
|                         </button> |                             </button> | ||||||
|  |                         </div> | ||||||
|                     </div> |                     </div> | ||||||
|                 </div> |                 </div> | ||||||
|             </div> |             </div> | ||||||
| @@ -88,6 +98,9 @@ export default { | |||||||
|             let result = Object.values(this.$root.apiKeyList); |             let result = Object.values(this.$root.apiKeyList); | ||||||
|             return result; |             return result; | ||||||
|         }, |         }, | ||||||
|  |         settings() { | ||||||
|  |             return this.$parent.$parent.$parent.settings; | ||||||
|  |         }, | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|     methods: { |     methods: { | ||||||
| @@ -126,9 +139,11 @@ export default { | |||||||
|          * @returns {void} |          * @returns {void} | ||||||
|          */ |          */ | ||||||
|         disableKey() { |         disableKey() { | ||||||
|             this.$root.getSocket().emit("disableAPIKey", this.selectedKeyID, (res) => { |             this.$root | ||||||
|                 this.$root.toastRes(res); |                 .getSocket() | ||||||
|             }); |                 .emit("disableAPIKey", this.selectedKeyID, (res) => { | ||||||
|  |                     this.$root.toastRes(res); | ||||||
|  |                 }); | ||||||
|         }, |         }, | ||||||
|  |  | ||||||
|         /** |         /** | ||||||
| @@ -146,113 +161,113 @@ export default { | |||||||
| </script> | </script> | ||||||
|  |  | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
|     @import "../../assets/vars.scss"; | @import "../../assets/vars.scss"; | ||||||
|  |  | ||||||
|     .mobile { |  | ||||||
|         .item { |  | ||||||
|             flex-direction: column; |  | ||||||
|             align-items: flex-start; |  | ||||||
|             margin-bottom: 20px; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     .add-btn { |  | ||||||
|         padding-top: 20px; |  | ||||||
|         padding-bottom: 20px; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|  | .mobile { | ||||||
|     .item { |     .item { | ||||||
|         display: flex; |         flex-direction: column; | ||||||
|         align-items: center; |         align-items: flex-start; | ||||||
|         gap: 10px; |         margin-bottom: 20px; | ||||||
|         text-decoration: none; |     } | ||||||
|         border-radius: 10px; | } | ||||||
|         transition: all ease-in-out 0.15s; |  | ||||||
|         justify-content: space-between; |  | ||||||
|         padding: 10px; |  | ||||||
|         min-height: 90px; |  | ||||||
|         margin-bottom: 5px; |  | ||||||
|  |  | ||||||
|         &:hover { | .add-btn { | ||||||
|             background-color: $highlight-white; |     padding-top: 20px; | ||||||
|  |     padding-bottom: 20px; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .item { | ||||||
|  |     display: flex; | ||||||
|  |     align-items: center; | ||||||
|  |     gap: 10px; | ||||||
|  |     text-decoration: none; | ||||||
|  |     border-radius: 10px; | ||||||
|  |     transition: all ease-in-out 0.15s; | ||||||
|  |     justify-content: space-between; | ||||||
|  |     padding: 10px; | ||||||
|  |     min-height: 90px; | ||||||
|  |     margin-bottom: 5px; | ||||||
|  |  | ||||||
|  |     &:hover { | ||||||
|  |         background-color: $highlight-white; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     &.active { | ||||||
|  |         .circle { | ||||||
|  |             background-color: $primary; | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|         &.active { |     &.inactive { | ||||||
|             .circle { |         .circle { | ||||||
|                 background-color: $primary; |             background-color: $danger; | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         &.inactive { |  | ||||||
|             .circle { |  | ||||||
|                 background-color: $danger; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         &.expired { |  | ||||||
|             .left-part { |  | ||||||
|                 opacity: 0.3; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             .circle { |  | ||||||
|                 background-color: $dark-font-color; |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     &.expired { | ||||||
|         .left-part { |         .left-part { | ||||||
|             display: flex; |             opacity: 0.3; | ||||||
|             gap: 12px; |  | ||||||
|             align-items: center; |  | ||||||
|  |  | ||||||
|             .circle { |  | ||||||
|                 width: 25px; |  | ||||||
|                 height: 25px; |  | ||||||
|                 border-radius: 50rem; |  | ||||||
|             } |  | ||||||
|  |  | ||||||
|             .info { |  | ||||||
|                 .title { |  | ||||||
|                     font-weight: bold; |  | ||||||
|                     font-size: 20px; |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 .status { |  | ||||||
|                     font-size: 14px; |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         .buttons { |         .circle { | ||||||
|             display: flex; |             background-color: $dark-font-color; | ||||||
|             gap: 8px; |         } | ||||||
|             flex-direction: row-reverse; |     } | ||||||
|  |  | ||||||
|             .btn-group { |     .left-part { | ||||||
|                 width: 310px; |         display: flex; | ||||||
|  |         gap: 12px; | ||||||
|  |         align-items: center; | ||||||
|  |  | ||||||
|  |         .circle { | ||||||
|  |             width: 25px; | ||||||
|  |             height: 25px; | ||||||
|  |             border-radius: 50rem; | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         .info { | ||||||
|  |             .title { | ||||||
|  |                 font-weight: bold; | ||||||
|  |                 font-size: 20px; | ||||||
|  |             } | ||||||
|  |  | ||||||
|  |             .status { | ||||||
|  |                 font-size: 14px; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     .date { |     .buttons { | ||||||
|         margin-top: 5px; |         display: flex; | ||||||
|         display: block; |         gap: 8px; | ||||||
|         font-size: 14px; |         flex-direction: row-reverse; | ||||||
|         background-color: rgba(255, 255, 255, 0.5); |  | ||||||
|         border-radius: 20px; |  | ||||||
|         padding: 0 10px; |  | ||||||
|         width: fit-content; |  | ||||||
|  |  | ||||||
|         .dark & { |         .btn-group { | ||||||
|             color: white; |             width: 310px; | ||||||
|             background-color: rgba(255, 255, 255, 0.1); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|     .dark { | .date { | ||||||
|         .item { |     margin-top: 5px; | ||||||
|             &:hover { |     display: block; | ||||||
|                 background-color: $dark-bg2; |     font-size: 14px; | ||||||
|             } |     background-color: rgba(255, 255, 255, 0.5); | ||||||
|  |     border-radius: 20px; | ||||||
|  |     padding: 0 10px; | ||||||
|  |     width: fit-content; | ||||||
|  |  | ||||||
|  |     .dark & { | ||||||
|  |         color: white; | ||||||
|  |         background-color: rgba(255, 255, 255, 0.1); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | .dark { | ||||||
|  |     .item { | ||||||
|  |         &:hover { | ||||||
|  |             background-color: $dark-bg2; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | } | ||||||
| </style> | </style> | ||||||
|   | |||||||
| @@ -954,5 +954,6 @@ | |||||||
|     "threemaSenderIdentity": "Gateway-ID", |     "threemaSenderIdentity": "Gateway-ID", | ||||||
|     "threemaSenderIdentityFormat": "8 characters, usually starts with *", |     "threemaSenderIdentityFormat": "8 characters, usually starts with *", | ||||||
|     "threemaApiAuthenticationSecret": "Gateway-ID Secret", |     "threemaApiAuthenticationSecret": "Gateway-ID Secret", | ||||||
|     "threemaBasicModeInfo": "Note: This integration uses Threema Gateway in basic mode (server-based encryption). Further details can be found {0}." |     "threemaBasicModeInfo": "Note: This integration uses Threema Gateway in basic mode (server-based encryption). Further details can be found {0}.", | ||||||
|  |     "apiKeysDisabledMsg": "API keys are disabled because authentication is disabled." | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										23
									
								
								src/util.js
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/util.js
									
									
									
									
									
								
							| @@ -8,11 +8,14 @@ | |||||||
| // Backend uses the compiled file util.js | // Backend uses the compiled file util.js | ||||||
| // Frontend uses util.ts | // Frontend uses util.ts | ||||||
| */ | */ | ||||||
|  | var __importDefault = (this && this.__importDefault) || function (mod) { | ||||||
|  |     return (mod && mod.__esModule) ? mod : { "default": mod }; | ||||||
|  | }; | ||||||
| var _a; | var _a; | ||||||
| Object.defineProperty(exports, "__esModule", { value: true }); | Object.defineProperty(exports, "__esModule", { value: true }); | ||||||
| exports.sleep = exports.flipStatus = exports.badgeConstants = exports.CONSOLE_STYLE_BgGray = exports.CONSOLE_STYLE_BgWhite = exports.CONSOLE_STYLE_BgCyan = exports.CONSOLE_STYLE_BgMagenta = exports.CONSOLE_STYLE_BgBlue = exports.CONSOLE_STYLE_BgYellow = exports.CONSOLE_STYLE_BgGreen = exports.CONSOLE_STYLE_BgRed = exports.CONSOLE_STYLE_BgBlack = exports.CONSOLE_STYLE_FgPink = exports.CONSOLE_STYLE_FgBrown = exports.CONSOLE_STYLE_FgViolet = exports.CONSOLE_STYLE_FgLightBlue = exports.CONSOLE_STYLE_FgLightGreen = exports.CONSOLE_STYLE_FgOrange = exports.CONSOLE_STYLE_FgGray = exports.CONSOLE_STYLE_FgWhite = exports.CONSOLE_STYLE_FgCyan = exports.CONSOLE_STYLE_FgMagenta = exports.CONSOLE_STYLE_FgBlue = exports.CONSOLE_STYLE_FgYellow = exports.CONSOLE_STYLE_FgGreen = exports.CONSOLE_STYLE_FgRed = exports.CONSOLE_STYLE_FgBlack = exports.CONSOLE_STYLE_Hidden = exports.CONSOLE_STYLE_Reverse = exports.CONSOLE_STYLE_Blink = exports.CONSOLE_STYLE_Underscore = exports.CONSOLE_STYLE_Dim = exports.CONSOLE_STYLE_Bright = exports.CONSOLE_STYLE_Reset = exports.MIN_INTERVAL_SECOND = exports.MAX_INTERVAL_SECOND = exports.SQL_DATETIME_FORMAT_WITHOUT_SECOND = exports.SQL_DATETIME_FORMAT = exports.SQL_DATE_FORMAT = exports.STATUS_PAGE_MAINTENANCE = exports.STATUS_PAGE_PARTIAL_DOWN = exports.STATUS_PAGE_ALL_UP = exports.STATUS_PAGE_ALL_DOWN = exports.MAINTENANCE = exports.PENDING = exports.UP = exports.DOWN = exports.appName = exports.isNode = exports.isDev = void 0; | exports.sleep = exports.flipStatus = exports.badgeConstants = exports.CONSOLE_STYLE_BgGray = exports.CONSOLE_STYLE_BgWhite = exports.CONSOLE_STYLE_BgCyan = exports.CONSOLE_STYLE_BgMagenta = exports.CONSOLE_STYLE_BgBlue = exports.CONSOLE_STYLE_BgYellow = exports.CONSOLE_STYLE_BgGreen = exports.CONSOLE_STYLE_BgRed = exports.CONSOLE_STYLE_BgBlack = exports.CONSOLE_STYLE_FgPink = exports.CONSOLE_STYLE_FgBrown = exports.CONSOLE_STYLE_FgViolet = exports.CONSOLE_STYLE_FgLightBlue = exports.CONSOLE_STYLE_FgLightGreen = exports.CONSOLE_STYLE_FgOrange = exports.CONSOLE_STYLE_FgGray = exports.CONSOLE_STYLE_FgWhite = exports.CONSOLE_STYLE_FgCyan = exports.CONSOLE_STYLE_FgMagenta = exports.CONSOLE_STYLE_FgBlue = exports.CONSOLE_STYLE_FgYellow = exports.CONSOLE_STYLE_FgGreen = exports.CONSOLE_STYLE_FgRed = exports.CONSOLE_STYLE_FgBlack = exports.CONSOLE_STYLE_Hidden = exports.CONSOLE_STYLE_Reverse = exports.CONSOLE_STYLE_Blink = exports.CONSOLE_STYLE_Underscore = exports.CONSOLE_STYLE_Dim = exports.CONSOLE_STYLE_Bright = exports.CONSOLE_STYLE_Reset = exports.MIN_INTERVAL_SECOND = exports.MAX_INTERVAL_SECOND = exports.SQL_DATETIME_FORMAT_WITHOUT_SECOND = exports.SQL_DATETIME_FORMAT = exports.SQL_DATE_FORMAT = exports.STATUS_PAGE_MAINTENANCE = exports.STATUS_PAGE_PARTIAL_DOWN = exports.STATUS_PAGE_ALL_UP = exports.STATUS_PAGE_ALL_DOWN = exports.MAINTENANCE = exports.PENDING = exports.UP = exports.DOWN = exports.appName = exports.isNode = exports.isDev = void 0; | ||||||
| exports.intHash = exports.localToUTC = exports.utcToLocal = exports.utcToISODateTime = exports.isoToUTCDateTime = exports.parseTimeFromTimeObject = exports.parseTimeObject = exports.getMaintenanceRelativeURL = exports.getMonitorRelativeURL = exports.genSecret = exports.getCryptoRandomInt = exports.getRandomInt = exports.getRandomArbitrary = exports.TimeLogger = exports.polyfill = exports.log = exports.debug = exports.ucfirst = void 0; | exports.intHash = exports.localToUTC = exports.utcToLocal = exports.utcToISODateTime = exports.isoToUTCDateTime = exports.parseTimeFromTimeObject = exports.parseTimeObject = exports.getMaintenanceRelativeURL = exports.getMonitorRelativeURL = exports.genSecret = exports.getCryptoRandomInt = exports.getRandomInt = exports.getRandomArbitrary = exports.TimeLogger = exports.polyfill = exports.log = exports.debug = exports.ucfirst = void 0; | ||||||
| const dayjs = require("dayjs"); | const dayjs_1 = __importDefault(require("dayjs")); | ||||||
| exports.isDev = process.env.NODE_ENV === "development"; | exports.isDev = process.env.NODE_ENV === "development"; | ||||||
| exports.isNode = typeof process !== "undefined" && ((_a = process === null || process === void 0 ? void 0 : process.versions) === null || _a === void 0 ? void 0 : _a.node); | exports.isNode = typeof process !== "undefined" && ((_a = process === null || process === void 0 ? void 0 : process.versions) === null || _a === void 0 ? void 0 : _a.node); | ||||||
| exports.appName = "Uptime Kuma"; | exports.appName = "Uptime Kuma"; | ||||||
| @@ -152,11 +155,11 @@ class Logger { | |||||||
|         module = module.toUpperCase(); |         module = module.toUpperCase(); | ||||||
|         level = level.toUpperCase(); |         level = level.toUpperCase(); | ||||||
|         let now; |         let now; | ||||||
|         if (dayjs.tz) { |         if (dayjs_1.default.tz) { | ||||||
|             now = dayjs.tz(new Date()).format(); |             now = dayjs_1.default.tz(new Date()).format(); | ||||||
|         } |         } | ||||||
|         else { |         else { | ||||||
|             now = dayjs().format(); |             now = (0, dayjs_1.default)().format(); | ||||||
|         } |         } | ||||||
|         const levelColor = consoleLevelColors[level]; |         const levelColor = consoleLevelColors[level]; | ||||||
|         const moduleColor = consoleModuleColors[intHash(module, consoleModuleColors.length)]; |         const moduleColor = consoleModuleColors[intHash(module, consoleModuleColors.length)]; | ||||||
| @@ -257,11 +260,11 @@ function polyfill() { | |||||||
| exports.polyfill = polyfill; | exports.polyfill = polyfill; | ||||||
| class TimeLogger { | class TimeLogger { | ||||||
|     constructor() { |     constructor() { | ||||||
|         this.startTime = dayjs().valueOf(); |         this.startTime = (0, dayjs_1.default)().valueOf(); | ||||||
|     } |     } | ||||||
|     print(name) { |     print(name) { | ||||||
|         if (exports.isDev && process.env.TIMELOGGER === "1") { |         if (exports.isDev && process.env.TIMELOGGER === "1") { | ||||||
|             console.log(name + ": " + (dayjs().valueOf() - this.startTime) + "ms"); |             console.log(name + ": " + ((0, dayjs_1.default)().valueOf() - this.startTime) + "ms"); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @@ -373,19 +376,19 @@ function parseTimeFromTimeObject(obj) { | |||||||
| } | } | ||||||
| exports.parseTimeFromTimeObject = parseTimeFromTimeObject; | exports.parseTimeFromTimeObject = parseTimeFromTimeObject; | ||||||
| function isoToUTCDateTime(input) { | function isoToUTCDateTime(input) { | ||||||
|     return dayjs(input).utc().format(exports.SQL_DATETIME_FORMAT); |     return (0, dayjs_1.default)(input).utc().format(exports.SQL_DATETIME_FORMAT); | ||||||
| } | } | ||||||
| exports.isoToUTCDateTime = isoToUTCDateTime; | exports.isoToUTCDateTime = isoToUTCDateTime; | ||||||
| function utcToISODateTime(input) { | function utcToISODateTime(input) { | ||||||
|     return dayjs.utc(input).toISOString(); |     return dayjs_1.default.utc(input).toISOString(); | ||||||
| } | } | ||||||
| exports.utcToISODateTime = utcToISODateTime; | exports.utcToISODateTime = utcToISODateTime; | ||||||
| function utcToLocal(input, format = exports.SQL_DATETIME_FORMAT) { | function utcToLocal(input, format = exports.SQL_DATETIME_FORMAT) { | ||||||
|     return dayjs.utc(input).local().format(format); |     return dayjs_1.default.utc(input).local().format(format); | ||||||
| } | } | ||||||
| exports.utcToLocal = utcToLocal; | exports.utcToLocal = utcToLocal; | ||||||
| function localToUTC(input, format = exports.SQL_DATETIME_FORMAT) { | function localToUTC(input, format = exports.SQL_DATETIME_FORMAT) { | ||||||
|     return dayjs(input).utc().format(format); |     return (0, dayjs_1.default)(input).utc().format(format); | ||||||
| } | } | ||||||
| exports.localToUTC = localToUTC; | exports.localToUTC = localToUTC; | ||||||
| function intHash(str, length = 10) { | function intHash(str, length = 10) { | ||||||
|   | |||||||
| @@ -9,7 +9,7 @@ | |||||||
| // Frontend uses util.ts | // Frontend uses util.ts | ||||||
| */ | */ | ||||||
|  |  | ||||||
| import * as dayjs from "dayjs"; | import dayjs from "dayjs"; | ||||||
|  |  | ||||||
| // For loading dayjs plugins, don't remove event though it is not used in this file | // For loading dayjs plugins, don't remove event though it is not used in this file | ||||||
| // eslint-disable-next-line @typescript-eslint/no-unused-vars | // eslint-disable-next-line @typescript-eslint/no-unused-vars | ||||||
|   | |||||||
| @@ -12,7 +12,8 @@ | |||||||
|         "removeComments": true, |         "removeComments": true, | ||||||
|         "preserveConstEnums": true, |         "preserveConstEnums": true, | ||||||
|         "sourceMap": false, |         "sourceMap": false, | ||||||
|         "strict": true |         "strict": true, | ||||||
|  |         "esModuleInterop": true | ||||||
|     }, |     }, | ||||||
|     "files": [ |     "files": [ | ||||||
|         "./src/util.ts" |         "./src/util.ts" | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user