pipelines_table.js 1.33 KB
Newer Older
1
/* eslint-disable no-param-reassign */
Filipa Lacerda's avatar
Filipa Lacerda committed
2 3
/* global Vue */

4
require('./pipelines_table_row');
5
/**
6
 * Pipelines Table Component.
7
 *
8
 * Given an array of objects, renders a table.
9
 */
Filipa Lacerda's avatar
Filipa Lacerda committed
10 11 12 13 14 15 16 17

(() => {
  window.gl = window.gl || {};
  gl.pipelines = gl.pipelines || {};

  gl.pipelines.PipelinesTableComponent = Vue.component('pipelines-table-component', {

    props: {
18 19
      pipelines: {
        type: Array,
Filipa Lacerda's avatar
Filipa Lacerda committed
20
        required: true,
21
        default: () => ([]),
Filipa Lacerda's avatar
Filipa Lacerda committed
22 23 24 25 26
      },

    },

    components: {
27
      'pipelines-table-row-component': gl.pipelines.PipelinesTableRowComponent,
Filipa Lacerda's avatar
Filipa Lacerda committed
28 29 30
    },

    template: `
31 32 33
      <table class="table ci-table">
        <thead>
          <tr>
34 35 36 37 38
            <th class="js-pipeline-status pipeline-status">Status</th>
            <th class="js-pipeline-info pipeline-info">Pipeline</th>
            <th class="js-pipeline-commit pipeline-commit">Commit</th>
            <th class="js-pipeline-stages pipeline-stages">Stages</th>
            <th class="js-pipeline-date pipeline-date"></th>
39
            <th class="js-pipeline-actions pipeline-actions"></th>
40 41 42 43 44
          </tr>
        </thead>
        <tbody>
          <template v-for="model in pipelines"
            v-bind:model="model">
45
            <tr is="pipelines-table-row-component"
Filipa Lacerda's avatar
Filipa Lacerda committed
46
              :pipeline="model"></tr>
47 48 49
          </template>
        </tbody>
      </table>
Filipa Lacerda's avatar
Filipa Lacerda committed
50 51 52
    `,
  });
})();