summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/environments/environments_bundle.js
blob: 2e0a4001b7c235fe2c008814d7dbfd5111ae0f1c (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
39
import Vue from 'vue';
import environmentsComponent from './components/environments_app.vue';
import { convertPermissionToBoolean } from '../lib/utils/common_utils';
import Translate from '../vue_shared/translate';

Vue.use(Translate);

document.addEventListener('DOMContentLoaded', () => new Vue({
  el: '#environments-list-view',
  components: {
    environmentsComponent,
  },
  data() {
    const environmentsData = document.querySelector(this.$options.el).dataset;

    return {
      endpoint: environmentsData.environmentsDataEndpoint,
      newEnvironmentPath: environmentsData.newEnvironmentPath,
      helpPagePath: environmentsData.helpPagePath,
      cssContainerClass: environmentsData.cssClass,
      canCreateEnvironment: convertPermissionToBoolean(environmentsData.canCreateEnvironment),
      canCreateDeployment: convertPermissionToBoolean(environmentsData.canCreateDeployment),
      canReadEnvironment: convertPermissionToBoolean(environmentsData.canReadEnvironment),
    };
  },
  render(createElement) {
    return createElement('environments-component', {
      props: {
        endpoint: this.endpoint,
        newEnvironmentPath: this.newEnvironmentPath,
        helpPagePath: this.helpPagePath,
        cssContainerClass: this.cssContainerClass,
        canCreateEnvironment: this.canCreateEnvironment,
        canCreateDeployment: this.canCreateDeployment,
        canReadEnvironment: this.canReadEnvironment,
      },
    });
  },
}));