diff options
Diffstat (limited to 'framework/Web/Javascripts/scriptaculous')
| -rw-r--r-- | framework/Web/Javascripts/scriptaculous/builder.js | 17 | ||||
| -rw-r--r-- | framework/Web/Javascripts/scriptaculous/controls.js | 57 | ||||
| -rw-r--r-- | framework/Web/Javascripts/scriptaculous/dragdrop.js | 43 | ||||
| -rw-r--r-- | framework/Web/Javascripts/scriptaculous/effects.js | 126 | ||||
| -rw-r--r-- | framework/Web/Javascripts/scriptaculous/slider.js | 7 | 
5 files changed, 156 insertions, 94 deletions
| diff --git a/framework/Web/Javascripts/scriptaculous/builder.js b/framework/Web/Javascripts/scriptaculous/builder.js index 199afc12..c110e0c7 100644 --- a/framework/Web/Javascripts/scriptaculous/builder.js +++ b/framework/Web/Javascripts/scriptaculous/builder.js @@ -1,6 +1,6 @@ -// script.aculo.us builder.js v1.7.0, Fri Jan 19 19:16:36 CET 2007 +// script.aculo.us builder.js v1.7.1_beta1, Mon Mar 12 14:40:50 +0100 2007 -// Copyright (c) 2005, 2006 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) +// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)  //  // script.aculo.us is freely distributable under the terms of an MIT-style license.  // For details, see the script.aculo.us web site: http://script.aculo.us/ @@ -48,7 +48,8 @@ var Builder = {      // attributes (or text)      if(arguments[1])        if(this._isStringOrNumber(arguments[1]) || -        (arguments[1] instanceof Array)) { +        (arguments[1] instanceof Array) || +        arguments[1].tagName) {            this._children(element, arguments[1]);          } else {            var attrs = this._attributes(arguments[1]); @@ -66,7 +67,7 @@ var Builder = {              }              if(element.tagName.toUpperCase() != elementName)                element = parentElement.getElementsByTagName(elementName)[0]; -            } +          }          }       // text, or array of children @@ -92,6 +93,10 @@ var Builder = {      return attrs.join(" ");    },    _children: function(element, children) { +    if(children.tagName) { +      element.appendChild(children); +      return; +    }      if(typeof children=='object') { // array can hold nodes and text        children.flatten().each( function(e) {          if(typeof e=='object') @@ -101,8 +106,8 @@ var Builder = {              element.appendChild(Builder._text(e));        });      } else -      if(Builder._isStringOrNumber(children))  -         element.appendChild(Builder._text(children)); +      if(Builder._isStringOrNumber(children)) +        element.appendChild(Builder._text(children));    },    _isStringOrNumber: function(param) {      return(typeof param=='string' || typeof param=='number'); diff --git a/framework/Web/Javascripts/scriptaculous/controls.js b/framework/Web/Javascripts/scriptaculous/controls.js index 46f2cc18..bbd00d69 100644 --- a/framework/Web/Javascripts/scriptaculous/controls.js +++ b/framework/Web/Javascripts/scriptaculous/controls.js @@ -1,8 +1,8 @@ -// script.aculo.us controls.js v1.7.0, Fri Jan 19 19:16:36 CET 2007 +// script.aculo.us controls.js v1.7.1_beta1, Mon Mar 12 14:40:50 +0100 2007 -// Copyright (c) 2005, 2006 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) -//           (c) 2005, 2006 Ivan Krstic (http://blogs.law.harvard.edu/ivan) -//           (c) 2005, 2006 Jon Tirsen (http://www.tirsen.com) +// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) +//           (c) 2005-2007 Ivan Krstic (http://blogs.law.harvard.edu/ivan) +//           (c) 2005-2007 Jon Tirsen (http://www.tirsen.com)  // Contributors:  //  Richard Livsey  //  Rahul Bhargava @@ -90,8 +90,7 @@ Autocompleter.Base.prototype = {    show: function() {      if(Element.getStyle(this.update, 'display')=='none') this.options.onShow(this.element, this.update);      if(!this.iefix &&  -      (navigator.appVersion.indexOf('MSIE')>0) && -      (navigator.userAgent.indexOf('Opera')<0) && +      (Prototype.Browser.IE) &&        (Element.getStyle(this.update, 'position')=='absolute')) {        new Insertion.After(this.update,          '<iframe id="' + this.update.id + '_iefix" '+ @@ -141,17 +140,17 @@ Autocompleter.Base.prototype = {         case Event.KEY_UP:           this.markPrevious();           this.render(); -         if(navigator.appVersion.indexOf('AppleWebKit')>0) Event.stop(event); +         if(Prototype.Browser.WebKit) Event.stop(event);           return;         case Event.KEY_DOWN:           this.markNext();           this.render(); -         if(navigator.appVersion.indexOf('AppleWebKit')>0) Event.stop(event); +         if(Prototype.Browser.WebKit) Event.stop(event);           return;        }       else          if(event.keyCode==Event.KEY_TAB || event.keyCode==Event.KEY_RETURN ||  -         (navigator.appVersion.indexOf('AppleWebKit') > 0 && event.keyCode == 0)) return; +         (Prototype.Browser.WebKit > 0 && event.keyCode == 0)) return;      this.changed = true;      this.hasFocus = true; @@ -477,9 +476,14 @@ Ajax.InPlaceEditor.prototype = {      this.options = Object.extend({        paramName: "value",        okButton: true, +      okLink: false,        okText: "ok", +      cancelButton: false,        cancelLink: true,        cancelText: "cancel", +      textBeforeControls: '', +      textBetweenControls: '', +      textAfterControls: '',        savingText: "Saving...",        clickToEditText: "Click to edit",        okText: "ok", @@ -567,23 +571,52 @@ Ajax.InPlaceEditor.prototype = {        var br = document.createElement("br");        this.form.appendChild(br);      } +     +    if (this.options.textBeforeControls) +      this.form.appendChild(document.createTextNode(this.options.textBeforeControls));      if (this.options.okButton) { -      okButton = document.createElement("input"); +      var okButton = document.createElement("input");        okButton.type = "submit";        okButton.value = this.options.okText;        okButton.className = 'editor_ok_button';        this.form.appendChild(okButton);      } +     +    if (this.options.okLink) { +      var okLink = document.createElement("a"); +      okLink.href = "#"; +      okLink.appendChild(document.createTextNode(this.options.okText)); +      okLink.onclick = this.onSubmit.bind(this); +      okLink.className = 'editor_ok_link'; +      this.form.appendChild(okLink); +    } +     +    if (this.options.textBetweenControls &&  +      (this.options.okLink || this.options.okButton) &&  +      (this.options.cancelLink || this.options.cancelButton)) +      this.form.appendChild(document.createTextNode(this.options.textBetweenControls)); +       +    if (this.options.cancelButton) { +      var cancelButton = document.createElement("input"); +      cancelButton.type = "submit"; +      cancelButton.value = this.options.cancelText; +      cancelButton.onclick = this.onclickCancel.bind(this); +      cancelButton.className = 'editor_cancel_button'; +      this.form.appendChild(cancelButton); +    }      if (this.options.cancelLink) { -      cancelLink = document.createElement("a"); +      var cancelLink = document.createElement("a");        cancelLink.href = "#";        cancelLink.appendChild(document.createTextNode(this.options.cancelText));        cancelLink.onclick = this.onclickCancel.bind(this); -      cancelLink.className = 'editor_cancel';       +      cancelLink.className = 'editor_cancel editor_cancel_link';              this.form.appendChild(cancelLink);      } +     +    if (this.options.textAfterControls) +      this.form.appendChild(document.createTextNode(this.options.textAfterControls));    },    hasHTMLLineBreaks: function(string) {      if (!this.options.handleLineBreaks) return false; diff --git a/framework/Web/Javascripts/scriptaculous/dragdrop.js b/framework/Web/Javascripts/scriptaculous/dragdrop.js index 32c91bc3..81e95c5c 100644 --- a/framework/Web/Javascripts/scriptaculous/dragdrop.js +++ b/framework/Web/Javascripts/scriptaculous/dragdrop.js @@ -1,7 +1,7 @@ -// script.aculo.us dragdrop.js v1.7.0, Fri Jan 19 19:16:36 CET 2007 +// script.aculo.us dragdrop.js v1.7.1_beta1, Mon Mar 12 14:40:50 +0100 2007 -// Copyright (c) 2005, 2006 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) -//           (c) 2005, 2006 Sammi Williams (http://www.oriontransfer.co.nz, sammi@oriontransfer.co.nz) +// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) +//           (c) 2005-2007 Sammi Williams (http://www.oriontransfer.co.nz, sammi@oriontransfer.co.nz)  //   // script.aculo.us is freely distributable under the terms of an MIT-style license.  // For details, see the script.aculo.us web site: http://script.aculo.us/ @@ -112,8 +112,10 @@ var Droppables = {      Position.prepare();      if (this.isAffected([Event.pointerX(event), Event.pointerY(event)], element, this.last_active)) -      if (this.last_active.onDrop)  -        this.last_active.onDrop(element, this.last_active.element, event); +      if (this.last_active.onDrop) { +        this.last_active.onDrop(element, this.last_active.element, event);  +        return true;  +      }    },    reset: function() { @@ -245,6 +247,7 @@ Draggable.prototype = {        },        zindex: 1000,        revert: false, +      quiet: false,        scroll: false,        scrollSensitivity: 20,        scrollSpeed: 15, @@ -353,8 +356,12 @@ Draggable.prototype = {    updateDrag: function(event, pointer) {      if(!this.dragging) this.startDrag(event); -    Position.prepare(); -    Droppables.show(pointer, this.element); +     +    if(!this.options.quiet){ +      Position.prepare(); +      Droppables.show(pointer, this.element); +    } +          Draggables.notify('onDrag', this, event);      this.draw(pointer); @@ -382,13 +389,19 @@ Draggable.prototype = {      }      // fix AppleWebKit rendering -    if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0); +    if(Prototype.Browser.WebKit) window.scrollBy(0,0);      Event.stop(event);    },    finishDrag: function(event, success) {      this.dragging = false; +     +    if(this.options.quiet){ +      Position.prepare(); +      var pointer = [Event.pointerX(event), Event.pointerY(event)]; +      Droppables.show(pointer, this.element); +    }      if(this.options.ghosting) {        Position.relativize(this.element); @@ -396,7 +409,12 @@ Draggable.prototype = {        this._clone = null;      } -    if(success) Droppables.fire(event, this.element); +    var dropped = false;  +    if(success) {  +      dropped = Droppables.fire(event, this.element);  +      if (!dropped) dropped = false;  +    } +    if(dropped && this.options.onDropped) this.options.onDropped(this.element);      Draggables.notify('onEnd', this, event);      var revert = this.options.revert; @@ -404,8 +422,9 @@ Draggable.prototype = {      var d = this.currentDelta();      if(revert && this.options.reverteffect) { -      this.options.reverteffect(this.element,  -        d[1]-this.delta[1], d[0]-this.delta[0]); +      if (dropped == 0 || revert != 'failure') +        this.options.reverteffect(this.element, +          d[1]-this.delta[1], d[0]-this.delta[0]);      } else {        this.delta = d;      } @@ -614,6 +633,7 @@ var Sortable = {        delay:       0,        hoverclass:  null,        ghosting:    false, +      quiet:       false,         scroll:      false,        scrollSensitivity: 20,        scrollSpeed: 15, @@ -628,6 +648,7 @@ var Sortable = {      // build options for the draggables      var options_for_draggable = {        revert:      true, +      quiet:       options.quiet,        scroll:      options.scroll,        scrollSpeed: options.scrollSpeed,        scrollSensitivity: options.scrollSensitivity, diff --git a/framework/Web/Javascripts/scriptaculous/effects.js b/framework/Web/Javascripts/scriptaculous/effects.js index 06f59b47..8a4a4f9f 100644 --- a/framework/Web/Javascripts/scriptaculous/effects.js +++ b/framework/Web/Javascripts/scriptaculous/effects.js @@ -1,6 +1,6 @@ -// script.aculo.us effects.js v1.7.0, Fri Jan 19 19:16:36 CET 2007 +// script.aculo.us effects.js v1.7.1_beta1, Mon Mar 12 14:40:50 +0100 2007 -// Copyright (c) 2005, 2006 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us) +// Copyright (c) 2005-2007 Thomas Fuchs (http://script.aculo.us, http://mir.aculo.us)  // Contributors:  //  Justin Palmer (http://encytemedia.com/)  //  Mark Pilgrim (http://diveintomark.org/) @@ -45,18 +45,10 @@ Element.collectTextNodesIgnoreClass = function(element, className) {  Element.setContentZoom = function(element, percent) {    element = $(element);      element.setStyle({fontSize: (percent/100) + 'em'});    -  if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0); +  if(Prototype.Browser.WebKit) window.scrollBy(0,0);    return element;  } -Element.getOpacity = function(element){ -  return $(element).getStyle('opacity'); -} - -Element.setOpacity = function(element, value){ -  return $(element).setStyle({opacity:value}); -} -  Element.getInlineOpacity = function(element){    return $(element).style.opacity || '';  } @@ -89,7 +81,7 @@ var Effect = {        throw("Effect.tagifyText requires including script.aculo.us' builder.js library");      var tagifyStyle = 'position:relative'; -    if(/MSIE/.test(navigator.userAgent) && !window.opera) tagifyStyle += ';zoom:1'; +    if(Prototype.Browser.IE) tagifyStyle += ';zoom:1';      element = $(element);      $A(element.childNodes).each( function(child) { @@ -152,7 +144,8 @@ Effect.Transitions = {      return 1-pos;    },    flicker: function(pos) { -    return ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random()/4; +    var pos = ((-Math.cos(pos*Math.PI)/4) + 0.75) + Math.random()/4; +    return (pos > 1 ? 1 : pos);    },    wobble: function(pos) {      return (-Math.cos(pos*Math.PI*(9*pos))/2) + 0.5; @@ -179,7 +172,7 @@ Effect.ScopedQueue = Class.create();  Object.extend(Object.extend(Effect.ScopedQueue.prototype, Enumerable), {    initialize: function() {      this.effects  = []; -    this.interval = null; +    this.interval = null;        },    _each: function(iterator) {      this.effects._each(iterator); @@ -213,7 +206,7 @@ Object.extend(Object.extend(Effect.ScopedQueue.prototype, Enumerable), {      if(!effect.options.queue.limit || (this.effects.length < effect.options.queue.limit))        this.effects.push(effect); -    if(!this.interval)  +    if(!this.interval)        this.interval = setInterval(this.loop.bind(this), 15);    },    remove: function(effect) { @@ -226,7 +219,7 @@ Object.extend(Object.extend(Effect.ScopedQueue.prototype, Enumerable), {    loop: function() {      var timePos = new Date().getTime();      for(var i=0, len=this.effects.length;i<len;i++)  -      if(this.effects[i]) this.effects[i].loop(timePos); +      this.effects[i] && this.effects[i].loop(timePos);    }  }); @@ -246,7 +239,7 @@ Effect.Queue = Effect.Queues.get('global');  Effect.DefaultOptions = {    transition: Effect.Transitions.sinoidal,    duration:   1.0,   // seconds -  fps:        60.0,  // max. 60fps due to Effect.Queue implementation +  fps:        100,   // 100= assume 66fps max.    sync:       false, // true for combining    from:       0.0,    to:         1.0, @@ -258,11 +251,35 @@ Effect.Base = function() {};  Effect.Base.prototype = {    position: null,    start: function(options) { +    function codeForEvent(options,eventName){ +      return ( +        (options[eventName+'Internal'] ? 'this.options.'+eventName+'Internal(this);' : '') + +        (options[eventName] ? 'this.options.'+eventName+'(this);' : '') +      ); +    } +    if(options.transition === false) options.transition = Effect.Transitions.linear;      this.options      = Object.extend(Object.extend({},Effect.DefaultOptions), options || {});      this.currentFrame = 0;      this.state        = 'idle';      this.startOn      = this.options.delay*1000; -    this.finishOn     = this.startOn + (this.options.duration*1000); +    this.finishOn     = this.startOn+(this.options.duration*1000); +    this.fromToDelta  = this.options.to-this.options.from; +    this.totalTime    = this.finishOn-this.startOn; +    this.totalFrames  = this.options.fps*this.options.duration; +     +    eval('this.render = function(pos){ '+ +      'if(this.state=="idle"){this.state="running";'+ +      codeForEvent(options,'beforeSetup')+ +      (this.setup ? 'this.setup();':'')+  +      codeForEvent(options,'afterSetup')+ +      '};if(this.state=="running"){'+ +      'pos=this.options.transition(pos)*'+this.fromToDelta+'+'+this.options.from+';'+ +      'this.position=pos;'+ +      codeForEvent(options,'beforeUpdate')+ +      (this.update ? 'this.update(pos);':'')+ +      codeForEvent(options,'afterUpdate')+ +      '}}'); +          this.event('beforeStart');      if(!this.options.sync)        Effect.Queues.get(typeof this.options.queue == 'string' ?  @@ -278,31 +295,14 @@ Effect.Base.prototype = {          this.event('afterFinish');          return;          } -      var pos   = (timePos - this.startOn) / (this.finishOn - this.startOn); -      var frame = Math.round(pos * this.options.fps * this.options.duration); +      var pos   = (timePos - this.startOn) / this.totalTime, +          frame = Math.round(pos * this.totalFrames);        if(frame > this.currentFrame) {          this.render(pos);          this.currentFrame = frame;        }      }    }, -  render: function(pos) { -    if(this.state == 'idle') { -      this.state = 'running'; -      this.event('beforeSetup'); -      if(this.setup) this.setup(); -      this.event('afterSetup'); -    } -    if(this.state == 'running') { -      if(this.options.transition) pos = this.options.transition(pos); -      pos *= (this.options.to-this.options.from); -      pos += this.options.from; -      this.position = pos; -      this.event('beforeUpdate'); -      if(this.update) this.update(pos); -      this.event('afterUpdate'); -    } -  },    cancel: function() {      if(!this.options.sync)        Effect.Queues.get(typeof this.options.queue == 'string' ?  @@ -358,7 +358,7 @@ Object.extend(Object.extend(Effect.Opacity.prototype, Effect.Base.prototype), {      this.element = $(element);      if(!this.element) throw(Effect._elementDoesNotExistError);      // make this work on IE on elements without 'layout' -    if(/MSIE/.test(navigator.userAgent) && !window.opera && (!this.element.currentStyle.hasLayout)) +    if(Prototype.Browser.IE && (!this.element.currentStyle.hasLayout))        this.element.setStyle({zoom: 1});      var options = Object.extend({        from: this.element.getOpacity() || 0.0, @@ -953,7 +953,7 @@ Object.extend(Object.extend(Effect.Morph.prototype, Effect.Base.prototype), {            effect.element.addClassName(effect.options.style);            effect.transforms.each(function(transform) {              if(transform.style != 'opacity') -              effect.element.style[transform.style.camelize()] = ''; +              effect.element.style[transform.style] = '';            });          }        } else this.style = options.style.parseStyle(); @@ -969,26 +969,28 @@ Object.extend(Object.extend(Effect.Morph.prototype, Effect.Base.prototype), {        });      }      this.transforms = this.style.map(function(pair){ -      var property = pair[0].underscore().dasherize(), value = pair[1], unit = null; +      var property = pair[0], value = pair[1], unit = null;        if(value.parseColor('#zzzzzz') != '#zzzzzz') {          value = value.parseColor();          unit  = 'color';        } else if(property == 'opacity') {          value = parseFloat(value); -        if(/MSIE/.test(navigator.userAgent) && !window.opera && (!this.element.currentStyle.hasLayout)) +        if(Prototype.Browser.IE && (!this.element.currentStyle.hasLayout))            this.element.setStyle({zoom: 1}); -      } else if(Element.CSS_LENGTH.test(value))  -        var components = value.match(/^([\+\-]?[0-9\.]+)(.*)$/), -          value = parseFloat(components[1]), unit = (components.length == 3) ? components[2] : null; +      } else if(Element.CSS_LENGTH.test(value)) { +          var components = value.match(/^([\+\-]?[0-9\.]+)(.*)$/); +          value = parseFloat(components[1]); +          unit = (components.length == 3) ? components[2] : null; +      }        var originalValue = this.element.getStyle(property); -      return $H({  -        style: property,  +      return {  +        style: property.camelize(),           originalValue: unit=='color' ? parseColor(originalValue) : parseFloat(originalValue || 0),           targetValue: unit=='color' ? parseColor(value) : value,          unit: unit -      }); +      };      }.bind(this)).reject(function(transform){        return (          (transform.originalValue == transform.targetValue) || @@ -1000,17 +1002,19 @@ Object.extend(Object.extend(Effect.Morph.prototype, Effect.Base.prototype), {      });    },    update: function(position) { -    var style = $H(), value = null; -    this.transforms.each(function(transform){ -      value = transform.unit=='color' ? -        $R(0,2).inject('#',function(m,v,i){ -          return m+(Math.round(transform.originalValue[i]+ -            (transform.targetValue[i] - transform.originalValue[i])*position)).toColorPart() }) :  +    var style = {}, transform, i = this.transforms.length; +    while(i--) +      style[(transform = this.transforms[i]).style] =  +        transform.unit=='color' ? '#'+ +          (Math.round(transform.originalValue[0]+ +            (transform.targetValue[0]-transform.originalValue[0])*position)).toColorPart() + +          (Math.round(transform.originalValue[1]+ +            (transform.targetValue[1]-transform.originalValue[1])*position)).toColorPart() + +          (Math.round(transform.originalValue[2]+ +            (transform.targetValue[2]-transform.originalValue[2])*position)).toColorPart() :          transform.originalValue + Math.round(            ((transform.targetValue - transform.originalValue) * position) * 1000)/1000 + transform.unit; -      style[transform.style] = value; -    }); -    this.element.setStyle(style); +    this.element.setStyle(style, true);    }  }); @@ -1057,14 +1061,14 @@ Element.CSS_PROPERTIES = $w(  Element.CSS_LENGTH = /^(([\+\-]?[0-9\.]+)(em|ex|px|in|cm|mm|pt|pc|\%))|0$/;  String.prototype.parseStyle = function(){ -  var element = Element.extend(document.createElement('div')); +  var element = document.createElement('div');    element.innerHTML = '<div style="' + this + '"></div>'; -  var style = element.down().style, styleRules = $H(); +  var style = element.childNodes[0].style, styleRules = $H();    Element.CSS_PROPERTIES.each(function(property){      if(style[property]) styleRules[property] = style[property];     }); -  if(/MSIE/.test(navigator.userAgent) && !window.opera && this.indexOf('opacity') > -1) { +  if(Prototype.Browser.IE && this.indexOf('opacity') > -1) {      styleRules.opacity = this.match(/opacity:\s*((?:0|1)?(?:\.\d*)?)/)[1];    }    return styleRules; @@ -1075,13 +1079,13 @@ Element.morph = function(element, style) {    return element;  }; -['setOpacity','getOpacity','getInlineOpacity','forceRerendering','setContentZoom', +['getInlineOpacity','forceRerendering','setContentZoom',   'collectTextNodes','collectTextNodesIgnoreClass','morph'].each(     function(f) { Element.Methods[f] = Element[f]; }  );  Element.Methods.visualEffect = function(element, effect, options) { -  s = effect.gsub(/_/, '-').camelize(); +  s = effect.dasherize().camelize();    effect_class = s.charAt(0).toUpperCase() + s.substring(1);    new Effect[effect_class](element, options);    return $(element); diff --git a/framework/Web/Javascripts/scriptaculous/slider.js b/framework/Web/Javascripts/scriptaculous/slider.js index f24f2823..64115199 100644 --- a/framework/Web/Javascripts/scriptaculous/slider.js +++ b/framework/Web/Javascripts/scriptaculous/slider.js @@ -1,6 +1,6 @@ -// script.aculo.us slider.js v1.7.0, Fri Jan 19 19:16:36 CET 2007 +// script.aculo.us slider.js v1.7.1_beta1, Mon Mar 12 14:40:50 +0100 2007 -// Copyright (c) 2005, 2006 Marty Haught, Thomas Fuchs  +// Copyright (c) 2005-2007 Marty Haught, Thomas Fuchs   //  // script.aculo.us is freely distributable under the terms of an MIT-style license.  // For details, see the script.aculo.us web site: http://script.aculo.us/ @@ -242,8 +242,7 @@ Control.Slider.prototype = {     if(this.active) {        if(!this.dragging) this.dragging = true;        this.draw(event); -      // fix AppleWebKit rendering -      if(navigator.appVersion.indexOf('AppleWebKit')>0) window.scrollBy(0,0); +      if(Prototype.Browser.WebKit) window.scrollBy(0,0);        Event.stop(event);     }    }, | 
