/*! Bulma integration for DataTables' Buttons * ©2021 SpryMedia Ltd - datatables.net/license */ (function( factory ){ if ( typeof define === 'function' && define.amd ) { // AMD define( ['jquery', 'datatables.net-bm', 'datatables.net-buttons'], function ( $ ) { return factory( $, window, document ); } ); } else if ( typeof exports === 'object' ) { // CommonJS module.exports = function (root, $) { if ( ! root ) { root = window; } if ( ! $ || ! $.fn.dataTable ) { $ = require('datatables.net-bm')(root, $).$; } if ( ! $.fn.dataTable.Buttons ) { require('datatables.net-buttons')(root, $); } return factory( $, root, root.document ); }; } else { // Browser factory( jQuery, window, document ); } }(function( $, window, document, undefined ) { 'use strict'; var DataTable = $.fn.dataTable; $.extend( true, DataTable.Buttons.defaults, { dom: { container: { className: 'dt-buttons field is-grouped' }, button: { className: 'button is-light', active: 'is-active', disabled: 'is-disabled' }, collection: { tag: 'div', closeButton: false, className: 'dropdown-content', button: { tag: 'a', className: 'dt-button dropdown-item', active: 'is-active', disabled: 'is-disabled' } }, splitWrapper: { tag: 'div', className: 'dt-btn-split-wrapper dropdown-trigger buttons has-addons', closeButton: false }, splitDropdownButton: { tag: 'button', className: 'dt-btn-split-drop-button button is-light', closeButton: false }, splitDropdown: { tag: 'button', text: '▼', className: 'button is-light', closeButton: false, align: 'split-left', splitAlignClass: 'dt-button-split-left' } }, buttonCreated: function ( config, button ) { // For collections if (config.buttons) { // Wrap the dropdown content in a menu element config._collection = $('<div class="dropdown-menu"/>') .append(config._collection); // And add the collection dropdown icon $(button).append( '<span class="icon is-small">' + '<i class="fa fa-angle-down" aria-hidden="true"></i>' + '</span>' ); } return button; } } ); return DataTable.Buttons; }));