118 lines
3.2 KiB
JavaScript
118 lines
3.2 KiB
JavaScript
import Vue from 'vue';
|
|
import Vuex from 'vuex';
|
|
import VueApollo from 'vue-apollo';
|
|
import PipelineTabs from 'ee_else_ce/pipelines/components/pipeline_tabs.vue';
|
|
import { removeParams, updateHistory } from '~/lib/utils/url_utility';
|
|
import { TAB_QUERY_PARAM } from '~/pipelines/constants';
|
|
import { parseBoolean } from '~/lib/utils/common_utils';
|
|
import createTestReportsStore from './stores/test_reports';
|
|
import { getPipelineDefaultTab, reportToSentry } from './utils';
|
|
|
|
Vue.use(VueApollo);
|
|
Vue.use(Vuex);
|
|
|
|
export const createAppOptions = (selector, apolloProvider) => {
|
|
const el = document.querySelector(selector);
|
|
|
|
if (!el) return null;
|
|
|
|
const { dataset } = el;
|
|
const {
|
|
canGenerateCodequalityReports,
|
|
codequalityReportDownloadPath,
|
|
codequalityBlobPath,
|
|
codequalityProjectPath,
|
|
downloadablePathForReportType,
|
|
exposeSecurityDashboard,
|
|
exposeLicenseScanningData,
|
|
failedJobsCount,
|
|
failedJobsSummary,
|
|
fullPath,
|
|
graphqlResourceEtag,
|
|
pipelineIid,
|
|
pipelineProjectPath,
|
|
totalJobCount,
|
|
licenseManagementApiUrl,
|
|
licenseManagementSettingsPath,
|
|
licensesApiPath,
|
|
canManageLicenses,
|
|
summaryEndpoint,
|
|
suiteEndpoint,
|
|
blobPath,
|
|
hasTestReport,
|
|
emptyStateImagePath,
|
|
artifactsExpiredImagePath,
|
|
isFullCodequalityReportAvailable,
|
|
testsCount,
|
|
} = dataset;
|
|
|
|
// TODO remove projectPath variable once https://gitlab.com/gitlab-org/gitlab/-/issues/371641 is resolved
|
|
const projectPath = fullPath;
|
|
const defaultTabValue = getPipelineDefaultTab(window.location.href);
|
|
|
|
return {
|
|
el,
|
|
components: {
|
|
PipelineTabs,
|
|
},
|
|
apolloProvider,
|
|
store: new Vuex.Store({
|
|
modules: {
|
|
testReports: createTestReportsStore({
|
|
blobPath,
|
|
summaryEndpoint,
|
|
suiteEndpoint,
|
|
}),
|
|
},
|
|
}),
|
|
provide: {
|
|
canGenerateCodequalityReports: parseBoolean(canGenerateCodequalityReports),
|
|
codequalityReportDownloadPath,
|
|
codequalityBlobPath,
|
|
codequalityProjectPath,
|
|
isFullCodequalityReportAvailable: parseBoolean(isFullCodequalityReportAvailable),
|
|
projectPath,
|
|
defaultTabValue,
|
|
downloadablePathForReportType,
|
|
exposeSecurityDashboard: parseBoolean(exposeSecurityDashboard),
|
|
exposeLicenseScanningData: parseBoolean(exposeLicenseScanningData),
|
|
failedJobsCount,
|
|
failedJobsSummary: JSON.parse(failedJobsSummary),
|
|
fullPath,
|
|
graphqlResourceEtag,
|
|
pipelineIid,
|
|
pipelineProjectPath,
|
|
totalJobCount,
|
|
licenseManagementApiUrl,
|
|
licenseManagementSettingsPath,
|
|
licensesApiPath,
|
|
canManageLicenses: parseBoolean(canManageLicenses),
|
|
summaryEndpoint,
|
|
suiteEndpoint,
|
|
blobPath,
|
|
hasTestReport,
|
|
emptyStateImagePath,
|
|
artifactsExpiredImagePath,
|
|
testsCount,
|
|
},
|
|
errorCaptured(err, _vm, info) {
|
|
reportToSentry('pipeline_tabs', `error: ${err}, info: ${info}`);
|
|
},
|
|
render(createElement) {
|
|
return createElement(PipelineTabs);
|
|
},
|
|
};
|
|
};
|
|
|
|
export const createPipelineTabs = (options) => {
|
|
if (!options) return;
|
|
|
|
updateHistory({
|
|
url: removeParams([TAB_QUERY_PARAM]),
|
|
title: document.title,
|
|
replace: true,
|
|
});
|
|
|
|
// eslint-disable-next-line no-new
|
|
new Vue(options);
|
|
};
|