summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/vue_merge_request_widget/components/extensions/container.js
blob: b9dfd3bd41e4483df7ae5a3bd2cbd9f56ee2eb7d (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
import { __ } from '~/locale';
import { registeredExtensions } from './index';

export default {
  props: {
    mr: {
      type: Object,
      required: true,
    },
  },
  render(h) {
    const { extensions } = registeredExtensions;

    if (extensions.length === 0) return null;

    return h(
      'div',
      {
        attrs: {
          role: 'region',
          'aria-label': __('Merge request reports'),
        },
      },
      [
        h(
          'ul',
          {
            class: 'gl-p-0 gl-m-0 gl-list-style-none',
          },
          [
            ...extensions.map((extension, index) =>
              h('li', { attrs: { class: index > 0 && 'mr-widget-border-top' } }, [
                h(
                  { ...extension },
                  {
                    props: {
                      ...extension.props.reduce(
                        (acc, key) => ({
                          ...acc,
                          [key]: this.mr[key],
                        }),
                        {},
                      ),
                    },
                  },
                ),
              ]),
            ),
          ],
        ),
      ],
    );
  },
};