2021-08-17 01:41:12 -07:00
|
|
|
import dayjs from "dayjs";
|
|
|
|
import relativeTime from "dayjs/plugin/relativeTime";
|
2021-09-27 23:07:42 -07:00
|
|
|
import timezone from "dayjs/plugin/timezone";
|
|
|
|
import utc from "dayjs/plugin/utc";
|
2021-08-17 01:41:12 -07:00
|
|
|
dayjs.extend(utc);
|
|
|
|
dayjs.extend(timezone);
|
|
|
|
dayjs.extend(relativeTime);
|
|
|
|
|
2021-08-17 01:43:59 -07:00
|
|
|
/**
|
|
|
|
* DateTime Mixin
|
|
|
|
* Handled timezone and format
|
|
|
|
*/
|
2021-08-17 01:41:12 -07:00
|
|
|
export default {
|
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
userTimezone: localStorage.timezone || "auto",
|
2021-09-27 23:07:42 -07:00
|
|
|
};
|
2021-08-17 01:41:12 -07:00
|
|
|
},
|
|
|
|
|
|
|
|
methods: {
|
|
|
|
datetime(value) {
|
|
|
|
return this.datetimeFormat(value, "YYYY-MM-DD HH:mm:ss");
|
|
|
|
},
|
|
|
|
|
|
|
|
date(value) {
|
|
|
|
return this.datetimeFormat(value, "YYYY-MM-DD");
|
|
|
|
},
|
|
|
|
|
|
|
|
time(value, second = true) {
|
|
|
|
let secondString;
|
|
|
|
if (second) {
|
|
|
|
secondString = ":ss";
|
|
|
|
} else {
|
|
|
|
secondString = "";
|
|
|
|
}
|
|
|
|
return this.datetimeFormat(value, "HH:mm" + secondString);
|
|
|
|
},
|
|
|
|
|
|
|
|
datetimeFormat(value, format) {
|
|
|
|
if (value !== undefined && value !== "") {
|
|
|
|
return dayjs.utc(value).tz(this.timezone).format(format);
|
|
|
|
}
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
computed: {
|
|
|
|
timezone() {
|
|
|
|
if (this.userTimezone === "auto") {
|
2021-09-27 23:07:42 -07:00
|
|
|
return dayjs.tz.guess();
|
2021-08-17 01:41:12 -07:00
|
|
|
}
|
|
|
|
|
2021-09-27 23:07:42 -07:00
|
|
|
return this.userTimezone;
|
2021-08-17 01:41:12 -07:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2021-09-27 23:07:42 -07:00
|
|
|
};
|