Projekt

Allgemein

Profil

« Zurück | Weiter » 

Revision 82cb442c

Von Sven Schöling vor etwa 13 Jahren hinzugefügt

  • ID 82cb442c2d9bff976babc64bb0b05a121896b6bf
  • Vorgänger ca9e9f88
  • Nachfolger 43829e1b

Onlinehilfe als modale Overlays.

L.online_help_tag produziert jetzt nicht mehr ein Popup sondern ein modales Overlay.
Im template muss leider im Moment noch ein Ziel dafür eingebunden werden mit:

[% PROCESS 'common/help_overlay.html' %]

Unterschiede anzeigen:

SL/Form.pm
701 701
                '<script type="text/javascript" src="js/jscalendar/calendar-setup.js"></script>',
702 702
                '<script type="text/javascript" src="js/part_selection.js"></script>',
703 703
                '<script type="text/javascript" src="js/jquery-ui.js"></script>',
704
                '<script type="text/javascript" src="js/jqModal.js"></script>',
704 705
                '<link rel="stylesheet" type="text/css" href="css/ui-lightness/jquery-ui-1.8.12.custom.css">';
705 706
  push @header, $self->{javascript} if $self->{javascript};
706 707
  push @header, map { $_->show_javascript } @{ $self->{AJAX} || [] };
SL/Template/Plugin/L.pm
507 507

  
508 508
  die 'malformed help tag' unless $tag =~ /^[a-zA-Z0-9_]+$/;
509 509
  return unless -f $file;
510
  return $self->html_tag('a', $text, href => $file, target => '_blank');
510
  return $self->html_tag('a', $text, href => $file, class => 'jqModal')
511 511
}
512 512

  
513 513
sub dump {
css/lx-office-erp.css
326 326
  margin-bottom: 5px;
327 327
  padding: 5px;
328 328
}
329

  
330
.jqmWindow {
331
  display: none;
332

  
333
  position: fixed;
334
  top: 17%;
335
  left: 40%;
336

  
337
  margin-left: -200px;
338
  width: 700px;
339

  
340
  background-color: lemonchiffon;
341
  color: #333;
342
  border: 1px solid black;
343
  padding: 4px;
344
}
345

  
346
.jqmContent {
347
  padding: 8px;
348
}
349

  
350
.jqmWindow h1 {
351
  border: 0;
352
  padding: 0;
353
  background-color: lemonchiffon;
354
}
355

  
356
.jqmOverlay {
357
  background-color: #000;
358
}
js/jqModal.js
1
jqModal/jqModal.js
js/jqModal/jqModal.js
1
/*
2
 * jqModal - Minimalist Modaling with jQuery
3
 *   (http://dev.iceburg.net/jquery/jqModal/)
4
 *
5
 * Copyright (c) 2007,2008 Brice Burgess <bhb@iceburg.net>
6
 * Dual licensed under the MIT and GPL licenses:
7
 *   http://www.opensource.org/licenses/mit-license.php
8
 *   http://www.gnu.org/licenses/gpl.html
9
 *
10
 * $Version: 03/01/2009 +r14
11
 */
12
(function($) {
13
$.fn.jqm=function(o){
14
var p={
15
overlay: 0,
16
overlayClass: 'jqmOverlay',
17
closeClass: 'jqmClose',
18
trigger: '.jqModal',
19
ajax: '@href',
20
ajaxText: '<img src="images/spinner.gif" alt="...">',
21
target: '#help_content',
22
modal: F,
23
toTop: F,
24
onShow: F,
25
onHide: F,
26
onLoad: F
27
};
28
return this.each(function(){if(this._jqm)return H[this._jqm].c=$.extend({},H[this._jqm].c,o);s++;this._jqm=s;
29
H[s]={c:$.extend(p,$.jqm.params,o),a:F,w:$(this).addClass('jqmID'+s),s:s};
30
if(p.trigger)$(this).jqmAddTrigger(p.trigger);
31
});};
32

  
33
$.fn.jqmAddClose=function(e){return hs(this,e,'jqmHide');};
34
$.fn.jqmAddTrigger=function(e){return hs(this,e,'jqmShow');};
35
$.fn.jqmShow=function(t){return this.each(function(){t=t||window.event;$.jqm.open(this._jqm,t);});};
36
$.fn.jqmHide=function(t){return this.each(function(){t=t||window.event;$.jqm.close(this._jqm,t)});};
37

  
38
$.jqm = {
39
hash:{},
40
open:function(s,t){var h=H[s],c=h.c,cc='.'+c.closeClass,z=(parseInt(h.w.css('z-index'))),z=(z>0)?z:3000,o=$('<div></div>').css({height:'100%',width:'100%',position:'fixed',left:0,top:0,'z-index':z-1,opacity:c.overlay/100});if(h.a)return F;h.t=t;h.a=true;h.w.css('z-index',z);
41
 if(c.modal) {if(!A[0])L('bind');A.push(s);}
42
 else if(c.overlay > 0)h.w.jqmAddClose(o);
43
 else o=F;
44

  
45
 h.o=(o)?o.addClass(c.overlayClass).prependTo('body'):F;
46
 if(ie6){$('html,body').css({height:'100%',width:'100%'});if(o){o=o.css({position:'absolute'})[0];for(var y in {Top:1,Left:1})o.style.setExpression(y.toLowerCase(),"(_=(document.documentElement.scroll"+y+" || document.body.scroll"+y+"))+'px'");}}
47

  
48
 if(c.ajax) {var r=c.target||h.w,u=c.ajax,r=(typeof r == 'string')?$(r,h.w):$(r),u=(u.substr(0,1) == '@')?$(t).attr(u.substring(1)):u;
49
  r.html(c.ajaxText).load(u,function(){if(c.onLoad)c.onLoad.call(this,h);if(cc)h.w.jqmAddClose($(cc,h.w));e(h);});}
50
 else if(cc)h.w.jqmAddClose($(cc,h.w));
51

  
52
 if(c.toTop&&h.o)h.w.before('<span id="jqmP'+h.w[0]._jqm+'"></span>').insertAfter(h.o);
53
 (c.onShow)?c.onShow(h):h.w.show();e(h);return F;
54
},
55
close:function(s){var h=H[s];if(!h.a)return F;h.a=F;
56
 if(A[0]){A.pop();if(!A[0])L('unbind');}
57
 if(h.c.toTop&&h.o)$('#jqmP'+h.w[0]._jqm).after(h.w).remove();
58
 if(h.c.onHide)h.c.onHide(h);else{h.w.hide();if(h.o)h.o.remove();} return F;
59
},
60
params:{}};
61
var s=0,H=$.jqm.hash,A=[],ie6=$.browser.msie&&($.browser.version == "6.0"),F=false,
62
i=$('<iframe src="javascript:false;document.write(\'\');" class="jqm"></iframe>').css({opacity:0}),
63
e=function(h){if(ie6)if(h.o)h.o.html('<p style="width:100%;height:100%"/>').prepend(i);else if(!$('iframe.jqm',h.w)[0])h.w.prepend(i); f(h);},
64
f=function(h){try{$(':input:visible',h.w)[0].focus();}catch(_){}},
65
L=function(t){$()[t]("keypress",m)[t]("keydown",m)[t]("mousedown",m);},
66
m=function(e){var h=H[A[A.length-1]],r=(!$(e.target).parents('.jqmID'+h.s)[0]);if(r)f(h);return !r;},
67
hs=function(w,t,c){return w.each(function(){var s=this._jqm;$(t).each(function() {
68
 if(!this[c]){this[c]=[];$(this).click(function(){for(var i in {jqmShow:1,jqmHide:1})for(var s in this[i])if(H[this[i][s]])H[this[i][s]].w[i](this);return F;});}this[c].push(s);});});};
69
})(jQuery);
templates/webpages/common/help_overlay.html
1
[%- USE T8 %]
2
<script type="text/javascript">
3
  $().ready(function(){$('#help_div').jqm()});
4
</script>
5
<div class='jqmWindow' id='help_div'>
6
  <a href='#' style='float:right' class='jqmClose'><img src='image/close.png' border='0' alt='[% 'Close Dialog' | $T8 %]'></a>
7
  <div class='jqmContent' id='help_content'>
8
    [% 'Please wait...' | $T8 %]
9
    <img src='image/spinner.gif' alt="[% 'loading' | $T8 %]">
10
  </div>
11
</div>

Auch abrufbar als: Unified diff