UNPKG

@tabler/core

Version:

Premium and Open Source dashboard template with responsive and high quality UI.

79 lines (56 loc) 2.24 kB
/** * Plugin: "remove_button" (Tom Select) * Copyright (c) contributors * * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this * file except in compliance with the License. You may obtain a copy of the License at: * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF * ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. * */ import type TomSelect from '../../tom-select.ts'; import { getDom } from '../../vanilla.ts'; import { escape_html, preventDefault, addEvent } from '../../utils.ts'; import { TomOption, TomItem } from '../../types/index.ts'; import { RBOptions } from './types.ts'; export default function(this:TomSelect, userOptions:RBOptions) { const options = Object.assign({ label : '&times;', title : 'Remove', className : 'remove', append : true }, userOptions); //options.className = 'remove-single'; var self = this; // override the render method to add remove button to each item if( !options.append ){ return; } var html = '<a href="javascript:void(0)" class="' + options.className + '" tabindex="-1" title="' + escape_html(options.title) + '">' + options.label + '</a>'; self.hook('after','setupTemplates',() => { var orig_render_item = self.settings.render.item; self.settings.render.item = (data:TomOption, escape:typeof escape_html) => { var item = getDom(orig_render_item.call(self, data, escape)) as TomItem; var close_button = getDom(html); item.appendChild(close_button); addEvent(close_button,'mousedown',(evt) => { preventDefault(evt,true); }); addEvent(close_button,'click',(evt) => { if( self.isLocked ) return; // propagating will trigger the dropdown to show for single mode preventDefault(evt,true); if( self.isLocked ) return; if( !self.shouldDelete([item],evt as MouseEvent) ) return; self.removeItem(item); self.refreshOptions(false); self.inputState(); }); return item; }; }); };