I think you're on to something... the fix does work for viewing the form tiddler in the pop-up, but it disables the viewing of the form tiddler in the straight "right from the tiddler" way...
Any ideas? (he said hopefully :-) Thanks, Dave On May 22, 10:23 pm, Eric Shulman <elsdes...@gmail.com> wrote: > > The slider isn't really the issue. The problem is that data in a form > > tiddler does not appear in transclusion (e.g., when using the > > <<tiddler>> macro) - all you can see is the outline of the form, not > > the contents of the form fields. > > The problem originates with the 'lookup function' that > [[FormTiddlerPlugin]] is using to identify the tiddler in which the > <<formTiddler>> macro and <data>...</data> block are stored (the > "source" tiddler). > > Here's what that function currently looks like: > ------------------------------------------ > config.macros.formTiddler.getContainingTiddlerName = function(element) > { > return story.findContainingTiddler(element).id.substr(7);} > > ------------------------------------------ > > Unfortunately, story.findContainingTiddler() (a standard TW core > function) always returns the title of the *outermost* containing > tiddler -- in this case, the one that invokes the <<tiddler>> macro -- > rather than name the actual source tiddler that was transcluded when > that macro was processed. This, of course, produces the results that > you have observed: the plugin is unable to retrieve the form data, > because it is looking in the wrong tiddler! > > Fortunately, there may be a relatively easy solution... > > The key is to know that, whenever a tiddler is displayed in the story > column, it is contained within a 'wrapper' element that includes a > special "tiddler" attribute that holds the title of the current > tiddler. > > Similarly, whenever a <<tiddler>> macro is processed, the transcluded > content is also contained in a wrapper element that has its own > "tiddler" attribute, set to the title of the source tiddler that was > transcluded. > > The fix involves re-defining the FormTiddlerPlugin lookup function, so > that it will find the *innermost* wrapper that has a "tiddler" > attribute, and then use *that* value to retrieve the correct > <data>...</data> block. > > We can do this by adding an extra tiddler, e.g., > [[FormTiddlerPluginTweak]], tagged with 'systemConfig', with the > following replacement code: > ------------------------------------------ > config.macros.formTiddler.getContainingTiddlerName = function(e) { > // find transcluded OR containing tiddler > while(e && !e.getAttribute("tiddler")) e=e.parentNode; > return e?e.getAttribute("tiddler"):e;}; > > ------------------------------------------ > > PLUS: as an added bonus, because 'transclusion' via the <<tabs>> macro > works the same way as the <<tiddler>> macro (i.e., it sets the > "tiddler" attribute of the containing wrapper), this 'tweak' should > also fix the same problem when using forms from within tabs! > > Give it a try and let me know what happens... > > enjoy, > -e > Eric Shulman > TiddlyTools / ELS Design Studios --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "TiddlyWiki" group. To post to this group, send email to TiddlyWiki@googlegroups.com To unsubscribe from this group, send email to tiddlywiki+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/TiddlyWiki?hl=en -~----------~----~----~----~------~----~------~--~---