diff options
Diffstat (limited to 'module/web/static/js')
| -rw-r--r-- | module/web/static/js/config.js | 2 | ||||
| -rwxr-xr-x | module/web/static/js/libs/bootstrap-2.3.js (renamed from module/web/static/js/libs/bootstrap-2.2.2.js) | 261 | ||||
| -rw-r--r-- | module/web/static/js/utils/animations.js | 11 | ||||
| -rw-r--r-- | module/web/static/js/views/headerView.js | 10 | 
4 files changed, 200 insertions, 84 deletions
| diff --git a/module/web/static/js/config.js b/module/web/static/js/config.js index 0c0eac3fc..5bdfcf201 100644 --- a/module/web/static/js/config.js +++ b/module/web/static/js/config.js @@ -11,7 +11,7 @@ require.config({          animate: "libs/jquery.animate-enhanced-0.99",          omniwindow: "libs/jquery.omniwindow",          select2: "libs/select2-3.2", -        bootstrap: "libs/bootstrap-2.2.2", +        bootstrap: "libs/bootstrap-2.3",          underscore: "libs/lodash-1.0.rc3",          backbone: "libs/backbone-0.9.10", diff --git a/module/web/static/js/libs/bootstrap-2.2.2.js b/module/web/static/js/libs/bootstrap-2.3.js index 56621401c..09b812c4f 100755 --- a/module/web/static/js/libs/bootstrap-2.2.2.js +++ b/module/web/static/js/libs/bootstrap-2.3.js @@ -1,5 +1,5 @@  /* =================================================== - * bootstrap-transition.js v2.2.2 + * bootstrap-transition.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#transitions   * ===================================================   * Copyright 2012 Twitter, Inc. @@ -59,7 +59,7 @@  }(window.jQuery);  /* ========================================================= - * bootstrap-modal.js v2.2.2 + * bootstrap-modal.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#modals   * =========================================================   * Copyright 2012 Twitter, Inc. @@ -120,8 +120,7 @@              that.$element.appendTo(document.body) //don't move modals dom position            } -          that.$element -            .show() +          that.$element.show()            if (transition) {              that.$element[0].offsetWidth // force reflow @@ -199,12 +198,13 @@          })        } -    , hideModal: function (that) { -        this.$element -          .hide() -          .trigger('hidden') - -        this.backdrop() +    , hideModal: function () { +        var that = this +        this.$element.hide() +        this.backdrop(function () { +          that.removeBackdrop() +          that.$element.trigger('hidden') +        })        }      , removeBackdrop: function () { @@ -232,6 +232,8 @@            this.$backdrop.addClass('in') +          if (!callback) return +            doAnimate ?              this.$backdrop.one($.support.transition.end, callback) :              callback() @@ -240,8 +242,8 @@            this.$backdrop.removeClass('in')            $.support.transition && this.$element.hasClass('fade')? -            this.$backdrop.one($.support.transition.end, $.proxy(this.removeBackdrop, this)) : -            this.removeBackdrop() +            this.$backdrop.one($.support.transition.end, callback) : +            callback()          } else if (callback) {            callback() @@ -305,7 +307,7 @@  }(window.jQuery);  /* ============================================================ - * bootstrap-dropdown.js v2.2.2 + * bootstrap-dropdown.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#dropdowns   * ============================================================   * Copyright 2012 Twitter, Inc. @@ -387,7 +389,10 @@        isActive = $parent.hasClass('open') -      if (!isActive || (isActive && e.keyCode == 27)) return $this.click() +      if (!isActive || (isActive && e.keyCode == 27)) { +        if (e.which == 27) $parent.find(toggle).focus() +        return $this.click() +      }        $items = $('[role=menu] li:not(.divider):visible a', $parent) @@ -421,8 +426,9 @@        selector = selector && /#/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') //strip for ie7      } -    $parent = $(selector) -    $parent.length || ($parent = $this.parent()) +    $parent = selector && $(selector) + +    if (!$parent || !$parent.length) $parent = $this.parent()      return $parent    } @@ -458,15 +464,16 @@     * =================================== */    $(document) -    .on('click.dropdown.data-api touchstart.dropdown.data-api', clearMenus) -    .on('click.dropdown touchstart.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() }) -    .on('touchstart.dropdown.data-api', '.dropdown-menu', function (e) { e.stopPropagation() }) -    .on('click.dropdown.data-api touchstart.dropdown.data-api'  , toggle, Dropdown.prototype.toggle) -    .on('keydown.dropdown.data-api touchstart.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown) +    .on('click.dropdown.data-api', clearMenus) +    .on('click.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() }) +    .on('.dropdown-menu', function (e) { e.stopPropagation() }) +    .on('click.dropdown.data-api'  , toggle, Dropdown.prototype.toggle) +    .on('keydown.dropdown.data-api', toggle + ', [role=menu]' , Dropdown.prototype.keydown)  }(window.jQuery); +  /* ============================================================= - * bootstrap-scrollspy.js v2.2.2 + * bootstrap-scrollspy.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#scrollspy   * =============================================================   * Copyright 2012 Twitter, Inc. @@ -526,7 +533,7 @@                , $href = /^#\w/.test(href) && $(href)              return ( $href                && $href.length -              && [[ $href.position().top + self.$scrollElement.scrollTop(), href ]] ) || null +              && [[ $href.position().top + (!$.isWindow(self.$scrollElement.get(0)) && self.$scrollElement.scrollTop()), href ]] ) || null            })            .sort(function (a, b) { return a[0] - b[0] })            .each(function () { @@ -628,7 +635,7 @@  }(window.jQuery);  /* ======================================================== - * bootstrap-tab.js v2.2.2 + * bootstrap-tab.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#tabs   * ========================================================   * Copyright 2012 Twitter, Inc. @@ -772,7 +779,7 @@  }(window.jQuery);  /* =========================================================== - * bootstrap-tooltip.js v2.2.2 + * bootstrap-tooltip.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#tooltips   * Inspired by the original jQuery.tipsy by Jason Frame   * =========================================================== @@ -811,19 +818,27 @@    , init: function (type, element, options) {        var eventIn          , eventOut +        , triggers +        , trigger +        , i        this.type = type        this.$element = $(element)        this.options = this.getOptions(options)        this.enabled = true -      if (this.options.trigger == 'click') { -        this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this)) -      } else if (this.options.trigger != 'manual') { -        eventIn = this.options.trigger == 'hover' ? 'mouseenter' : 'focus' -        eventOut = this.options.trigger == 'hover' ? 'mouseleave' : 'blur' -        this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this)) -        this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this)) +      triggers = this.options.trigger.split(' ') + +      for (i = triggers.length; i--;) { +        trigger = triggers[i] +        if (trigger == 'click') { +          this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this)) +        } else if (trigger != 'manual') { +          eventIn = trigger == 'hover' ? 'mouseenter' : 'focus' +          eventOut = trigger == 'hover' ? 'mouseleave' : 'blur' +          this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this)) +          this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this)) +        }        }        this.options.selector ? @@ -832,7 +847,7 @@      }    , getOptions: function (options) { -      options = $.extend({}, $.fn[this.type].defaults, options, this.$element.data()) +      options = $.extend({}, $.fn[this.type].defaults, this.$element.data(), options)        if (options.delay && typeof options.delay == 'number') {          options.delay = { @@ -870,14 +885,16 @@    , show: function () {        var $tip -        , inside          , pos          , actualWidth          , actualHeight          , placement          , tp +        , e = $.Event('show')        if (this.hasContent() && this.enabled) { +        this.$element.trigger(e) +        if (e.isDefaultPrevented()) return          $tip = this.tip()          this.setContent() @@ -889,19 +906,18 @@            this.options.placement.call(this, $tip[0], this.$element[0]) :            this.options.placement -        inside = /in/.test(placement) -          $tip            .detach()            .css({ top: 0, left: 0, display: 'block' }) -          .insertAfter(this.$element) -        pos = this.getPosition(inside) +        this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element) + +        pos = this.getPosition()          actualWidth = $tip[0].offsetWidth          actualHeight = $tip[0].offsetHeight -        switch (inside ? placement.split(' ')[1] : placement) { +        switch (placement) {            case 'bottom':              tp = {top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2}              break @@ -916,13 +932,58 @@              break          } -        $tip -          .offset(tp) -          .addClass(placement) -          .addClass('in') +        this.applyPlacement(tp, placement) +        this.$element.trigger('shown')        }      } +  , applyPlacement: function(offset, placement){ +      var $tip = this.tip() +        , width = $tip[0].offsetWidth +        , height = $tip[0].offsetHeight +        , actualWidth +        , actualHeight +        , delta +        , replace + +      $tip +        .offset(offset) +        .addClass(placement) +        .addClass('in') + +      actualWidth = $tip[0].offsetWidth +      actualHeight = $tip[0].offsetHeight + +      if (placement == 'top' && actualHeight != height) { +        offset.top = offset.top + height - actualHeight +        replace = true +      } + +      if (placement == 'bottom' || placement == 'top') { +        delta = 0 + +        if (offset.left < 0){ +          delta = offset.left * -2 +          offset.left = 0 +          $tip.offset(offset) +          actualWidth = $tip[0].offsetWidth +          actualHeight = $tip[0].offsetHeight +        } + +        this.replaceArrow(delta - width + actualWidth, actualWidth, 'left') +      } else { +        this.replaceArrow(actualHeight - height, actualHeight, 'top') +      } + +      if (replace) $tip.offset(offset) +    } + +  , replaceArrow: function(delta, dimension, position){ +      this +        .arrow() +        .css(position, delta ? (50 * (1 - delta / dimension) + "%") : '') +    } +    , setContent: function () {        var $tip = this.tip()          , title = this.getTitle() @@ -934,6 +995,10 @@    , hide: function () {        var that = this          , $tip = this.tip() +        , e = $.Event('hide') + +      this.$element.trigger(e) +      if (e.isDefaultPrevented()) return        $tip.removeClass('in') @@ -952,13 +1017,15 @@          removeWithAnimation() :          $tip.detach() +      this.$element.trigger('hidden') +        return this      }    , fixTitle: function () {        var $e = this.$element        if ($e.attr('title') || typeof($e.attr('data-original-title')) != 'string') { -        $e.attr('data-original-title', $e.attr('title') || '').removeAttr('title') +        $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')        }      } @@ -966,11 +1033,12 @@        return this.getTitle()      } -  , getPosition: function (inside) { -      return $.extend({}, (inside ? {top: 0, left: 0} : this.$element.offset()), { -        width: this.$element[0].offsetWidth -      , height: this.$element[0].offsetHeight -      }) +  , getPosition: function () { +      var el = this.$element[0] +      return $.extend({}, (typeof el.getBoundingClientRect == 'function') ? el.getBoundingClientRect() : { +        width: el.offsetWidth +      , height: el.offsetHeight +      }, this.$element.offset())      }    , getTitle: function () { @@ -988,6 +1056,10 @@        return this.$tip = this.$tip || $(this.options.template)      } +  , arrow: function(){ +      return this.$arrow = this.$arrow || this.tip().find(".tooltip-arrow") +    } +    , validate: function () {        if (!this.$element[0].parentNode) {          this.hide() @@ -1009,8 +1081,8 @@      }    , toggle: function (e) { -      var self = $(e.currentTarget)[this.type](this._options).data(this.type) -      self[self.tip().hasClass('in') ? 'hide' : 'show']() +      var self = e ? $(e.currentTarget)[this.type](this._options).data(this.type) : this +      self.tip().hasClass('in') ? self.hide() : self.show()      }    , destroy: function () { @@ -1042,10 +1114,11 @@    , placement: 'top'    , selector: false    , template: '<div class="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>' -  , trigger: 'hover' +  , trigger: 'hover focus'    , title: ''    , delay: 0    , html: false +  , container: false    } @@ -1058,8 +1131,9 @@    }  }(window.jQuery); +  /* =========================================================== - * bootstrap-popover.js v2.2.2 + * bootstrap-popover.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#popovers   * ===========================================================   * Copyright 2012 Twitter, Inc. @@ -1118,8 +1192,8 @@          , $e = this.$element          , o = this.options -      content = $e.attr('data-content') -        || (typeof o.content == 'function' ? o.content.call($e[0]) :  o.content) +      content = (typeof o.content == 'function' ? o.content.call($e[0]) :  o.content) +        || $e.attr('data-content')        return content      } @@ -1159,7 +1233,7 @@      placement: 'right'    , trigger: 'click'    , content: '' -  , template: '<div class="popover"><div class="arrow"></div><div class="popover-inner"><h3 class="popover-title"></h3><div class="popover-content"></div></div></div>' +  , template: '<div class="popover"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'    }) @@ -1172,8 +1246,9 @@    }  }(window.jQuery); +  /* ========================================================== - * bootstrap-affix.js v2.2.2 + * bootstrap-affix.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#affix   * ==========================================================   * Copyright 2012 Twitter, Inc. @@ -1290,7 +1365,7 @@  }(window.jQuery);  /* ========================================================== - * bootstrap-alert.js v2.2.2 + * bootstrap-alert.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#alerts   * ==========================================================   * Copyright 2012 Twitter, Inc. @@ -1389,7 +1464,7 @@  }(window.jQuery);  /* ============================================================ - * bootstrap-button.js v2.2.2 + * bootstrap-button.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#buttons   * ============================================================   * Copyright 2012 Twitter, Inc. @@ -1494,7 +1569,7 @@  }(window.jQuery);  /* ============================================================= - * bootstrap-collapse.js v2.2.2 + * bootstrap-collapse.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#collapse   * =============================================================   * Copyright 2012 Twitter, Inc. @@ -1547,7 +1622,7 @@          , actives          , hasData -      if (this.transitioning) return +      if (this.transitioning || this.$element.hasClass('in')) return        dimension = this.dimension()        scroll = $.camelCase(['scroll', dimension].join('-')) @@ -1567,7 +1642,7 @@    , hide: function () {        var dimension -      if (this.transitioning) return +      if (this.transitioning || !this.$element.hasClass('in')) return        dimension = this.dimension()        this.reset(this.$element[dimension]())        this.transition('removeClass', $.Event('hide'), 'hidden') @@ -1624,7 +1699,7 @@      return this.each(function () {        var $this = $(this)          , data = $this.data('collapse') -        , options = typeof option == 'object' && option +        , options = $.extend({}, $.fn.collapse.defaults, $this.data(), typeof option == 'object' && option)        if (!data) $this.data('collapse', (data = new Collapse(this, options)))        if (typeof option == 'string') data[option]()      }) @@ -1661,7 +1736,7 @@  }(window.jQuery);  /* ========================================================== - * bootstrap-carousel.js v2.2.2 + * bootstrap-carousel.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#carousel   * ==========================================================   * Copyright 2012 Twitter, Inc. @@ -1690,6 +1765,7 @@    var Carousel = function (element, options) {      this.$element = $(element) +    this.$indicators = this.$element.find('.carousel-indicators')      this.options = options      this.options.pause == 'hover' && this.$element        .on('mouseenter', $.proxy(this.pause, this)) @@ -1700,19 +1776,24 @@      cycle: function (e) {        if (!e) this.paused = false +      if (this.interval) clearInterval(this.interval);        this.options.interval          && !this.paused          && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))        return this      } +  , getActiveIndex: function () { +      this.$active = this.$element.find('.item.active') +      this.$items = this.$active.parent().children() +      return this.$items.index(this.$active) +    } +    , to: function (pos) { -      var $active = this.$element.find('.item.active') -        , children = $active.parent().children() -        , activePos = children.index($active) +      var activeIndex = this.getActiveIndex()          , that = this -      if (pos > (children.length - 1) || pos < 0) return +      if (pos > (this.$items.length - 1) || pos < 0) return        if (this.sliding) {          return this.$element.one('slid', function () { @@ -1720,11 +1801,11 @@          })        } -      if (activePos == pos) { +      if (activeIndex == pos) {          return this.pause().cycle()        } -      return this.slide(pos > activePos ? 'next' : 'prev', $(children[pos])) +      return this.slide(pos > activeIndex ? 'next' : 'prev', $(this.$items[pos]))      }    , pause: function (e) { @@ -1765,10 +1846,19 @@        e = $.Event('slide', {          relatedTarget: $next[0] +      , direction: direction        })        if ($next.hasClass('active')) return +      if (this.$indicators.length) { +        this.$indicators.find('.active').removeClass('active') +        this.$element.one('slid', function () { +          var $nextIndicator = $(that.$indicators.children()[that.getActiveIndex()]) +          $nextIndicator && $nextIndicator.addClass('active') +        }) +      } +        if ($.support.transition && this.$element.hasClass('slide')) {          this.$element.trigger(e)          if (e.isDefaultPrevented()) return @@ -1813,7 +1903,7 @@        if (!data) $this.data('carousel', (data = new Carousel(this, options)))        if (typeof option == 'number') data.to(option)        else if (action) data[action]() -      else if (options.interval) data.cycle() +      else if (options.interval) data.pause().cycle()      })    } @@ -1836,17 +1926,24 @@   /* CAROUSEL DATA-API    * ================= */ -  $(document).on('click.carousel.data-api', '[data-slide]', function (e) { +  $(document).on('click.carousel.data-api', '[data-slide], [data-slide-to]', function (e) {      var $this = $(this), href        , $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) //strip for ie7        , options = $.extend({}, $target.data(), $this.data()) +      , slideIndex +      $target.carousel(options) + +    if (slideIndex = $this.attr('data-slide-to')) { +      $target.data('carousel').pause().to(slideIndex).cycle() +    } +      e.preventDefault()    })  }(window.jQuery);  /* ============================================================= - * bootstrap-typeahead.js v2.2.2 + * bootstrap-typeahead.js v2.3.0   * http://twitter.github.com/bootstrap/javascript.html#typeahead   * =============================================================   * Copyright 2012 Twitter, Inc. @@ -2019,6 +2116,7 @@    , listen: function () {        this.$element +        .on('focus',    $.proxy(this.focus, this))          .on('blur',     $.proxy(this.blur, this))          .on('keypress', $.proxy(this.keypress, this))          .on('keyup',    $.proxy(this.keyup, this)) @@ -2030,6 +2128,7 @@        this.$menu          .on('click', $.proxy(this.click, this))          .on('mouseenter', 'li', $.proxy(this.mouseenter, this)) +        .on('mouseleave', 'li', $.proxy(this.mouseleave, this))      }    , eventSupported: function(eventName) { @@ -2103,22 +2202,33 @@        e.preventDefault()    } +  , focus: function (e) { +      this.focused = true +    } +    , blur: function (e) { -      var that = this -      setTimeout(function () { that.hide() }, 150) +      this.focused = false +      if (!this.mousedover && this.shown) this.hide()      }    , click: function (e) {        e.stopPropagation()        e.preventDefault()        this.select() +      this.$element.focus()      }    , mouseenter: function (e) { +      this.mousedover = true        this.$menu.find('.active').removeClass('active')        $(e.currentTarget).addClass('active')      } +  , mouseleave: function (e) { +      this.mousedover = false +      if (!this.focused && this.shown) this.hide() +    } +    } @@ -2163,7 +2273,6 @@    $(document).on('focus.typeahead.data-api', '[data-provide="typeahead"]', function (e) {      var $this = $(this)      if ($this.data('typeahead')) return -    e.preventDefault()      $this.typeahead($this.data())    }) diff --git a/module/web/static/js/utils/animations.js b/module/web/static/js/utils/animations.js index 789359e0c..ea06669b3 100644 --- a/module/web/static/js/utils/animations.js +++ b/module/web/static/js/utils/animations.js @@ -44,7 +44,7 @@ define(['jquery', 'underscore', 'transit'], function(jQuery, _) {      };      // calculate the height and write it to data, better used on invisible elements -    jQuery.fn.calculateHeight = function() { +    jQuery.fn.calculateHeight = function(setHeight) {          var o = jQuery(this[0]);          var height = o.height();          if (!height) { @@ -57,6 +57,9 @@ define(['jquery', 'underscore', 'transit'], function(jQuery, _) {              o.css('visibility', '');          } +        if (setHeight) +            o.css('height', height); +          o.data('height', height);          return this;      }; @@ -78,7 +81,11 @@ define(['jquery', 'underscore', 'transit'], function(jQuery, _) {          placement || (placement = 'top');          var o = jQuery(this[0]); -        o.find('[data-toggle="tooltip"]').tooltip({delay: {show: 500, hide: 100}, placement: placement}); +        o.find('[data-toggle="tooltip"]').tooltip( +            { +                delay: {show: 800, hide: 100}, +                placement: placement +            });          return this;      }; diff --git a/module/web/static/js/views/headerView.js b/module/web/static/js/views/headerView.js index 43c66b99f..cfceca6cd 100644 --- a/module/web/static/js/views/headerView.js +++ b/module/web/static/js/views/headerView.js @@ -5,7 +5,7 @@ define(['jquery', 'underscore', 'backbone', 'flot'], function($, _, Backbone) {          el: 'header',          events: { -            'click i.icon-tasks': 'show_taskList', +            'click i.iconf-list': 'toggle_taskList',              'click .popover .close': 'hide_taskList',              'click .btn-grabber': 'open_grabber'          }, @@ -17,8 +17,8 @@ define(['jquery', 'underscore', 'backbone', 'flot'], function($, _, Backbone) {          initialize: function() { -            this.notifications = this.$('#notification-area').calculateHeight(); -            this.selections = this.$('#selection-area').calculateHeight(); +            this.notifications = this.$('#notification-area').calculateHeight().height(0); +            this.selections = this.$('#selection-area').calculateHeight().height(0);              var totalPoints = 100;              var data = []; @@ -81,8 +81,8 @@ define(['jquery', 'underscore', 'backbone', 'flot'], function($, _, Backbone) {          render: function() {          }, -        show_taskList: function() { -            this.$('.popover').fadeIn(); +        toggle_taskList: function() { +            this.$('.popover').animate({opacity: 'toggle'});          },          hide_taskList: function() { | 
