Podtable is a no dependency table library to fit large table dataset into smaller device screens base on the maximum squishability with various options on achieving a responsive datatable.
Preview
Installation
NPM
npm install podtable
CDN
https://unpkg.com/podtable@<VERSION>/dist/podtable.css
https://unpkg.com/podtable@<VERSION>/dist/podtable.js
Usage
Include podtable script
<script src="path/to/podtable.js></script>
Include podtable styles
<link rel="stylesheet" type="text/css" href="path/to/podtable.css" />
Or import podtable using the ES6 syntax
import Podtable from "podtable";
@import "~podtable/dist/podtable.css";
Quick Note :
-
Podtable will use the last cell of every row including the head as control column.
-
Or you can define an empty cell for podtable to use as control column.
-
Its really important to include the podtable stylesheet because podtable relies on it.
-
Also podtable css doesn't include general table styling only css which it needs so you can style your table as you want.
-
Also never include more that one row in the able header currently this will prevent podtable from working properly
-
if you are using vuejs always provide a Unique key for your v-for because of vue's In-place-patch strategy.
Your HTML structure
<table id="table" class="table" width="100%">
<thead>
<tr>
<th>Firstname</th>
<th>Lastname</th>
...
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>Mark</td>
<td>Spencer</td>
...
<td></td>
</tr>
</tbody>
</table>
Then initialize podtable by passing the table selector
new Podtable("#table", {
// config options
});
Or passing the element directly
new Podtable(document.querySelector("#table"), {
// config options
});
The podtable instance receives two params the first parameter is an element selector or a table element and also the second parameter is a config object which receives a key value pairs in achieving a responsive table which can be use together or as your use case demands.
Config Options
KeepCell
priority
method
rowGroup
keepCell
which is an array of cells index that wont be hidden.
Also note the first cell for the table rows with an index of 0
will not be hidden by default.
new Podtable("#table", {
keepCell: [1, 6],
});
priority
This config option which is an array of index of cells, which determines how cells will be hidden and if only few cell index are passed to the priority config object this will take precedence over the other cell index.
new Podtable("#table", {
priority: [2, 4, 5],
});
method
This config option option which takes in a function to be executed for the hidden cells. and the function receives a parameter to acess the index of the cell that was last hidden.
new Podtable("#table", {
method: (state) => {
if (state.current == 5) {
// do something
}
},
});
rowGroup
This config option which takes in a boolean in order to use the row group feature, so for this to work
-
Data Iteration needs to be done via the body tag that is rows should be grouped together via the body tag
-
podtable assumes every first row of each body tag is the row group header hence there is need to let podtable know it should ignore it using a dataset
data-ptr-ignore
This attribute make podtable ignore the row entire from control and responsive action hence a colspan is important to avoid breaking the table behaviour -
Content in your ignored rows should be wrapable and should not have a fixed width
-
Your ignored row td cells should have colspan that will correspond to the number of cells in other rows.
-
Currently the dataset
data-ptr-ignore
is only meant for the body tag when you are using row group feature and also in the footer while you use it in the footer make sure you add apply your colspan.
new Podtable("#table", {
rowGroup: true,
});
<table id="table" class="table" width="100%">
<thead>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th></th>
</tr>
</thead>
<tbody>
<tr data-ptr-ignore="">
<td colspan="3"></td>
</tr>
<tr>
<td>Mark</td>
<td>Spencer</td>
<td></td>
</tr>
</tbody>
...
<!-- more body tags here grouping rows together -->
</table>
In fact for every row group you can define an extra row in order to show empty row group message.
<table id="table" class="table" width="100%">
<thead>
<tr>
<th>Firstname</th>
<th>Lastname</th>
...
<th></th>
</tr>
</thead>
<tbody>
<tr data-ptr-ignore="">
<td colspan="3">This is the Heading</td>
</tr>
<!-- other rows if there is data to show -->
<tr data-ptr-ignore="">
<td colspan="3">Sorry no record to show</td>
</tr>
</tbody>
</table>
Instance methods
destroy()
destroy()
The destroy method revert any alteration to the table in the DOM and detach all event listeners.
const podtable = new Podtable("#table", {
// config
});
podtable.destroy();
Contributing
Thank you for considering to contribute to Podtablejs, pull requests, is highly recommended not just bug reports & dont forget to star this repo.
Examples
you can view it live on codepen
Roadmap
- More awesomeness in achieving a responsive datatable. 😊
- Send in your feature requests if you have sth you want me to add.
License
Podtablejs is an open-sourced software licensed under the MIT license.