Skip to content

Commit

Permalink
Merge branch 'main' into main_editable_events
Browse files Browse the repository at this point in the history
  • Loading branch information
johanneswilm authored Aug 21, 2024
2 parents 9fcb069 + ec0f752 commit f25c70b
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 9 deletions.
37 changes: 37 additions & 0 deletions docs/documentation/Events.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,17 @@ dataTable.on('datatable.page', function(page) {
});
```

### `datatable.page:before`
Fires before page change.

A single argument is available which returns the page number:

```javascript
dataTable.on('datatable.page:before', function(page) {
//
});
```

### `datatable.perpage`
Fires when the perPage option is changed with the dropdown. A single argument returns the per-page value:

Expand All @@ -31,9 +42,21 @@ dataTable.on('datatable.perpage', function(perpage) {
});
```

### `datatable.perpage:before`
Fires before the perPage option is changed with the dropdown. A single argument returns the per-page value:

```javascript
dataTable.on('datatable.perpage:before', function(perpage) {
//
});
```

### `datatable.refresh`
Fires when the `.refresh()` method is called.

### `datatable.refresh:before`
Fires before the `.refresh()` method is called.

### `datatable.search`
Fires on keyup during a search.

Expand All @@ -45,6 +68,17 @@ dataTable.on('datatable.search', function(query, matched) {
});
```

### `datatable.search:before`
Fires on keyup before a search.

Two arguments are available: `query` which returns the query string entered and `matched` which returns an array of rows containing the matched string:

```javascript
dataTable.on('datatable.search:before', function(query, matched) {
//
});
```

### `datatable.selectrow`
Fires when user selects a row - either by mouse click on a row or using `Space`/`Enter` during keyboard based navigation (requires option [[rowNavigation]]).

Expand Down Expand Up @@ -73,6 +107,9 @@ dataTable.on('datatable.sort', function(column, direction) {
### `datatable.update`
Fires when the `.update()` method is called.

### `datatable.update:before`
Fires before the `.update()` method is called.

### `editable.init`
Fires when the editor is initialized.

Expand Down
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "simple-datatables",
"version": "9.0.3",
"version": "9.0.4",
"description": "A lightweight, dependency-free JavaScript HTML table plugin.",
"main": "dist/index.js",
"types": "dist/index.d.ts",
Expand Down
28 changes: 20 additions & 8 deletions src/datatable.ts
Original file line number Diff line number Diff line change
Expand Up @@ -499,6 +499,7 @@ export class DataTable {
if (selector && selector instanceof HTMLSelectElement) {
// Change per page
selector.addEventListener("change", () => {
this.emit("datatable.perpage:before", this.options.perPage)
this.options.perPage = parseInt(selector.value, 10)
this.update()

Expand Down Expand Up @@ -676,14 +677,16 @@ export class DataTable {
if (!this.options.destroyable) {
return
}
if (this.wrapperDOM.parentElement) {
// Restore the initial HTML
const oldDOM = createElement("div")
oldDOM.innerHTML = this._initialHTML
this.wrapperDOM.parentElement.replaceChild(oldDOM.firstElementChild, this.wrapperDOM)
} else {
// Remove the className
this.options.classes.table?.split(" ").forEach(className => this.wrapperDOM.classList.remove(className))
if (this.wrapperDOM) {
if (this.wrapperDOM.parentElement) {
// Restore the initial HTML
const oldDOM = createElement("div")
oldDOM.innerHTML = this._initialHTML
this.wrapperDOM.parentElement.replaceChild(oldDOM.firstElementChild, this.wrapperDOM)
} else {
// Remove the className
this.options.classes.table?.split(" ").forEach(className => this.wrapperDOM.classList.remove(className))
}
}

window.removeEventListener("resize", this._listeners.onResize)
Expand All @@ -696,6 +699,8 @@ export class DataTable {
* @return {Void}
*/
update(measureWidths = false) {
this.emit("datatable.update:before")

if (measureWidths) {
this.columns._measureWidths()
this.hasRows = Boolean(this.data.data.length)
Expand Down Expand Up @@ -776,6 +781,7 @@ export class DataTable {
* Perform a simple search of the data set
*/
search(term: string, columns: (number[] | undefined ) = undefined) {
this.emit("datatable.search:before", term, this._searchData)

if (!term.length) {
this._currentPage = 1
Expand Down Expand Up @@ -811,6 +817,8 @@ export class DataTable {
})).filter(query => query.terms.length
)

this.emit("datatable.multisearch:before", queries, this._searchData)

this._searchQueries = queries

if (!queries.length) {
Expand Down Expand Up @@ -889,6 +897,8 @@ export class DataTable {
* Change page
*/
page(page: number, lastRowCursor = false) {
this.emit("datatable.page:before", page)

// We don't want to load the current page again.
if (page === this._currentPage) {
return false
Expand Down Expand Up @@ -971,6 +981,8 @@ export class DataTable {
* Refresh the instance
*/
refresh() {
this.emit("datatable.refresh:before")

if (this.options.searchable) {
const inputSelector = classNamesToSelector(this.options.classes.input)
const inputs: HTMLInputElement[] = Array.from(this.wrapperDOM.querySelectorAll(inputSelector))
Expand Down

0 comments on commit f25c70b

Please sign in to comment.