X-Git-Url: https://dev.renevier.net/?p=syj.git;a=blobdiff_plain;f=public%2Fjs%2Futils.js;h=f437d150d8f821000afa9adda7253547deb0c0eb;hp=d59a112736ce89d77e79b00c78b9de699c3f7e4c;hb=6cc4b3cd4538430770c935bd3192f1f72d75d96b;hpb=8e7d8e39a2ee5801a2f68b95cdc0e84b55da1019 diff --git a/public/js/utils.js b/public/js/utils.js index d59a112..f437d15 100644 --- a/public/js/utils.js +++ b/public/js/utils.js @@ -30,6 +30,36 @@ var CloseBtn = Class.create({ } }); +var Toggler = Class.create({ + initialize: function(target, options) { + options = Object.extend({}, options); + target = $(target).hide(); + + var openIcn = options.openIcn || 'icons/bullet_arrow_right.png', + closeIcn = options.closeIcn || 'icons/bullet_arrow_down.png'; + + this.element = new Element("img", { src: openIcn }) + .setStyle({ border: 'none', // in firefox, in image inside an anchor has a border + verticalAlign: "middle"}); + + this.element.observe('click', function(evt) { + if (target.visible()) { + evt.target.src = openIcn; + target.hide(); + } else { + evt.target.src = closeIcn; + target.show(); + } + evt.stop(); + }); + + if (options.initialShow) { + target.show(); + this.element.src = closeIcn; + } + } +}); + var Deck = Class.create({ initialize: function(elt, options) { this.element = $(elt);