2021-11-03 16:40:31 +00:00
|
|
|
import { computed, Ref } from 'vue';
|
2022-05-16 19:18:48 +00:00
|
|
|
import { useI18n } from 'vue-i18n';
|
2021-11-03 16:40:31 +00:00
|
|
|
|
2022-02-14 10:02:17 +00:00
|
|
|
import { useDate } from '~/compositions/useDate';
|
2021-11-03 16:40:31 +00:00
|
|
|
import { useElapsedTime } from '~/compositions/useElapsedTime';
|
2022-10-18 01:24:12 +00:00
|
|
|
import { Pipeline } from '~/lib/api/types';
|
2021-11-03 16:40:31 +00:00
|
|
|
import { prettyDuration } from '~/utils/duration';
|
|
|
|
import { convertEmojis } from '~/utils/emoji';
|
2023-08-03 17:25:12 +00:00
|
|
|
|
|
|
|
import useTimeAgo from './useTimeAgo';
|
2021-11-03 16:40:31 +00:00
|
|
|
|
2022-02-14 10:02:17 +00:00
|
|
|
const { toLocaleString } = useDate();
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
export default (pipeline: Ref<Pipeline | undefined>) => {
|
2021-11-03 16:40:31 +00:00
|
|
|
const sinceRaw = computed(() => {
|
2022-10-18 01:24:12 +00:00
|
|
|
if (!pipeline.value) {
|
2021-11-03 16:40:31 +00:00
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
const start = pipeline.value.created_at || 0;
|
2021-11-03 16:40:31 +00:00
|
|
|
|
|
|
|
return start * 1000;
|
|
|
|
});
|
|
|
|
|
|
|
|
const sinceUnderOneHour = computed(
|
|
|
|
() => sinceRaw.value !== undefined && sinceRaw.value > 0 && sinceRaw.value <= 1000 * 60 * 60,
|
|
|
|
);
|
|
|
|
const { time: sinceElapsed } = useElapsedTime(sinceUnderOneHour, sinceRaw);
|
|
|
|
|
2022-05-16 19:18:48 +00:00
|
|
|
const i18n = useI18n();
|
2023-08-03 17:25:12 +00:00
|
|
|
const timeAgo = useTimeAgo();
|
2021-11-03 16:40:31 +00:00
|
|
|
const since = computed(() => {
|
|
|
|
if (sinceRaw.value === 0) {
|
2022-05-16 19:18:48 +00:00
|
|
|
return i18n.t('time.not_started');
|
2021-11-03 16:40:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (sinceElapsed.value === undefined) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
return timeAgo.format(sinceElapsed.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
const durationRaw = computed(() => {
|
2022-10-18 01:24:12 +00:00
|
|
|
if (!pipeline.value) {
|
2021-11-03 16:40:31 +00:00
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
const start = pipeline.value.started_at || 0;
|
|
|
|
const end = pipeline.value.finished_at || pipeline.value.updated_at || 0;
|
2021-11-03 16:40:31 +00:00
|
|
|
|
2022-01-31 15:58:11 +00:00
|
|
|
if (start === 0 || end === 0) {
|
2021-11-03 16:40:31 +00:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
// only calculate time based no now() for running pipelines
|
|
|
|
if (pipeline.value.status === 'running') {
|
2021-11-03 16:40:31 +00:00
|
|
|
return Date.now() - start * 1000;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (end - start) * 1000;
|
|
|
|
});
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
const running = computed(() => pipeline.value !== undefined && pipeline.value.status === 'running');
|
2021-11-03 16:40:31 +00:00
|
|
|
const { time: durationElapsed } = useElapsedTime(running, durationRaw);
|
|
|
|
|
|
|
|
const duration = computed(() => {
|
|
|
|
if (durationElapsed.value === undefined) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (durationRaw.value === 0) {
|
2022-05-16 19:18:48 +00:00
|
|
|
return i18n.t('time.not_started');
|
2021-11-03 16:40:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return prettyDuration(durationElapsed.value);
|
|
|
|
});
|
|
|
|
|
|
|
|
const message = computed(() => {
|
2022-10-18 01:24:12 +00:00
|
|
|
if (!pipeline.value) {
|
2021-11-03 16:40:31 +00:00
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
return convertEmojis(pipeline.value.message);
|
2021-11-03 16:40:31 +00:00
|
|
|
});
|
|
|
|
|
2023-08-30 15:08:56 +00:00
|
|
|
const title = computed(() => message.value.split('\n')[0]);
|
|
|
|
|
2022-01-16 17:42:10 +00:00
|
|
|
const prettyRef = computed(() => {
|
2023-09-17 10:32:23 +00:00
|
|
|
if (pipeline.value?.event === 'push' || pipeline.value?.event === 'deployment') {
|
2022-10-18 01:24:12 +00:00
|
|
|
return pipeline.value.branch;
|
2022-01-16 17:42:10 +00:00
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
if (pipeline.value?.event === 'cron') {
|
|
|
|
return pipeline.value.ref.replaceAll('refs/heads/', '');
|
2022-08-31 22:36:32 +00:00
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
if (pipeline.value?.event === 'tag') {
|
|
|
|
return pipeline.value.ref.replaceAll('refs/tags/', '');
|
2022-01-16 17:42:10 +00:00
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
if (pipeline.value?.event === 'pull_request') {
|
|
|
|
return `#${pipeline.value.ref
|
2022-01-16 17:42:10 +00:00
|
|
|
.replaceAll('refs/pull/', '')
|
|
|
|
.replaceAll('refs/merge-requests/', '')
|
|
|
|
.replaceAll('/merge', '')
|
|
|
|
.replaceAll('/head', '')}`;
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
return pipeline.value?.ref;
|
2022-01-16 17:42:10 +00:00
|
|
|
});
|
|
|
|
|
2022-02-08 22:41:16 +00:00
|
|
|
const created = computed(() => {
|
2022-10-18 01:24:12 +00:00
|
|
|
if (!pipeline.value) {
|
2022-02-08 22:41:16 +00:00
|
|
|
return undefined;
|
|
|
|
}
|
|
|
|
|
2022-10-18 01:24:12 +00:00
|
|
|
const start = pipeline.value.created_at || 0;
|
2022-02-08 22:41:16 +00:00
|
|
|
|
2022-02-14 10:02:17 +00:00
|
|
|
return toLocaleString(new Date(start * 1000));
|
2022-02-08 22:41:16 +00:00
|
|
|
});
|
2022-02-14 10:02:17 +00:00
|
|
|
|
2023-08-30 15:08:56 +00:00
|
|
|
return { since, duration, message, title, prettyRef, created };
|
2021-11-03 16:40:31 +00:00
|
|
|
};
|