diff options
author | ivan <ivan> | 2008-03-31 21:11:02 +0000 |
---|---|---|
committer | ivan <ivan> | 2008-03-31 21:11:02 +0000 |
commit | 41ab1bbaf58292688e1e84ab153059896f17a5d4 (patch) | |
tree | b678597d3c7b434db24a07d0ee5f4d091ec07e4e /httemplate/elements/popup_link_onclick.html | |
parent | a2649b652a3db877b105b4bea5b34727dbcb914f (diff) |
fix safari weirdness with caching iframes and auto-submitting them (in tax editor at least)
Diffstat (limited to 'httemplate/elements/popup_link_onclick.html')
-rw-r--r-- | httemplate/elements/popup_link_onclick.html | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/httemplate/elements/popup_link_onclick.html b/httemplate/elements/popup_link_onclick.html new file mode 100644 index 000000000..41383fdf6 --- /dev/null +++ b/httemplate/elements/popup_link_onclick.html @@ -0,0 +1,55 @@ +<%doc> + +Example: + + <SCRIPT TYPE="text/javascript" SRC="overlibmws.js"></SCRIPT> + <SCRIPT TYPE="text/javascript" SRC="iframecontentmws.js"></SCRIPT> + + include( '/elements/popup_link_onclick.html', { #hashref or a list, either way + + #required + 'action' => 'content.html', # uri for content of popup + + #strongly recommended + 'actionlabel => 'You clicked', # popup title + + #opt + 'width' => '540', + 'color' => '#ff0000', + 'closetext' => 'Go Away', # the value '' removes the link + } ) + +</%doc> +% if ($action) { +<% $onclick %>\ +% } +<%init> + +my($action, $actionlabel) = ( '', '' ); +my( $width, $height ) = ( 540, 336 ); +my $closetext = 'Close'; +my $color = '#333399'; + +my $params; +if (ref($_[0]) eq 'HASH') { + #$params = { %$params, %{ $_[0] } }; + $params = shift; +} else { + #$params = { %$params, @_ }; + $params = { @_ }; +} + +$action = $params->{'action'} if exists $params->{'action'}; +$actionlabel = $params->{'actionlabel'} if exists $params->{'actionlabel'}; +$width = $params->{'width'} if exists $params->{'width'}; +$height = $params->{'height'} if exists $params->{'height'}; +$color = $params->{'color'} if exists $params->{'color'}; +$closetext = $params->{'closetext'} if exists $params->{'closetext'}; + +#stupid safari is caching the "location" of popup iframs, and submitting them +#instead of displaying them. this should prevent that. +my $popup_name = 'popup-'.time. "-$$-". rand() * 2**32; + +my $onclick = "overlib( OLiframeContent('$action', $width, $height, '$popup_name' ), CAPTION, '$actionlabel', STICKY, AUTOSTATUSCAP, MIDX, 0, MIDY, 0, DRAGGABLE, CLOSECLICK, BGCOLOR, '$color', CGCOLOR, '$color', CLOSETEXT, '$closetext' ); return false;"; + +</%init> |