{ "id": "61855", "key": "TIMOB-1223", "fields": { "issuetype": { "id": "1", "description": "A problem which impairs or prevents the functions of the product.", "name": "Bug", "subtask": false }, "project": { "id": "10153", "key": "TIMOB", "name": "Titanium SDK/CLI", "projectCategory": { "id": "10100", "description": "Titanium and related SDKs used in application development", "name": "Client" } }, "fixVersions": [ { "id": "11225", "name": "Release 1.5.0", "archived": true, "released": true, "releaseDate": "2010-12-14" } ], "resolution": { "id": "1", "description": "A fix for this issue is checked into the tree and tested.", "name": "Fixed" }, "resolutiondate": "2011-04-17T01:55:34.000+0000", "created": "2011-04-15T02:46:58.000+0000", "priority": { "name": "Medium", "id": "3" }, "labels": [ "android", "blackberry", "defect" ], "versions": [], "issuelinks": [], "assignee": { "name": "dthorp", "key": "dthorp", "displayName": "Don Thorp", "active": true, "timeZone": "America/Los_Angeles" }, "updated": "2011-04-17T01:55:34.000+0000", "status": { "description": "The issue is considered finished, the resolution is correct. Issues which are closed can be reopened.", "name": "Closed", "id": "6", "statusCategory": { "id": 3, "key": "done", "colorName": "green", "name": "Done" } }, "components": [ { "id": "10202", "name": "Android", "description": "Android Platform" } ], "description": "{html}
By \"dynamic properties\" here we mean \"unofficial\" (unregistered)\nproperties, such as if a developer just sets a property in JS on\none of our proxies, like:
\n\nvar win = Ti.UI.createWindow();\nwin.secret = \"my secret message\";
\n
\n\"secret\" is not a registered property of WindowProxy. In\nAndroid/BB, we handle the assignment by passing it on to the\nscriptable -- we don't give it to the proxy. Later, if the proxy is\nwrapped again into a different KrollObject, and code tries to get\nthe property value, it will fail.
\nThis happens with currentWindow, for example, when a new context\nis created for a window and then Ti.UI.currentWindow is set to a\nwrapped instance of that window proxy. Here's a complete fail case\nexample:
\nFile: app.js
\n// ....\nvar win = Ti.UI.createWindow({url:'win1.js'});\nwin.secret = \"My secret message\";\nTi.API.info(win.secret); // ok -- .secret is on the scriptable\nwin.open(); // causes new context win1.js
\n
\nFile: win1.js
\nvar win = Ti.UI.currentWindow;\nTi.API.info(win.secret); // fails -- currentWindow is different scriptable than win was in previous context
\n
\nIn our iPhone/iPad implementation, these unregistered properties\nare put right into the proxy's (target's) dynprops collection and\nare therefore available even if the proxy gets wrapped into a\ndifferent scriptable.
This is related to #1005 as well.
To help with prioritizing, I just want to note that I (and\nothers too) are currently being stymied by this problem and are\neagerly looking forward to \"Passing Data\" being supported on\nAndroid and BlackBerry (see http://developer.appcelerator.com/helpdesk/view/28391).
+1 for prioritizing this in 1.5. It makes it difficult to create\nmeaningful abstractions for enterprise apps without this\nfunctionality.
There are a few cases where this will work. We are adding\nfeatures for Android where this will absolutely not work by design.\nPlease don't rely on it as a silver bullet. Blackberry may have\nsome of the same restrictions but in different areas.
So how will child contexts be able to access data from their\nparent context? Only through manual Ti.API.Properties calls? Or\nwill I need to have it fire an event on the parent that fires an\nevent back on the child, passing it the data? Neither of those two\noptions seems like something that should be done (let alone the\nonly way to get something done) in a modern framework...
Do you have any guess yet as to when you'll be able to code a\nfix for this? Trying to gauge if it's worth waiting for the fix or\nif we'll need to make the time to rearchitect our code around this\nproblem.
Marshall is actively working on the required refactor to support\nthis capability.
Thank you for increasing the priority, a fix for this would be\ngreat!
This should be fixed by #915
Thank you! Confirmed fixed on Android 2.1.
confirmed iOS 4.0.2 and 3.1.2. Android 2.2. Thanks for\nconfirming 2.1 Matthew!
FYI parts of this fix appear to have regressed in master\n(1.5.0); see #2221.