Änderungen von Dokument Show Hide Macro
Zuletzt geändert von jklein am 2025/06/02 14:04
Zusammenfassung
-
Objekte (4 geändert, 0 hinzugefügt, 1 gelöscht)
Details
- XWiki.JavaScriptExtension[0]
-
- Code
-
... ... @@ -1,31 +1,16 @@ 1 1 require(['jquery'], function($) { 2 - function onClick () { 3 - var button = $(this), 4 - content = button.parent().next(), 5 - effect = button.attr('data-show-effect'), 6 - data = button.data(); 7 - 8 - if ($.inArray(effect, ['toggle', 'fadeToggle', 'slideToggle']) == -1) 9 - effect = 'toggle'; 10 - 11 - // Determine current visibility and toggle state 12 - data.showHideState = !(('showHideState' in data) ? data.showHideState : content.is(':visible')); 13 - 14 - // Determine message and icon 15 - var message = button.attr(data.showHideState ? 'data-hide-message' : 'data-show-message'); 16 - var icon = data.showHideState ? '▼ ' : '► '; 17 - 18 - // Update button text with icon 19 - button.html(icon + message); 20 - 21 - // Perform the animation 22 - content.stop()[effect](parseInt(button.attr('data-show-duration'))); 23 - 24 - return false; 25 - } 26 - 27 - $(document).ready(function() { 28 - $('.showhidebutton').children('a').on('click', onClick); 29 - }); 2 + function onClick () { 3 + var button = $(this), 4 + content = button.parent().next(), 5 + effect = button.attr('data-show-effect'), 6 + data = button.data(); 7 + if($.inArray(effect,['toggle','fadeToggle','slideToggle']) == -1) effect = 'toggle'; 8 + data.showHideState = !(('showHideState' in data) ? data.showHideState : content.is(':visible')); 9 + button.html(button.attr(data.showHideState ? 'data-hide-message' : 'data-show-message')); 10 + content.stop()[effect](parseInt(button.attr('data-show-duration'))); 11 + return false; 12 + } 13 + $(document).ready(function() { 14 + $('.showhidebutton').children('a').click(onClick); 15 + }); 30 30 }); 31 -
- XWiki.StyleSheetExtension[0]
-
- Pufferstrategie
-
... ... @@ -1,1 +1,0 @@ 1 -long - Code
-
... ... @@ -1,22 +1,0 @@ 1 -.showhide-header-flex { 2 - display: flex; 3 - justify-content: space-between; 4 - align-items: center; 5 - background-color: #f9f9f9; 6 - padding: 6px 10px; 7 - border: 1px solid #ddd; 8 - border-radius: 4px 4px 0 0; 9 - font-weight: bold; 10 -} 11 - 12 -.showhide-title { 13 - flex: 1; 14 - text-align: left; 15 -} 16 - 17 -.showhidebutton a { 18 - text-decoration: none; 19 - cursor: pointer; 20 - font-weight: normal; 21 -} 22 - - Name
-
... ... @@ -1,1 +1,0 @@ 1 -ShowHide Style
- XWiki.WikiMacroClass[0]
-
- Cached
-
... ... @@ -1,1 +1,0 @@ 1 -Nein - Asynchrones Rendern
-
... ... @@ -1,1 +1,0 @@ 1 -Nein - Makro-Code
-
... ... @@ -11,17 +11,6 @@ 11 11 #set($hidemessage = $escapetool.xml($mparams.hidemessage)) 12 12 #set($divstyle = $escapetool.xml($mparams.style)) 13 13 #set($effect = $escapetool.xml($mparams.effect)) 14 -#set($title = $escapetool.xml($mparams.title)) 15 - 16 -## Standardtexte setzen 17 -#if(!$showmessage || $showmessage == "") 18 - #set($showmessage = "Anzeigen") 19 -#end 20 -#if(!$hidemessage || $hidemessage == "") 21 - #set($hidemessage = "Verbergen") 22 -#end 23 - 24 -## Effekte setzen 25 25 #if($effect == "appear" || $effect == "fade") 26 26 #set($effect = "fadeToggle") 27 27 #elseif ($effect == "blind" || $effect == "slide") ... ... @@ -28,37 +28,19 @@ 28 28 #set($effect = "slideToggle") 29 29 #end 30 30 #set($effectduration = $mathtool.mul(1000,$mparams.effectduration)) 31 - 32 -## HTML-Struktur 33 33 (% #if($divstyle && $divstyle!="") style="${divstyle}" #end %) 34 34 ((( 35 - 36 -(% class="showhide-header" %) 37 -((( 22 +(% class="showhidebutton" %) 23 +((( 38 38 {{html clean=false}} 39 -<div class="showhide-header-flex"> 40 - <div class="showhide-title">$title</div> 41 - <div class="showhidebutton"> 42 - <a href="javascript:void(0)" 43 - #if($id && $id!="")id="showhidebuttontext${id}" #end 44 - data-show-duration="$effectduration" 45 - data-show-effect="$effect" 46 - data-show-message="$showmessage" 47 - data-hide-message="$hidemessage"> 48 - ► $showmessage 49 - </a> 50 - </div> 51 -</div> 25 +<a href="javascript:void(0)" #if($id && $id!="")id="showhidebuttontext${id}" #end data-show-duration="$effectduration" data-show-effect="$effect" data-show-message="$showmessage" data-hide-message="$hidemessage">$mparams.showmessage</a> 52 52 {{/html}} 53 53 ))) 54 - 55 -(% class="showhidecontent" #if($id && $id!="")id="showhidecontent${id}" #end#if($xcontext.action != 'edit') style="display: none;"#end %) 56 -((( 57 -((( 58 -{{wikimacrocontent /}} 59 -))) 28 +(% class="showhidecontent" #if($id && $id!="")id="showhidecontent${id}" #end style="display: none;" %) 29 +((( 30 +((( 31 +$xcontext.macro.content 60 60 ))) 61 - 62 62 ))) 34 +))) 63 63 {{/velocity}} 64 - - Makroinhaltstyp
-
... ... @@ -1,1 +1,0 @@ 1 -Wiki - Makrobeschreibung
-
... ... @@ -1,1 +1,1 @@ 1 -Show /hide content with animations.1 +Show Hide Macro
- XWiki.WikiMacroParameterClass[0]
-
- Parameter-Vorgabe
-
... ... @@ -1,1 +1,1 @@ 1 - Ausklappen1 +Show !
- XWiki.WikiMacroParameterClass[1]
-
- Parameter-Vorgabe
-
... ... @@ -1,1 +1,1 @@ 1 - Einklappen1 +Hide !