All files / app/assets/javascripts/incidents list.js

0% Statements 0/7
100% Branches 0/0
0% Functions 0/2
0% Lines 0/7

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56                                                                                                               
import Vue from 'vue';
import VueApollo from 'vue-apollo';
import createDefaultClient from '~/lib/graphql';
import { parseBoolean } from '~/lib/utils/common_utils';
import IncidentsList from './components/incidents_list.vue';
 
Vue.use(VueApollo);
export default () => {
  const selector = '#js-incidents';
 
  const domEl = document.querySelector(selector);
  const {
    projectPath,
    newIssuePath,
    incidentTemplateName,
    incidentType,
    issuePath,
    publishedAvailable,
    emptyListSvgPath,
    textQuery,
    authorUsernameQuery,
    assigneeUsernameQuery,
    slaFeatureAvailable,
    canCreateIncident,
  } = domEl.dataset;
 
  const apolloProvider = new VueApollo({
    defaultClient: createDefaultClient(),
  });
 
  return new Vue({
    el: selector,
    components: {
      IncidentsList,
    },
    provide: {
      projectPath,
      incidentTemplateName,
      incidentType,
      newIssuePath,
      issuePath,
      publishedAvailable: parseBoolean(publishedAvailable),
      emptyListSvgPath,
      textQuery,
      authorUsernameQuery,
      assigneeUsernameQuery,
      slaFeatureAvailable: parseBoolean(slaFeatureAvailable),
      canCreateIncident: parseBoolean(canCreateIncident),
    },
    apolloProvider,
    render(createElement) {
      return createElement('incidents-list');
    },
  });
};