Subversion Repositories Integrator Subversion

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 espaco 1
var TableEditable = function () {
2
 
3
    var handleTable = function () {
4
 
5
        function restoreRow(oTable, nRow) {
6
            var aData = oTable.fnGetData(nRow);
7
            var jqTds = $('>td', nRow);
8
 
9
            for (var i = 0, iLen = jqTds.length; i < iLen; i++) {
10
                oTable.fnUpdate(aData[i], nRow, i, false);
11
            }
12
 
13
            oTable.fnDraw();
14
        }
15
 
16
        function editRow(oTable, nRow) {
17
            var aData = oTable.fnGetData(nRow);
18
            var jqTds = $('>td', nRow);
19
            jqTds[0].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[0] + '">';
20
            jqTds[1].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[1] + '">';
21
            jqTds[2].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[2] + '">';
22
            jqTds[3].innerHTML = '<input type="text" class="form-control input-small" value="' + aData[3] + '">';
23
            jqTds[4].innerHTML = '<a class="edit" href="">Save</a>';
24
            jqTds[5].innerHTML = '<a class="cancel" href="">Cancel</a>';
25
        }
26
 
27
        function saveRow(oTable, nRow) {
28
            var jqInputs = $('input', nRow);
29
            oTable.fnUpdate(jqInputs[0].value, nRow, 0, false);
30
            oTable.fnUpdate(jqInputs[1].value, nRow, 1, false);
31
            oTable.fnUpdate(jqInputs[2].value, nRow, 2, false);
32
            oTable.fnUpdate(jqInputs[3].value, nRow, 3, false);
33
            oTable.fnUpdate('<a class="edit" href="">Edit</a>', nRow, 4, false);
34
            oTable.fnUpdate('<a class="delete" href="">Delete</a>', nRow, 5, false);
35
            oTable.fnDraw();
36
        }
37
 
38
        function cancelEditRow(oTable, nRow) {
39
            var jqInputs = $('input', nRow);
40
            oTable.fnUpdate(jqInputs[0].value, nRow, 0, false);
41
            oTable.fnUpdate(jqInputs[1].value, nRow, 1, false);
42
            oTable.fnUpdate(jqInputs[2].value, nRow, 2, false);
43
            oTable.fnUpdate(jqInputs[3].value, nRow, 3, false);
44
            oTable.fnUpdate('<a class="edit" href="">Edit</a>', nRow, 4, false);
45
            oTable.fnDraw();
46
        }
47
 
48
        var table = $('#sample_editable_1');
49
 
50
        var oTable = table.dataTable({
51
 
52
            // Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
53
            // setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js). 
54
            // So when dropdowns used the scrollable div should be removed. 
55
            //"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
56
 
57
            "lengthMenu": [
58
                [5, 15, 20, -1],
59
                [5, 15, 20, "All"] // change per page values here
60
            ],
61
 
62
            // Or you can use remote translation file
63
            //"language": {
64
            //   url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
65
            //},
66
 
67
            // set the initial value
68
            "pageLength": 10,
69
 
70
            "language": {
71
                "lengthMenu": " _MENU_ records"
72
            },
73
            "columnDefs": [{ // set default column settings
74
                'orderable': true,
75
                'targets': [0]
76
            }, {
77
                "searchable": true,
78
                "targets": [0]
79
            }],
80
            "order": [
81
                [0, "asc"]
82
            ] // set first column as a default sort by asc
83
        });
84
 
85
        var tableWrapper = $("#sample_editable_1_wrapper");
86
 
87
        tableWrapper.find(".dataTables_length select").select2({
88
            showSearchInput: false //hide search box with special css class
89
        }); // initialize select2 dropdown
90
 
91
        var nEditing = null;
92
        var nNew = false;
93
 
94
        $('#sample_editable_1_new').click(function (e) {
95
            e.preventDefault();
96
 
97
            if (nNew && nEditing) {
98
                if (confirm("Previose row not saved. Do you want to save it ?")) {
99
                    saveRow(oTable, nEditing); // save
100
                    $(nEditing).find("td:first").html("Untitled");
101
                    nEditing = null;
102
                    nNew = false;
103
 
104
                } else {
105
                    oTable.fnDeleteRow(nEditing); // cancel
106
                    nEditing = null;
107
                    nNew = false;
108
 
109
                    return;
110
                }
111
            }
112
 
113
            var aiNew = oTable.fnAddData(['', '', '', '', '', '']);
114
            var nRow = oTable.fnGetNodes(aiNew[0]);
115
            editRow(oTable, nRow);
116
            nEditing = nRow;
117
            nNew = true;
118
        });
119
 
120
        table.on('click', '.delete', function (e) {
121
            e.preventDefault();
122
 
123
            if (confirm("Are you sure to delete this row ?") == false) {
124
                return;
125
            }
126
 
127
            var nRow = $(this).parents('tr')[0];
128
            oTable.fnDeleteRow(nRow);
129
            alert("Deleted! Do not forget to do some ajax to sync with backend :)");
130
        });
131
 
132
        table.on('click', '.cancel', function (e) {
133
            e.preventDefault();
134
            if (nNew) {
135
                oTable.fnDeleteRow(nEditing);
136
                nEditing = null;
137
                nNew = false;
138
            } else {
139
                restoreRow(oTable, nEditing);
140
                nEditing = null;
141
            }
142
        });
143
 
144
        table.on('click', '.edit', function (e) {
145
            e.preventDefault();
146
 
147
            /* Get the row as a parent of the link that was clicked on */
148
            var nRow = $(this).parents('tr')[0];
149
 
150
            if (nEditing !== null && nEditing != nRow) {
151
                /* Currently editing - but not this row - restore the old before continuing to edit mode */
152
                restoreRow(oTable, nEditing);
153
                editRow(oTable, nRow);
154
                nEditing = nRow;
155
            } else if (nEditing == nRow && this.innerHTML == "Save") {
156
                /* Editing this row and want to save it */
157
                saveRow(oTable, nEditing);
158
                nEditing = null;
159
                alert("Updated! Do not forget to do some ajax to sync with backend :)");
160
            } else {
161
                /* No edit in progress - let's start one */
162
                editRow(oTable, nRow);
163
                nEditing = nRow;
164
            }
165
        });
166
    }
167
 
168
    return {
169
 
170
        //main function to initiate the module
171
        init: function () {
172
            handleTable();
173
        }
174
 
175
    };
176
 
177
}();