forked from cloudflarearchive/backgrid-select2-cell
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbackgrid-select2-cell.min.js
60 lines (52 loc) · 2.59 KB
/
backgrid-select2-cell.min.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/*
backgrid-select2-cell
http://github.com/wyuenho/backgrid
Copyright (c) 2013 Jimmy Yuen Ho Wong and contributors
Licensed under the MIT @license.
*/
!function(a,b){"function"==typeof define&&define.amd?
// AMD
define(["underscore","backgrid"],b):"object"==typeof exports?(
// CommonJS
require("select2"),module.exports=b(a,require("underscore"),require("backgrid"))):
// Browser globals
b(a,a._,a.Backgrid)}(this,function(a,b,c){"use strict";/**
Select2CellEditor is a cell editor that renders a `select2` select box
instead of the default `<select>` HTML element.
See:
- [Select2](http://ivaynberg.github.com/select2/)
@class Backgrid.Extension.Select2CellEditor
@extends Backgrid.SelectCellEditor
*/
var d=c.Extension.Select2CellEditor=c.SelectCellEditor.extend({/** @property */
events:{change:"save"},/** @property */
select2Options:{openOnEnter:!1},initialize:function(){c.SelectCellEditor.prototype.initialize.apply(this,arguments),this.close=b.bind(this.close,this)},/**
Sets the options for `select2`. Called by the parent Select2Cell during
edit mode.
*/
setSelect2Options:function(a){this.select2Options=b.extend(a||{})},/**
Renders a `select2` select box instead of the default `<select>` HTML
element using the supplied options from #select2Options.
@chainable
*/
render:function(){return c.SelectCellEditor.prototype.render.apply(this,arguments),this.$el.select2(this.select2Options),this},/**
Attach event handlers to the select2 box and focus it.
*/
postRender:function(){var a=this;a.$el.on("blur",function(b){a.close(b)}).select2("focus")},remove:function(){return this.$el.select2("destroy"),c.SelectCellEditor.prototype.remove.apply(this,arguments)}});/**
Select2Cell is a cell class that renders a `select2` select box during edit
mode.
@class Backgrid.Extension.Select2Cell
@extends Backgrid.SelectCell
*/
c.Extension.Select2Cell=c.SelectCell.extend({/** @property */
className:"select2-cell",/** @property */
editor:d,/** @property */
select2Options:null,/**
Initializer.
@param {Object} options
@param {Backbone.Model} options.model
@param {Backgrid.Column} options.column
@param {Object} [options.select2Options]
@throws {TypeError} If `optionsValues` is undefined.
*/
initialize:function(a){c.SelectCell.prototype.initialize.apply(this,arguments),this.select2Options=a.select2Options||this.select2Options,this.listenTo(this.model,"backgrid:edit",function(a,b,c,d){b.get("name")==this.column.get("name")&&d.setSelect2Options(this.select2Options)})}})});