mirror of
https://github.com/apache/skywalking-booster-ui.git
synced 2025-05-02 07:54:02 +00:00
136 lines
4.2 KiB
TypeScript
136 lines
4.2 KiB
TypeScript
/**
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership.
|
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
* (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
import { defineStore } from "pinia";
|
|
import { store } from "@/store";
|
|
import { Duration, DurationTime } from "@/types/app";
|
|
import getLocalTime from "@/utils/localtime";
|
|
import getDurationRow from "@/utils/dateTime";
|
|
import dateFormatStep, { dateFormatTime } from "@/utils/dateFormat";
|
|
/*global Nullable*/
|
|
interface AppState {
|
|
durationRow: any;
|
|
utc: string;
|
|
utcHour: number;
|
|
utcMin: number;
|
|
eventStack: (() => unknown)[];
|
|
timer: Nullable<any>;
|
|
}
|
|
|
|
export const appStore = defineStore({
|
|
id: "app",
|
|
state: (): AppState => ({
|
|
durationRow: getDurationRow(),
|
|
utc: "",
|
|
utcHour: 0,
|
|
utcMin: 0,
|
|
eventStack: [],
|
|
timer: null,
|
|
}),
|
|
getters: {
|
|
duration(): Duration {
|
|
return {
|
|
start: getLocalTime(this.utc, this.durationRow.start),
|
|
end: getLocalTime(this.utc, this.durationRow.end),
|
|
step: this.durationRow.step,
|
|
};
|
|
},
|
|
durationTime(): DurationTime {
|
|
return {
|
|
start: dateFormatStep(this.duration.start, this.duration.step, true),
|
|
end: dateFormatStep(this.duration.end, this.duration.step, true),
|
|
step: this.duration.step,
|
|
};
|
|
},
|
|
intervalTime(): string[] {
|
|
let interval = 946080000000;
|
|
switch (this.duration.step) {
|
|
case "MINUTE":
|
|
interval = 60000;
|
|
break;
|
|
case "HOUR":
|
|
interval = 3600000;
|
|
break;
|
|
case "DAY":
|
|
interval = 86400000;
|
|
break;
|
|
case "MONTH":
|
|
interval =
|
|
(this.duration.end.getTime() - this.duration.start.getTime()) /
|
|
(this.duration.end.getFullYear() * 12 +
|
|
this.duration.end.getMonth() -
|
|
this.duration.start.getFullYear() * 12 -
|
|
this.duration.start.getMonth());
|
|
break;
|
|
}
|
|
const utcArr = this.utc.split(":");
|
|
const utcHour = isNaN(Number(utcArr[0])) ? 0 : Number(utcArr[0]);
|
|
const utcMin = isNaN(Number(utcArr[1])) ? 0 : Number(utcArr[1]);
|
|
const utcSpace =
|
|
(utcHour + new Date().getTimezoneOffset() / 60) * 3600000 +
|
|
utcMin * 60000;
|
|
const startUnix: number = this.duration.start.getTime();
|
|
const endUnix: number = this.duration.end.getTime();
|
|
const timeIntervals: string[] = [];
|
|
for (let i = 0; i <= endUnix - startUnix; i += interval) {
|
|
const temp: string = dateFormatTime(
|
|
new Date(startUnix + i - utcSpace),
|
|
this.duration.step
|
|
);
|
|
timeIntervals.push(temp);
|
|
}
|
|
return timeIntervals;
|
|
},
|
|
},
|
|
actions: {
|
|
setDuration(data: Duration): void {
|
|
this.durationRow = data;
|
|
if ((window as any).axiosCancel.length !== 0) {
|
|
for (const event of (window as any).axiosCancel) {
|
|
setTimeout(event(), 0);
|
|
}
|
|
(window as any).axiosCancel = [];
|
|
}
|
|
this.runEventStack();
|
|
},
|
|
setUTC(utcHour: number, utcMin: number): void {
|
|
this.runEventStack();
|
|
this.utcMin = utcMin;
|
|
this.utcHour = utcHour;
|
|
this.utc = `${utcHour}:${utcMin}`;
|
|
localStorage.setItem("utc", this.utc);
|
|
},
|
|
setEventStack(funcs: (() => void)[]): void {
|
|
this.eventStack = funcs;
|
|
},
|
|
runEventStack() {
|
|
if (this.timer) {
|
|
clearTimeout(this.timer);
|
|
}
|
|
this.timer = setTimeout(
|
|
() =>
|
|
this.eventStack.forEach((event: any) => {
|
|
setTimeout(event(), 0);
|
|
}),
|
|
500
|
|
);
|
|
},
|
|
},
|
|
});
|
|
export function useAppStoreWithOut(): any {
|
|
return appStore(store);
|
|
}
|