0.18.2 • Published 7 years ago

vue-md-powerful-datatable v0.18.2

Weekly downloads
17
License
MIT
Repository
github
Last release
7 years ago

vue-md-powerful-datatable

A Vue.js 2.0 Component

Development

Roadmap

  • Refactor general code (from ugly for loops to array functions etc 🙄)
  • Add tests (jest maybe?)
  • Refactor prop names
  • Refactor CSS

Prerequisites

  • nodeJS
  • VueJS material-design

    $ npm i vue-material
  • VueJS material-design-lite

    $ npm install vue-mdl

Usage

Installation

$ npm install vue-md-powerful-datatable
$ yarn add vue-md-powerful-datatable

Use component

  • add material design icons to html

    <link rel="stylesheet" href="//fonts.googleapis.com/css?family=Roboto:300,400,500,700,400italic">
    <link rel="stylesheet" href="//fonts.googleapis.com/icon?family=Material+Icons">
  • add to components:

    import VueMdPowerfulDatatable from 'vue-md-powerful-datatable';
    ...
    components: {
        VueMdPowerfulDatatable,
    },
  • add md libs to Vue init script:

    import VueMdl from 'vue-mdl';
    import VueMaterial from 'vue-material';
    
    require('vue-material/dist/vue-material.css');
    
    Vue.use(VueMaterial);
    Vue.material.registerTheme('blue', {});
    
    require('material-design-lite/material.min.js');
    require('material-design-lite/material.min.css');
  • in template:

    <vue-md-powerful-datatable
        :headData="birdsHeadData"
        :data="birds"
        max=10>
    </vue-md-powerful-datatable>
  • data and headData in parent component

    birds: [
        {
          name: 'Birdy',
          variety: 'Eagle',
          size: 330,
          wingCount: 1.5,
        },
        {
          name: 'Rosa',
          variety: 'Peacock',
          size: 630,
          wingCount: 2,
        },
      ],
      birdsHeadData: [
        {
          key: 'name',
          name: 'Birds Name',
        }, {
          key: 'variety',
          name: 'Birds variety',
        }, {
          key: 'size',
          name: 'Size of Bird',
          format: (value) => { // dynamically change format
            if (value) {
              return `${value} mm`;
            }
            return '';
          },
        }, {
          key: 'wingCount',
          name: 'Number of wings',
        },
      ],

Props

property namedescriptiontypeexample
dataactual table dataArray[{ name: 'test', anotherKey: 'asd', ... }, ...]
headDatatable header information Array[{ key: 'name', // object's key name: 'Birds Name' // column title }]
maxnumber of rows per page, default: 20Number 
ignoreColumnshide data columnsArray['anotherKey', ...]
searchenable search, default: trueBoolean
pagerenable pagination, default: trueBoolean
sortableenable sort, default: trueBoolean 
selectableenable selectable rows (selectedRowIndexKey must be provided on true), default: falseBoolean  
selectedRowIndexKeykey name for selecting linesString'name'
selectAllOnlyOnPagethe "select all" checkbox in table header will only select rows on current pageBooleanfalse

Events

event namedescriptionarguments
rowSelectionChangeWill be emitted everytime a row is selected or deselectedArray of keys of selected lines

Use selectable feature

  • in template:

    <vue-md-powerful-datatable
        :headData="birdsHeadData"
        :data="birds"
        max=10
    
        selectable="true"
        selectedRowIndexKey="name"
        v-on:rowSelectionChange="selectedRowsChanged"
        > <!-- last 3 attributes to use feature -->
    </vue-md-powerful-datatable>
  • in methods:

    ...
    methods: {
      ...
      selectedRowsChanged(selectedRows) {
        console.log(selectedRows);
      },
      ...
    }
    ...
0.18.2

7 years ago

0.18.1

7 years ago

0.18.0

7 years ago

0.17.0

8 years ago

0.16.3

8 years ago

0.16.2

8 years ago

0.16.1

8 years ago

0.16.0

8 years ago

0.15.0

8 years ago

0.14.4

8 years ago

0.14.3

8 years ago

0.14.2

8 years ago

0.14.1

8 years ago

0.14.0

8 years ago

0.13.2

8 years ago

0.13.0

8 years ago

0.12.1

8 years ago

0.12.0

8 years ago

0.11.2

8 years ago

0.11.1

8 years ago

0.11.0

8 years ago

0.10.0

8 years ago

0.9.0

8 years ago

0.8.0

8 years ago

0.7.0

8 years ago

0.6.0

8 years ago

0.5.3

8 years ago

0.5.2

8 years ago

0.5.1

8 years ago

0.5.0

8 years ago

0.4.0

8 years ago

0.3.0

8 years ago