summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/issue_show/incident.js
blob: 618fb551f283be0c6ae6e26e94f42271c4e62a84 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
import Vue from 'vue';
import VueApollo from 'vue-apollo';
import createDefaultClient from '~/lib/graphql';
import issuableApp from './components/app.vue';
import incidentTabs from './components/incidents/incident_tabs.vue';
import { parseBoolean } from '~/lib/utils/common_utils';

Vue.use(VueApollo);

export default function initIssuableApp(issuableData = {}) {
  const apolloProvider = new VueApollo({
    defaultClient: createDefaultClient(),
  });

  const { iid, projectNamespace, projectPath, slaFeatureAvailable } = issuableData;

  return new Vue({
    el: document.getElementById('js-issuable-app'),
    apolloProvider,
    components: {
      issuableApp,
    },
    provide: {
      fullPath: `${projectNamespace}/${projectPath}`,
      iid,
      slaFeatureAvailable: parseBoolean(slaFeatureAvailable),
    },
    render(createElement) {
      return createElement('issuable-app', {
        props: {
          ...issuableData,
          descriptionComponent: incidentTabs,
          showTitleBorder: false,
        },
      });
    },
  });
}