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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "neo.mjs",
3
- "version": "4.3.15",
3
+ "version": "4.3.17",
4
4
  "description": "The webworkers driven UI framework",
5
5
  "type": "module",
6
6
  "repository": {
@@ -447,12 +447,16 @@ class Base extends CoreBase {
447
447
 
448
448
  /**
449
449
  * Registers the domListeners inside the Neo.manager.DomEvent
450
- * @param {Array} value
451
- * @param {Array} oldValue
450
+ * @param {Object[]} value
451
+ * @param {Object[]} oldValue
452
452
  * @protected
453
453
  */
454
454
  afterSetDomListeners(value, oldValue) {
455
- DomEventManager.updateDomListeners(this, value, oldValue);
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 {Object} component=null
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} [component=this.component]
138
+ * @param {Neo.component.Base} component=this.component
139
139
  */
140
140
  parseConfig(component=this.component) {
141
- let me = this,
142
- domListeners = component.domListeners,
143
- listeners = component.listeners,
144
- reference = component.reference,
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
@@ -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;
@@ -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
@@ -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;