159 lines
4.3 KiB
JavaScript
159 lines
4.3 KiB
JavaScript
import Vue from 'vue';
|
|
import VueApollo from 'vue-apollo';
|
|
import VueRouter from 'vue-router';
|
|
import IssuesListApp from 'ee_else_ce/issues/list/components/issues_list_app.vue';
|
|
import { parseBoolean } from '~/lib/utils/common_utils';
|
|
import JiraIssuesImportStatusApp from './components/jira_issues_import_status_app.vue';
|
|
import { gqlClient } from './graphql';
|
|
|
|
export async function mountJiraIssuesListApp() {
|
|
const el = document.querySelector('.js-jira-issues-import-status-root');
|
|
|
|
if (!el) {
|
|
return null;
|
|
}
|
|
|
|
const { issuesPath, projectPath } = el.dataset;
|
|
const canEdit = parseBoolean(el.dataset.canEdit);
|
|
const isJiraConfigured = parseBoolean(el.dataset.isJiraConfigured);
|
|
|
|
if (!isJiraConfigured || !canEdit) {
|
|
return null;
|
|
}
|
|
|
|
Vue.use(VueApollo);
|
|
|
|
return new Vue({
|
|
el,
|
|
name: 'JiraIssuesImportStatusRoot',
|
|
apolloProvider: new VueApollo({
|
|
defaultClient: await gqlClient(),
|
|
}),
|
|
render(createComponent) {
|
|
return createComponent(JiraIssuesImportStatusApp, {
|
|
props: {
|
|
canEdit,
|
|
isJiraConfigured,
|
|
issuesPath,
|
|
projectPath,
|
|
},
|
|
});
|
|
},
|
|
});
|
|
}
|
|
|
|
export async function mountIssuesListApp() {
|
|
const el = document.querySelector('.js-issues-list-root');
|
|
|
|
if (!el) {
|
|
return null;
|
|
}
|
|
|
|
Vue.use(VueApollo);
|
|
Vue.use(VueRouter);
|
|
|
|
const {
|
|
autocompleteAwardEmojisPath,
|
|
calendarPath,
|
|
canBulkUpdate,
|
|
canCreateProjects,
|
|
canEdit,
|
|
canImportIssues,
|
|
canReadCrmContact,
|
|
canReadCrmOrganization,
|
|
email,
|
|
emailsHelpPagePath,
|
|
emptyStateSvgPath,
|
|
exportCsvPath,
|
|
fullPath,
|
|
groupPath,
|
|
hasAnyIssues,
|
|
hasAnyProjects,
|
|
hasBlockedIssuesFeature,
|
|
hasIssuableHealthStatusFeature,
|
|
hasIssueWeightsFeature,
|
|
hasIterationsFeature,
|
|
hasScopedLabelsFeature,
|
|
hasOkrsFeature,
|
|
importCsvIssuesPath,
|
|
initialEmail,
|
|
initialSort,
|
|
isIssueRepositioningDisabled,
|
|
isProject,
|
|
isPublicVisibilityRestricted,
|
|
isSignedIn,
|
|
jiraIntegrationPath,
|
|
markdownHelpPath,
|
|
maxAttachmentSize,
|
|
newIssuePath,
|
|
newProjectPath,
|
|
projectImportJiraPath,
|
|
quickActionsHelpPath,
|
|
releasesPath,
|
|
resetPath,
|
|
rssPath,
|
|
showNewIssueLink,
|
|
signInPath,
|
|
} = el.dataset;
|
|
|
|
return new Vue({
|
|
el,
|
|
name: 'IssuesListRoot',
|
|
apolloProvider: new VueApollo({
|
|
defaultClient: await gqlClient(),
|
|
}),
|
|
router: new VueRouter({
|
|
base: window.location.pathname,
|
|
mode: 'history',
|
|
routes: [{ path: '/' }],
|
|
}),
|
|
provide: {
|
|
autocompleteAwardEmojisPath,
|
|
calendarPath,
|
|
canBulkUpdate: parseBoolean(canBulkUpdate),
|
|
canCreateProjects: parseBoolean(canCreateProjects),
|
|
canReadCrmContact: parseBoolean(canReadCrmContact),
|
|
canReadCrmOrganization: parseBoolean(canReadCrmOrganization),
|
|
emptyStateSvgPath,
|
|
fullPath,
|
|
groupPath,
|
|
hasAnyIssues: parseBoolean(hasAnyIssues),
|
|
hasAnyProjects: parseBoolean(hasAnyProjects),
|
|
hasBlockedIssuesFeature: parseBoolean(hasBlockedIssuesFeature),
|
|
hasIssuableHealthStatusFeature: parseBoolean(hasIssuableHealthStatusFeature),
|
|
hasIssueWeightsFeature: parseBoolean(hasIssueWeightsFeature),
|
|
hasIterationsFeature: parseBoolean(hasIterationsFeature),
|
|
hasScopedLabelsFeature: parseBoolean(hasScopedLabelsFeature),
|
|
hasOkrsFeature: parseBoolean(hasOkrsFeature),
|
|
initialSort,
|
|
isIssueRepositioningDisabled: parseBoolean(isIssueRepositioningDisabled),
|
|
isProject: parseBoolean(isProject),
|
|
isPublicVisibilityRestricted: parseBoolean(isPublicVisibilityRestricted),
|
|
isSignedIn: parseBoolean(isSignedIn),
|
|
jiraIntegrationPath,
|
|
newIssuePath,
|
|
newProjectPath,
|
|
releasesPath,
|
|
rssPath,
|
|
showNewIssueLink: parseBoolean(showNewIssueLink),
|
|
signInPath,
|
|
// For CsvImportExportButtons component
|
|
canEdit: parseBoolean(canEdit),
|
|
email,
|
|
exportCsvPath,
|
|
importCsvIssuesPath,
|
|
maxAttachmentSize,
|
|
projectImportJiraPath,
|
|
showExportButton: parseBoolean(hasAnyIssues),
|
|
showImportButton: parseBoolean(canImportIssues),
|
|
showLabel: !parseBoolean(hasAnyIssues),
|
|
// For IssuableByEmail component
|
|
emailsHelpPagePath,
|
|
initialEmail,
|
|
markdownHelpPath,
|
|
quickActionsHelpPath,
|
|
resetPath,
|
|
},
|
|
render: (createComponent) => createComponent(IssuesListApp),
|
|
});
|
|
}
|