@xuda.io/runtime-bundle 1.0.388 → 1.0.389

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.
@@ -31989,16 +31989,81 @@ func.UI.screen.execute_xu_functions = async function (SESSION_ID, is_skeleton, $
31989
31989
 
31990
31990
  // create a new instance of `MutationObserver` named `observer`,
31991
31991
  // passing it a callback function
31992
- const observer = new MutationObserver(() => {
31993
- console.log('callback that runs when observer is triggered');
31994
- });
31992
+ // const observer = new MutationObserver(() => {
31993
+ // console.log('callback that runs when observer is triggered');
31994
+ // });
31995
+
31996
+ // // call `observe()`, passing it the element to observe, and the options object
31997
+ // observer.observe(_session.DS_GLB[paramsP.dsSessionP], {
31998
+ // subtree: true,
31999
+ // childList: true,
32000
+ // });
32001
+ //==================
32002
+ class ObjectObserver {
32003
+ constructor(targetObject, callback) {
32004
+ this.callback = callback;
32005
+ this.target = targetObject;
32006
+
32007
+ // Create a proxy to intercept property access and modifications
32008
+ this.proxy = new Proxy(targetObject, {
32009
+ set: (target, property, value) => {
32010
+ const oldValue = target[property];
32011
+ target[property] = value;
32012
+
32013
+ // Call the callback with mutation information
32014
+ this.callback({
32015
+ type: 'update',
32016
+ object: target,
32017
+ property,
32018
+ oldValue,
32019
+ newValue: value,
32020
+ });
32021
+
32022
+ return true;
32023
+ },
32024
+
32025
+ deleteProperty: (target, property) => {
32026
+ const oldValue = target[property];
32027
+ const deleted = delete target[property];
32028
+
32029
+ if (deleted) {
32030
+ this.callback({
32031
+ type: 'delete',
32032
+ object: target,
32033
+ property,
32034
+ oldValue,
32035
+ });
32036
+ }
32037
+
32038
+ return deleted;
32039
+ },
32040
+ });
32041
+
32042
+ return this.proxy;
32043
+ }
31995
32044
 
31996
- // call `observe()`, passing it the element to observe, and the options object
31997
- observer.observe(_session.DS_GLB[paramsP.dsSessionP], {
31998
- subtree: true,
31999
- childList: true,
32045
+ // Method to stop observing (for cleanup)
32046
+ disconnect() {
32047
+ this.callback = null;
32048
+ this.target = null;
32049
+ this.proxy = null;
32050
+ }
32051
+ }
32052
+
32053
+ // Usage example:
32054
+ const originalObject = _session.DS_GLB[paramsP.dsSessionP];
32055
+
32056
+ // Create observer with callback
32057
+ const observedObject = new ObjectObserver(originalObject, (mutation) => {
32058
+ console.log('Change detected:', mutation);
32000
32059
  });
32001
32060
 
32061
+ // // These operations will trigger the callback
32062
+ // observedObject.name = "Jane"; // Property update
32063
+ // observedObject.job = "Developer"; // Property addition
32064
+ // delete observedObject.age; // Property deletion
32065
+ //==================
32066
+
32002
32067
  return {};
32003
32068
  },
32004
32069
  'xu-bind': async function ($elm, val) {