35 lines
1.1 KiB
JavaScript
35 lines
1.1 KiB
JavaScript
import Vue from 'vue';
|
|
import { TYPE_ISSUE } from '~/issues/constants';
|
|
import { apolloProvider } from '~/graphql_shared/issuable_client';
|
|
import { parseBoolean } from '~/lib/utils/common_utils';
|
|
import RelatedIssuesRoot from './components/related_issues_root.vue';
|
|
|
|
export function initRelatedIssues(issueType = TYPE_ISSUE) {
|
|
const el = document.querySelector('.js-related-issues-root');
|
|
|
|
if (!el) {
|
|
return null;
|
|
}
|
|
|
|
return new Vue({
|
|
el,
|
|
name: 'RelatedIssuesRoot',
|
|
apolloProvider,
|
|
provide: {
|
|
fullPath: el.dataset.fullPath,
|
|
hasIssueWeightsFeature: parseBoolean(el.dataset.hasIssueWeightsFeature),
|
|
hasIterationsFeature: parseBoolean(el.dataset.hasIterationsFeature),
|
|
},
|
|
render: (createElement) =>
|
|
createElement(RelatedIssuesRoot, {
|
|
props: {
|
|
endpoint: el.dataset.endpoint,
|
|
canAdmin: parseBoolean(el.dataset.canAddRelatedIssues),
|
|
helpPath: el.dataset.helpPath,
|
|
showCategorizedIssues: parseBoolean(el.dataset.showCategorizedIssues),
|
|
issuableType: issueType,
|
|
autoCompleteEpics: false,
|
|
},
|
|
}),
|
|
});
|
|
}
|