/*! © SpryMedia Ltd - datatables.net/license */ import $ from 'jquery'; import DataTable from 'datatables.net'; /** * Sort data by a defined enumerated (enum) list. The options for the values in * the enum are defined by passing the values in an array to the method * `DataTable.enum`. Type detection and sorting plug-ins for DataTables will * automatically be generated and added to the table. * * For full details and instructions please see [this DataTables blog * post](//datatables.net/blog/2016-06-16). * * @name enum * @summary Dynamically create enum sorting options for a DataTable * @author [SpryMedia Ltd](http://datatables.net) * * @example * DataTable.enum( [ 'High', 'Medium', 'Low' ] ); * * new DataTable('#myTable'); */ var unique = 0; var types = DataTable.ext.type; // Using form DataTable.enum breaks at least YuiCompressor since enum is // a reserved word in JavaScript DataTable['enum'] = function (arr) { var name = 'enum-' + unique++; var lookup = window.Map ? new Map() : {}; for (var i = 0, ien = arr.length; i < ien; i++) { lookup[arr[i]] = i; } // Add type detection types.detect.unshift(function (d) { return lookup[d] !== undefined ? name : null; }); // Add sorting method types.order[name + '-pre'] = function (d) { return lookup[d]; }; }; export default DataTable;