zhaojs
2023-05-16 ea24ddd0b978cbd3b0a900711b49b8a9c2db4186
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
/**
 * @author: Dennis Hernández
 * @webSite: http://djhvscf.github.io/Blog
 * @version: v1.0.0
 */
 
!function ($) {
 
    'use strict';
 
    document.onselectstart = function() {
        return false;
    };
 
    var getTableObjectFromCurrentTarget = function (currentTarget) {
        currentTarget = $(currentTarget);
        return currentTarget.is("table") ? currentTarget : currentTarget.parents().find(".table");
    };
 
    var getRow = function (target) {
        target = $(target);
        return target.parent().parent();
    };
 
    var onRowClick = function (e) {
        var that = getTableObjectFromCurrentTarget(e.currentTarget);
 
        if (window.event.ctrlKey) {
            toggleRow(e.currentTarget, that, false, false);
        }
 
        if (window.event.button === 0) {
            if (!window.event.ctrlKey && !window.event.shiftKey) {
                clearAll(that);
                toggleRow(e.currentTarget, that, false, false);
            }
 
            if (window.event.shiftKey) {
                selectRowsBetweenIndexes([that.bootstrapTable("getOptions").multipleSelectRowLastSelectedRow.rowIndex, e.currentTarget.rowIndex], that)
            }
        }
    };
 
    var onCheckboxChange = function (e) {
        var that = getTableObjectFromCurrentTarget(e.currentTarget);
        clearAll(that);
        toggleRow(getRow(e.currentTarget), that, false, false);
    };
 
    var toggleRow = function (row, that, clearAll, useShift) {
        if (clearAll) {
            row = $(row);
            that.bootstrapTable("getOptions").multipleSelectRowLastSelectedRow = undefined;
            row.removeClass(that.bootstrapTable("getOptions").multipleSelectRowCssClass);
            that.bootstrapTable("uncheck", row.data("index"));    
        } else {
            that.bootstrapTable("getOptions").multipleSelectRowLastSelectedRow = row;
            row = $(row);
            if (useShift) {
                row.addClass(that.bootstrapTable("getOptions").multipleSelectRowCssClass);
                that.bootstrapTable("check", row.data("index"));  
            } else {
                if(row.hasClass(that.bootstrapTable("getOptions").multipleSelectRowCssClass)) {
                    row.removeClass(that.bootstrapTable("getOptions").multipleSelectRowCssClass)
                    that.bootstrapTable("uncheck", row.data("index"));  
                } else {
                    row.addClass(that.bootstrapTable("getOptions").multipleSelectRowCssClass);
                    that.bootstrapTable("check", row.data("index"));  
                }
            }
        }
    };
 
    var selectRowsBetweenIndexes = function (indexes, that) {
        indexes.sort(function(a, b) {
            return a - b;
        });
 
        for (var i = indexes[0]; i <= indexes[1]; i++) {
            toggleRow(that.bootstrapTable("getOptions").multipleSelectRowRows[i-1], that, false, true);
        }
    };
 
    var clearAll = function (that) {
        for (var i = 0; i < that.bootstrapTable("getOptions").multipleSelectRowRows.length; i++) {
            toggleRow(that.bootstrapTable("getOptions").multipleSelectRowRows[i], that, true, false);
        }
    };
    
    $.extend($.fn.bootstrapTable.defaults, {
        multipleSelectRow: false,
        multipleSelectRowCssClass: 'multiple-select-row-selected',
        //internal variables used by the extension
        multipleSelectRowLastSelectedRow: undefined,
        multipleSelectRowRows: []
    });
 
    var BootstrapTable = $.fn.bootstrapTable.Constructor,
        _init = BootstrapTable.prototype.init,
        _initBody = BootstrapTable.prototype.initBody;
 
    BootstrapTable.prototype.init = function () {
        if (this.options.multipleSelectRow) {
            var that = this;
 
            //Make sure that the internal variables have the correct value
            this.options.multipleSelectRowLastSelectedRow = undefined;
            this.options.multipleSelectRowRows = [];
            
            this.$el.on("post-body.bs.table", function (e) {
                setTimeout(function () {
                    that.options.multipleSelectRowRows = that.$body.children();
                    that.options.multipleSelectRowRows.click(onRowClick);
                    that.options.multipleSelectRowRows.find("input[type=checkbox]").change(onCheckboxChange);
                }, 1);
            });
        }
 
        _init.apply(this, Array.prototype.slice.apply(arguments));
    };
 
    BootstrapTable.prototype.clearAllMultipleSelectionRow = function () {
        clearAll(this);
    };
 
    $.fn.bootstrapTable.methods.push('clearAllMultipleSelectionRow');
}(jQuery);