neo.mjs 4.3.15 → 4.3.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json
CHANGED
package/src/component/Base.mjs
CHANGED
@@ -447,12 +447,16 @@ class Base extends CoreBase {
|
|
447
447
|
|
448
448
|
/**
|
449
449
|
* Registers the domListeners inside the Neo.manager.DomEvent
|
450
|
-
* @param {
|
451
|
-
* @param {
|
450
|
+
* @param {Object[]} value
|
451
|
+
* @param {Object[]} oldValue
|
452
452
|
* @protected
|
453
453
|
*/
|
454
454
|
afterSetDomListeners(value, oldValue) {
|
455
|
-
|
455
|
+
let me = this;
|
456
|
+
|
457
|
+
me.getController()?.parseDomListeners(me);
|
458
|
+
|
459
|
+
DomEventManager.updateDomListeners(me, value, oldValue);
|
456
460
|
}
|
457
461
|
|
458
462
|
/**
|
@@ -20,7 +20,7 @@ class Component extends Base {
|
|
20
20
|
*/
|
21
21
|
ntype: 'component-controller',
|
22
22
|
/**
|
23
|
-
* @member {
|
23
|
+
* @member {Neo.component.Base|null} component=null
|
24
24
|
* @protected
|
25
25
|
*/
|
26
26
|
component: null,
|
@@ -135,49 +135,13 @@ class Component extends Base {
|
|
135
135
|
onComponentConstructed() {}
|
136
136
|
|
137
137
|
/**
|
138
|
-
* @param {Neo.component.Base}
|
138
|
+
* @param {Neo.component.Base} component=this.component
|
139
139
|
*/
|
140
140
|
parseConfig(component=this.component) {
|
141
|
-
let me
|
142
|
-
|
143
|
-
|
144
|
-
|
145
|
-
eventHandler, fn, handlerScope, parentController;
|
146
|
-
|
147
|
-
if (domListeners) {
|
148
|
-
domListeners.forEach(domListener => {
|
149
|
-
Object.entries(domListener).forEach(([key, value]) => {
|
150
|
-
eventHandler = null;
|
151
|
-
|
152
|
-
if (key !== 'scope' && key !== 'delegate') {
|
153
|
-
if (Neo.isString(value)) {
|
154
|
-
eventHandler = value;
|
155
|
-
} else if (Neo.isObject(value) && value.hasOwnProperty('fn') && Neo.isString(value.fn)) {
|
156
|
-
eventHandler = value.fn;
|
157
|
-
}
|
158
|
-
|
159
|
-
if (eventHandler) {
|
160
|
-
handlerScope = me.getHandlerScope(eventHandler);
|
161
|
-
|
162
|
-
if (!handlerScope) {
|
163
|
-
Logger.logError('Unknown domEvent handler for', eventHandler, component);
|
164
|
-
} else {
|
165
|
-
fn = handlerScope[eventHandler].bind(handlerScope);
|
166
|
-
domListener[key] = fn;
|
167
|
-
|
168
|
-
DomEventManager.updateListenerPlaceholder({
|
169
|
-
componentId : component.id,
|
170
|
-
eventHandlerMethod: fn,
|
171
|
-
eventHandlerName : eventHandler,
|
172
|
-
eventName : key,
|
173
|
-
scope : parentController
|
174
|
-
});
|
175
|
-
}
|
176
|
-
}
|
177
|
-
}
|
178
|
-
});
|
179
|
-
});
|
180
|
-
}
|
141
|
+
let me = this,
|
142
|
+
listeners = component.listeners,
|
143
|
+
reference = component.reference,
|
144
|
+
eventHandler, handlerScope;
|
181
145
|
|
182
146
|
if (listeners) {
|
183
147
|
Object.entries(listeners).forEach(([key, value]) => {
|
@@ -215,6 +179,41 @@ class Component extends Base {
|
|
215
179
|
}
|
216
180
|
}
|
217
181
|
|
182
|
+
/**
|
183
|
+
* @param {Neo.component.Base} component=this.component
|
184
|
+
*/
|
185
|
+
parseDomListeners(component=this.component) {
|
186
|
+
let me = this,
|
187
|
+
domListeners = component.domListeners,
|
188
|
+
eventHandler, scope;
|
189
|
+
|
190
|
+
if (domListeners) {
|
191
|
+
domListeners.forEach(domListener => {
|
192
|
+
Object.entries(domListener).forEach(([key, value]) => {
|
193
|
+
eventHandler = null;
|
194
|
+
|
195
|
+
if (key !== 'scope' && key !== 'delegate') {
|
196
|
+
if (Neo.isString(value)) {
|
197
|
+
eventHandler = value;
|
198
|
+
} else if (Neo.isObject(value) && value.hasOwnProperty('fn') && Neo.isString(value.fn)) {
|
199
|
+
eventHandler = value.fn;
|
200
|
+
}
|
201
|
+
|
202
|
+
if (eventHandler) {
|
203
|
+
scope = me.getHandlerScope(eventHandler);
|
204
|
+
|
205
|
+
if (!scope) {
|
206
|
+
Logger.logError('Unknown domEvent handler for', eventHandler, component);
|
207
|
+
} else {
|
208
|
+
domListener[key] = scope[eventHandler].bind(scope);
|
209
|
+
}
|
210
|
+
}
|
211
|
+
}
|
212
|
+
});
|
213
|
+
});
|
214
|
+
}
|
215
|
+
}
|
216
|
+
|
218
217
|
/**
|
219
218
|
* Will get called by component.Base: destroy() in case the component has a reference config
|
220
219
|
* @param {Neo.component.Base} component
|
package/src/grid/Container.mjs
CHANGED
@@ -184,19 +184,26 @@ class Container extends BaseContainer {
|
|
184
184
|
createColumns(columns) {
|
185
185
|
let me = this,
|
186
186
|
columnDefaults = me.columnDefaults,
|
187
|
-
sorters = me.store?.sorters
|
187
|
+
sorters = me.store?.sorters,
|
188
|
+
renderer;
|
188
189
|
|
189
190
|
if (!columns || !columns.length) {
|
190
191
|
Neo.logError('Attempting to create a grid.Container without defined columns', me.id);
|
191
192
|
}
|
192
193
|
|
193
194
|
columns.forEach(column => {
|
195
|
+
renderer = column.renderer;
|
196
|
+
|
194
197
|
columnDefaults && Neo.assignDefaults(column, columnDefaults);
|
195
198
|
|
196
199
|
if (column.dock && !column.width) {
|
197
200
|
Neo.logError('Attempting to create a docked column without a defined width', column, me.id);
|
198
201
|
}
|
199
202
|
|
203
|
+
if (renderer && Neo.isString(renderer) && me[renderer]) {
|
204
|
+
column.renderer = me[renderer];
|
205
|
+
}
|
206
|
+
|
200
207
|
if (sorters?.[0]) {
|
201
208
|
if (column.field === sorters[0].property) {
|
202
209
|
column.isSorted = sorters[0].direction;
|
package/src/manager/DomEvent.mjs
CHANGED
@@ -405,34 +405,6 @@ class DomEvent extends Base {
|
|
405
405
|
}
|
406
406
|
}
|
407
407
|
|
408
|
-
/**
|
409
|
-
* Intended for Neo.controller.Component to replace listener placeholders provided as a string
|
410
|
-
* @param {Object} config
|
411
|
-
* @param {String} config.componentId
|
412
|
-
* @param {Function} config.eventHandlerMethod
|
413
|
-
* @param {String} config.eventHandlerName
|
414
|
-
* @param {String} config.eventName
|
415
|
-
* @param {Neo.core.Base} config.scope
|
416
|
-
*/
|
417
|
-
updateListenerPlaceholder(config) {
|
418
|
-
let me = this,
|
419
|
-
items = me.items[config.componentId] || {},
|
420
|
-
eventListeners = items[config.eventName] || [],
|
421
|
-
i = 0,
|
422
|
-
len = eventListeners.length,
|
423
|
-
listener;
|
424
|
-
|
425
|
-
for (; i < len; i++) {
|
426
|
-
listener = eventListeners[i];
|
427
|
-
|
428
|
-
if (listener.fn === config.eventHandlerName) {
|
429
|
-
listener.fn = config.eventHandlerMethod;
|
430
|
-
listener.scope = config.scope;
|
431
|
-
break;
|
432
|
-
}
|
433
|
-
}
|
434
|
-
}
|
435
|
-
|
436
408
|
/**
|
437
409
|
* @param {Object} listener
|
438
410
|
* @param {Array} path
|
package/src/table/Container.mjs
CHANGED
@@ -286,19 +286,26 @@ class Container extends BaseContainer {
|
|
286
286
|
createColumns(columns) {
|
287
287
|
let me = this,
|
288
288
|
columnDefaults = me.columnDefaults,
|
289
|
-
sorters = me.store?.sorters
|
289
|
+
sorters = me.store?.sorters,
|
290
|
+
renderer;
|
290
291
|
|
291
292
|
if (!columns || !columns.length) {
|
292
293
|
Neo.logError('Attempting to create a table.Container without defined columns', me.id);
|
293
294
|
}
|
294
295
|
|
295
296
|
columns.forEach(column => {
|
297
|
+
renderer = column.renderer;
|
298
|
+
|
296
299
|
columnDefaults && Neo.assignDefaults(column, columnDefaults);
|
297
300
|
|
298
301
|
if (column.dock && !column.width) {
|
299
302
|
Neo.logError('Attempting to create a docked column without a defined width', column, me.id);
|
300
303
|
}
|
301
304
|
|
305
|
+
if (renderer && Neo.isString(renderer) && me[renderer]) {
|
306
|
+
column.renderer = me[renderer];
|
307
|
+
}
|
308
|
+
|
302
309
|
if (sorters?.[0]) {
|
303
310
|
if (column.dataField === sorters[0].property) {
|
304
311
|
column.isSorted = sorters[0].direction;
|