1 |
|
2 |
|
3 |
|
4 |
|
5 |
|
6 | import { isArray, isNumber } from 'tinper-sparrow/src/util';
|
7 | import { utilFunObj } from './util';
|
8 |
|
9 |
|
10 |
|
11 |
|
12 |
|
13 |
|
14 |
|
15 | var setAllRowsSelect = function setAllRowsSelect() {
|
16 | var indices = new Array(this.rows().length);
|
17 | for (var i = 0; i < indices.length; i++) {
|
18 | indices[i] = i;
|
19 | }
|
20 | this.setRowsSelect(indices);
|
21 | this.allSelected(true);
|
22 | this.trigger(DataTable.ON_ROW_ALLSELECT, {});
|
23 | };
|
24 |
|
25 |
|
26 |
|
27 |
|
28 |
|
29 |
|
30 |
|
31 |
|
32 | var setRowSelect = function setRowSelect(index) {
|
33 | if (index instanceof Row) {
|
34 | index = this.getIndexByRowId(index.rowId);
|
35 | }
|
36 | this.setRowsSelect([index]);
|
37 | this.setRowFocus(this.getSelectedIndex());
|
38 | };
|
39 |
|
40 |
|
41 |
|
42 |
|
43 |
|
44 |
|
45 |
|
46 |
|
47 | var setRowsSelect = function setRowsSelect(indices) {
|
48 | indices = indices || -1;
|
49 | if (indices == -1) {
|
50 | this.setAllRowsUnSelect({
|
51 | quiet: true
|
52 | });
|
53 | return;
|
54 | }
|
55 | indices = utilFunObj._formatToIndicesArray(this, indices);
|
56 | var sIns = this.selectedIndices();
|
57 | if (isArray(indices) && isArray(sIns) && indices.join() == sIns.join()) {
|
58 |
|
59 | return;
|
60 | }
|
61 |
|
62 | if (isArray(indices)) {
|
63 | var rowNum = this.rows().length;
|
64 | for (var i = 0; i < indices.length; i++) {
|
65 | if (indices[i] < 0 || indices[i] >= rowNum) indices.splice(i, 1);
|
66 | }
|
67 | }
|
68 |
|
69 | this.setAllRowsUnSelect({
|
70 | quiet: true
|
71 | });
|
72 | try {
|
73 | this.selectedIndices(indices);
|
74 | } catch (e) {}
|
75 | this.updatePageSelect();
|
76 | var rowIds = this.getRowIdsByIndices(indices);
|
77 | this.currentRowChange(-this.currentRowChange());
|
78 | this.trigger(DataTable.ON_ROW_SELECT, {
|
79 | indices: indices,
|
80 | rowIds: rowIds
|
81 | });
|
82 | this.updateCurrIndex();
|
83 | };
|
84 |
|
85 |
|
86 |
|
87 |
|
88 |
|
89 |
|
90 |
|
91 |
|
92 | var addRowSelect = function addRowSelect(index) {
|
93 | if (index instanceof Row) {
|
94 | index = this.getIndexByRowId(index.rowId);
|
95 | }
|
96 | this.addRowsSelect([index]);
|
97 | };
|
98 |
|
99 |
|
100 |
|
101 |
|
102 |
|
103 |
|
104 |
|
105 |
|
106 | var addRowsSelect = function addRowsSelect(indices) {
|
107 | indices = utilFunObj._formatToIndicesArray(this, indices);
|
108 | var selectedIndices = this.selectedIndices().slice();
|
109 | var needTrigger = false;
|
110 | for (var i = 0; i < indices.length; i++) {
|
111 | var ind = indices[i],
|
112 | toAdd = true;
|
113 | for (var j = 0; j < selectedIndices.length; j++) {
|
114 | if (selectedIndices[j] == ind) {
|
115 | toAdd = false;
|
116 | }
|
117 | }
|
118 |
|
119 | if (toAdd && indices[i] > -1) {
|
120 | needTrigger = true;
|
121 | selectedIndices.push(indices[i]);
|
122 | }
|
123 | }
|
124 | this.selectedIndices(selectedIndices);
|
125 | this.updatePageSelect();
|
126 | var rowIds = this.getRowIdsByIndices(selectedIndices);
|
127 | if (needTrigger) {
|
128 | this.trigger(DataTable.ON_ROW_SELECT, {
|
129 | indices: selectedIndices,
|
130 | rowIds: rowIds
|
131 | });
|
132 | }
|
133 | this.updateCurrIndex();
|
134 | };
|
135 |
|
136 |
|
137 |
|
138 |
|
139 |
|
140 |
|
141 |
|
142 |
|
143 |
|
144 |
|
145 | var setAllRowsUnSelect = function setAllRowsUnSelect(options) {
|
146 | this.selectedIndices([]);
|
147 | this.updatePageSelect();
|
148 | if (!(options && options.quiet)) {
|
149 | this.trigger(DataTable.ON_ROW_ALLUNSELECT);
|
150 | }
|
151 | this.updateCurrIndex();
|
152 | this.allSelected(false);
|
153 | };
|
154 |
|
155 |
|
156 |
|
157 |
|
158 |
|
159 |
|
160 |
|
161 |
|
162 | var setRowUnSelect = function setRowUnSelect(index) {
|
163 | if (index instanceof Row) {
|
164 | index = this.getIndexByRowId(index.rowId);
|
165 | }
|
166 | this.setRowsUnSelect([index]);
|
167 | };
|
168 |
|
169 |
|
170 |
|
171 |
|
172 |
|
173 |
|
174 |
|
175 |
|
176 | var setRowsUnSelect = function setRowsUnSelect(indices) {
|
177 | indices = utilFunObj._formatToIndicesArray(this, indices);
|
178 | var selectedIndices = this.selectedIndices().slice();
|
179 |
|
180 |
|
181 | if (selectedIndices.indexOf(indices[0]) == -1) return;
|
182 |
|
183 | for (var i = 0; i < indices.length; i++) {
|
184 | var index = indices[i];
|
185 | var pos = selectedIndices.indexOf(index);
|
186 | if (pos != -1) selectedIndices.splice(pos, 1);
|
187 | }
|
188 | this.selectedIndices(selectedIndices);
|
189 | this.updatePageSelect();
|
190 | var rowIds = this.getRowIdsByIndices(indices);
|
191 | this.trigger(DataTable.ON_ROW_UNSELECT, {
|
192 | indices: indices,
|
193 | rowIds: rowIds
|
194 | });
|
195 | this.updateCurrIndex();
|
196 | this.allSelected(false);
|
197 | };
|
198 |
|
199 |
|
200 |
|
201 |
|
202 |
|
203 | var toggleAllSelect = function toggleAllSelect() {
|
204 | if (this.allSelected()) {
|
205 | this.setAllRowsUnSelect();
|
206 | } else {
|
207 | this.setAllRowsSelect();
|
208 | }
|
209 | };
|
210 |
|
211 |
|
212 |
|
213 |
|
214 |
|
215 |
|
216 |
|
217 |
|
218 | var updateSelectedIndices = function updateSelectedIndices(index, type, num) {
|
219 | if (!isNumber(num)) {
|
220 | num = 1;
|
221 | }
|
222 | var selectedIndices = this.selectedIndices().slice();
|
223 | if (selectedIndices == null || selectedIndices.length == 0) return;
|
224 | for (var i = 0, count = selectedIndices.length; i < count; i++) {
|
225 | if (type == '+') {
|
226 | if (selectedIndices[i] >= index) selectedIndices[i] = parseInt(selectedIndices[i]) + num;
|
227 | } else if (type == '-') {
|
228 | if (selectedIndices[i] >= index && selectedIndices[i] <= index + num - 1) {
|
229 | selectedIndices.splice(i, 1);
|
230 | } else if (selectedIndices[i] > index + num - 1) selectedIndices[i] = selectedIndices[i] - num;
|
231 | }
|
232 | }
|
233 | this.selectedIndices(selectedIndices);
|
234 | this.updatePageSelect();
|
235 | };
|
236 | export var rowSelectFunObj = {
|
237 | setAllRowsSelect: setAllRowsSelect,
|
238 | setRowSelect: setRowSelect,
|
239 | setRowsSelect: setRowsSelect,
|
240 | addRowSelect: addRowSelect,
|
241 | addRowsSelect: addRowsSelect,
|
242 | setAllRowsUnSelect: setAllRowsUnSelect,
|
243 | setRowUnSelect: setRowUnSelect,
|
244 | setRowsUnSelect: setRowsUnSelect,
|
245 | toggleAllSelect: toggleAllSelect,
|
246 | updateSelectedIndices: updateSelectedIndices
|
247 | }; |
\ | No newline at end of file |