-
Notifications
You must be signed in to change notification settings - Fork 1
/
Grid.js
242 lines (219 loc) · 6.49 KB
/
Grid.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
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
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
define([
"dojo/_base/declare",
"dojo/_base/lang",
"dojo/_base/sniff",
"dojo/on",
"dojo/i18n",
"dojo/dom-class",
"dojo/dom-geometry",
"dojo/query",
"dojox/html/metrics",
"dijit/_WidgetBase",
"dijit/_FocusMixin",
"dijit/_TemplatedMixin",
"dojo/text!./templates/Grid.html",
"./core/Core",
"./core/model/extensions/Query",
"./core/_Module",
"./modules/Header",
"./modules/View",
"./modules/Body",
"./modules/VLayout",
"./modules/HLayout",
"./modules/VScroller",
"./modules/HScroller",
"./modules/ColumnWidth",
"./modules/Focus",
"dijit/_BidiSupport",
"dojo/i18n!./nls/gridx",
"dojo/NodeList-dom",
"dojo/NodeList-traverse"
], function(declare, lang, has, on, i18n, domClass, domGeometry, query, metrics,
_WidgetBase, _FocusMixin, _TemplatedMixin, template,
Core, Query, _Module, Header, View, Body, VLayout, HLayout, VScroller, HScroller, ColumnWidth, Focus, _BidiSupport){
var dummyFunc = function(){};
return declare('gridx.Grid', [_WidgetBase, _TemplatedMixin, _FocusMixin, Core], {
// summary:
// Gridx is a highly extensible widget providing grid/table functionalities.
// description:
// Gridx is much smaller, faster, more reasonable designed, more powerful and more flexible
// compared to the old dojo DataGrid/EnhancedGrid.
templateString: template,
//textDir bidi support begin
_setTextDirAttr: function(textDir){
// summary:
// Seamlessly changes grid 'textDir' property on the fly.
// textDir:
// Grid text direction
if(this.textDir != textDir){
this.textDir = textDir;
this.header.refresh();
if(this.edit){
this.edit._initAlwaysEdit();
}
this.body.refresh();
}
},
getTextDir: function(colId, text){
var col = this._columnsById[colId],
textDir = (col && col.textDir) || this.textDir;
return textDir = (textDir === "auto") ? _BidiSupport.prototype._checkContextual(text) : textDir;
},
getTextDirStyle: function(colId, text){
var textDir = this.getTextDir(colId, text);
return textDir ? " direction:" + textDir + ";" : "";
},
enforceTextDirWithUcc: function(colId, text){
var textDir = this.getTextDir(colId, text);
//var LRE = '\u202A', RLE = '\u202B', PDF = '\u202C';
return textDir ? (textDir === "rtl" ? '\u202B' : '\u202A') + text + '\u202C' : text;
},
//textDir bidi support end
coreModules: [
//Put default modules here!
Header,
View,
Body,
VLayout,
HLayout,
VScroller,
HScroller,
ColumnWidth,
Focus
],
coreExtensions: [
//Put default extensions here!
Query
],
postCreate: function(){
// summary:
// Override to initialize grid modules
// tags:
// protected extension
var t = this;
t.inherited(arguments);
if(t.touch === undefined){
t.touch = has('ios') || has('android');
}
if(t.touch){
domClass.add(t.domNode, 'gridxTouch');
}else{
domClass.add(t.domNode, 'gridxDesktop');
}
if(!t.isLeftToRight()){
domClass.add(t.domNode, 'gridxRtl');
}
t.nls = i18n.getLocalization('gridx', 'gridx', t.lang);
t._eventFlags = {};
t.modules = t.coreModules.concat(t.modules || []);
t.modelExtensions = t.coreExtensions.concat(t.modelExtensions || []);
t.lastFocusNode.setAttribute('tabIndex', t.domNode.getAttribute('tabIndex'));
t._initEvents(t._compNames, t._eventNames);
t._init();
//resize the grid when zoomed in/out.
t.connect(metrics, 'onFontResize', function(){
t.resize();
});
},
startup: function(){
// summary:
// Startup this grid widget
// tags:
// public extension
if(!this._started){
this.inherited(arguments);
this._deferStartup.callback();
}
},
destroy: function(){
// summary:
// Destroy this grid widget
// tags:
// public extension
this._uninit();
this.inherited(arguments);
},
/*=====
// autoHeight: Boolean
// If true, the grid's height is determined by the total height of the rows in current body view,
// so that there will never be vertical scroller bar. And when scrolling the mouse wheel over grid body,
// the whole page will be scrolled. Note if this is false, only the grid body will be scrolled.
autoHeight: false,
// autoWidth: Boolean
// If true, the grid's width is determined by the total width of the columns, so that there will
// never be horizontal scroller bar.
autoWidth: false,
// touch: Boolean
// Whether grid is run in touch environment
// If undefined, automatically set to true on mobile devices (like ios or android)
//touch: undefined,
=====*/
resize: function(changeSize){
// summary:
// Resize the grid using given width and height.
// tags:
// public
// changeSize: Object?
// An object like {w: ..., h: ...}.
// If omitted, the grid will re-layout itself in current width/height.
var t = this, ds = {};
if(changeSize){
if(t.autoWidth){
changeSize.w = undefined;
}
if(t.autoHeight){
changeSize.h = undefined;
}
domGeometry.setMarginBox(t.domNode, changeSize);
}
t._onResizeBegin(changeSize, ds);
t._onResizeEnd(changeSize, ds);
},
//Private-------------------------------------------------------------------------------
_onResizeBegin: function(){},
_onResizeEnd: function(){},
_escapeId: function(id){
return String(id).replace(/\\/g, "\\\\");
},
//event handling begin
_compNames: ['Cell', 'HeaderCell', 'Row', 'Header'],
_eventNames: [
'TouchStart', 'TouchEnd',
'Click', 'DblClick',
'MouseDown', 'MouseUp',
'MouseOver', 'MouseOut',
'MouseMove', 'ContextMenu',
'KeyDown', 'KeyPress', 'KeyUp'
],
_initEvents: function(objNames, evtNames){
var i = 0, j, comp, evt, evtName;
while(comp = objNames[i++]){
for(j = 0; evt = evtNames[j++];){
evtName = 'on' + comp + evt;
this[evtName] = this[evtName] || dummyFunc;
}
}
},
_connectEvents: function(node, connector, scope){
for(var t = this,
m = t.model,
eventName,
eventNames = t._eventNames,
len = eventNames.length,
i = 0; i < len; ++i){
eventName = eventNames[i];
m._cnnts.push(on(node, eventName.toLowerCase(), lang.hitch(scope, connector, eventName)));
}
},
_isConnected: function(eventName){
return this[eventName] !== dummyFunc;
},
//event handling end
_isCtrlKey: function(evt){
// summary:
// On Mac Ctrl+click also opens a context menu. So call this to check ctrlKey instead of directly call evt.ctrlKey
// if you need to implement some handler for Ctrl+click.
return has('mac') ? evt.metaKey : evt.ctrlKey;
}
});
});