debian-mirror-gitlab/app/assets/javascripts/pipelines/pipeline_tabs.js

64 lines
1.8 KiB
JavaScript
Raw Normal View History

2022-06-21 17:19:12 +05:30
import Vue from 'vue';
import VueApollo from 'vue-apollo';
import PipelineTabs from 'ee_else_ce/pipelines/components/pipeline_tabs.vue';
2022-07-16 23:28:13 +05:30
import { removeParams, updateHistory } from '~/lib/utils/url_utility';
import { TAB_QUERY_PARAM } from '~/pipelines/constants';
import { parseBoolean } from '~/lib/utils/common_utils';
import { getPipelineDefaultTab, reportToSentry } from './utils';
2022-06-21 17:19:12 +05:30
Vue.use(VueApollo);
const createPipelineTabs = (selector, apolloProvider) => {
const el = document.querySelector(selector);
if (!el) return;
const { dataset } = document.querySelector(selector);
const {
canGenerateCodequalityReports,
codequalityReportDownloadPath,
downloadablePathForReportType,
exposeSecurityDashboard,
exposeLicenseScanningData,
2022-07-16 23:28:13 +05:30
graphqlResourceEtag,
pipelineIid,
pipelineProjectPath,
2022-06-21 17:19:12 +05:30
} = dataset;
2022-07-16 23:28:13 +05:30
const defaultTabValue = getPipelineDefaultTab(window.location.href);
updateHistory({
url: removeParams([TAB_QUERY_PARAM]),
title: document.title,
replace: true,
});
2022-06-21 17:19:12 +05:30
// eslint-disable-next-line no-new
new Vue({
el: selector,
components: {
PipelineTabs,
},
apolloProvider,
provide: {
2022-07-16 23:28:13 +05:30
canGenerateCodequalityReports: parseBoolean(canGenerateCodequalityReports),
2022-06-21 17:19:12 +05:30
codequalityReportDownloadPath,
2022-07-16 23:28:13 +05:30
defaultTabValue,
2022-06-21 17:19:12 +05:30
downloadablePathForReportType,
2022-07-16 23:28:13 +05:30
exposeSecurityDashboard: parseBoolean(exposeSecurityDashboard),
exposeLicenseScanningData: parseBoolean(exposeLicenseScanningData),
graphqlResourceEtag,
pipelineIid,
pipelineProjectPath,
2022-06-21 17:19:12 +05:30
},
errorCaptured(err, _vm, info) {
reportToSentry('pipeline_tabs', `error: ${err}, info: ${info}`);
},
render(createElement) {
return createElement(PipelineTabs);
},
});
};
export { createPipelineTabs };