|
1 |
| -import DataTable from 'ember-data-table/components/data-table'; |
| 1 | +/* eslint-disable ember/no-classic-classes, ember/no-classic-components, ember/no-observers, ember/require-tagless-components */ |
| 2 | +import { typeOf } from '@ember/utils'; |
| 3 | +import { computed, observer } from '@ember/object'; |
| 4 | +import { bool, equal, oneWay } from '@ember/object/computed'; |
| 5 | +import Component from '@ember/component'; |
| 6 | + |
| 7 | +// Source: https://github.com/mu-semtech/ember-data-table/blob/c690a3948b2d9d5f91d69f0a935c6b5cdb4862ca/addon/components/data-table.js |
| 8 | +const DataTable = Component.extend({ |
| 9 | + init() { |
| 10 | + this._super(...arguments); |
| 11 | + if (this.selection === undefined) this.set('selection', []); |
| 12 | + }, |
| 13 | + noDataMessage: 'No data', |
| 14 | + isLoading: false, |
| 15 | + lineNumbers: false, |
| 16 | + searchDebounceTime: 2000, |
| 17 | + enableLineNumbers: bool('lineNumbers'), |
| 18 | + enableSelection: oneWay('hasMenu'), |
| 19 | + selectionIsEmpty: equal('selection.length', 0), |
| 20 | + enableSizes: true, |
| 21 | + size: 5, |
| 22 | + sizeOptions: computed('size', 'sizes', 'enableSizes', function () { |
| 23 | + if (!this.enableSizes) { |
| 24 | + return null; |
| 25 | + } else { |
| 26 | + const sizeOptions = this.sizes || [5, 10, 25, 50, 100]; |
| 27 | + if (!sizeOptions.includes(this.size)) { |
| 28 | + sizeOptions.push(this.size); |
| 29 | + } |
| 30 | + sizeOptions.sort((a, b) => a - b); |
| 31 | + return sizeOptions; |
| 32 | + } |
| 33 | + }), |
| 34 | + hasMenu: false, // set from inner component, migth fail with nested if |
| 35 | + enableSearch: computed('filter', function () { |
| 36 | + return this.filter || this.filter === ''; |
| 37 | + }), |
| 38 | + autoSearch: true, |
| 39 | + filterChanged: observer('filter', function () { |
| 40 | + this.set('page', 0); |
| 41 | + }), |
| 42 | + sizeChanged: observer('size', function () { |
| 43 | + this.set('page', 0); |
| 44 | + }), |
| 45 | + parsedFields: computed('fields', function () { |
| 46 | + const fields = this.fields; |
| 47 | + if (typeOf(fields) === 'string') { |
| 48 | + return fields.split(' '); |
| 49 | + } else { |
| 50 | + return fields || []; |
| 51 | + } |
| 52 | + }), |
| 53 | + addItemToSelection(item) { |
| 54 | + this.selection.addObject(item); |
| 55 | + }, |
| 56 | + removeItemFromSelection(item) { |
| 57 | + this.selection.removeObject(item); |
| 58 | + }, |
| 59 | + clearSelection() { |
| 60 | + this.selection.clear(); |
| 61 | + }, |
| 62 | +}); |
2 | 63 |
|
3 | 64 | export default DataTable.extend({
|
4 | 65 | tagName: '',
|
|
0 commit comments