summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/alert_management/components/alert_sidebar.vue
blob: 41d77716592dc95aef34f66052ccba3392ff09ff (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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
<script>
import SidebarHeader from './sidebar/sidebar_header.vue';
import SidebarTodo from './sidebar/sidebar_todo.vue';
import SidebarStatus from './sidebar/sidebar_status.vue';
import SidebarAssignees from './sidebar/sidebar_assignees.vue';

import sidebarStatusQuery from '../graphql/queries/sidebar_status.query.graphql';

export default {
  components: {
    SidebarAssignees,
    SidebarHeader,
    SidebarTodo,
    SidebarStatus,
  },
  inject: {
    projectPath: {
      default: '',
    },
    projectId: {
      default: '',
    },
  },
  props: {
    alert: {
      type: Object,
      required: true,
    },
  },
  apollo: {
    sidebarStatus: {
      query: sidebarStatusQuery,
    },
  },
  data() {
    return {
      sidebarStatus: false,
    };
  },
  computed: {
    sidebarCollapsedClass() {
      return this.sidebarStatus ? 'right-sidebar-collapsed' : 'right-sidebar-expanded';
    },
  },
};
</script>

<template>
  <aside :class="sidebarCollapsedClass" class="right-sidebar alert-sidebar">
    <div class="issuable-sidebar js-issuable-update">
      <sidebar-header
        :sidebar-collapsed="sidebarStatus"
        :project-path="projectPath"
        :alert="alert"
        @toggle-sidebar="$emit('toggle-sidebar')"
        @alert-error="$emit('alert-error', $event)"
      />
      <sidebar-todo
        v-if="sidebarStatus"
        :project-path="projectPath"
        :alert="alert"
        :sidebar-collapsed="sidebarStatus"
        @alert-error="$emit('alert-error', $event)"
      />
      <sidebar-status
        :project-path="projectPath"
        :alert="alert"
        @toggle-sidebar="$emit('toggle-sidebar')"
        @alert-error="$emit('alert-error', $event)"
      />
      <sidebar-assignees
        :project-path="projectPath"
        :project-id="projectId"
        :alert="alert"
        :sidebar-collapsed="sidebarStatus"
        @toggle-sidebar="$emit('toggle-sidebar')"
        @alert-error="$emit('alert-error', $event)"
      />
      <div class="block"></div>
    </div>
  </aside>
</template>