Commit b8ca1d62c453fcdb8cb7f65ee793fcd159b4c336
Exists in
master
and in
4 other branches
Merge branch 'dev'
Conflicts: app/assets/images/ajax-loader.gif public/favicon.ico
Showing
195 changed files
with
6401 additions
and
1157 deletions
Show diff stats
Gemfile
| ... | ... | @@ -5,7 +5,7 @@ gem 'rails', '3.1.0' |
| 5 | 5 | gem 'sqlite3' |
| 6 | 6 | gem 'devise', "1.4.7" |
| 7 | 7 | gem 'stamp' |
| 8 | -gem 'will_paginate', '~> 3.0' | |
| 8 | +gem 'kaminari' | |
| 9 | 9 | gem 'haml-rails' |
| 10 | 10 | gem 'jquery-rails' |
| 11 | 11 | gem 'grit', :git => 'git://github.com/gitlabhq/grit.git' |
| ... | ... | @@ -16,10 +16,12 @@ gem 'faker' |
| 16 | 16 | gem 'seed-fu', :git => 'git://github.com/mbleigh/seed-fu.git' |
| 17 | 17 | gem "inifile" |
| 18 | 18 | gem "pygments.rb", "0.2.3" |
| 19 | -gem "kaminari" | |
| 20 | 19 | gem "thin" |
| 21 | 20 | gem "git" |
| 22 | 21 | gem "acts_as_list" |
| 22 | +gem 'rdiscount' | |
| 23 | + | |
| 24 | +gem 'acts-as-taggable-on', '~>2.1.0' | |
| 23 | 25 | |
| 24 | 26 | group :assets do |
| 25 | 27 | gem 'sass-rails', " ~> 3.1.0" |
| ... | ... | @@ -27,14 +29,15 @@ group :assets do |
| 27 | 29 | gem 'uglifier' |
| 28 | 30 | end |
| 29 | 31 | |
| 30 | -group :development do | |
| 32 | +group :development do | |
| 33 | + gem 'letter_opener' | |
| 31 | 34 | gem 'rails-footnotes', '>= 3.7.5.rc4' |
| 32 | 35 | gem 'annotate', :git => 'git://github.com/ctran/annotate_models.git' |
| 33 | 36 | end |
| 34 | 37 | |
| 35 | 38 | group :development, :test do |
| 36 | 39 | gem 'rspec-rails' |
| 37 | - gem 'shoulda' | |
| 40 | + gem "shoulda", "~> 3.0.0.beta2" | |
| 38 | 41 | gem 'capybara' |
| 39 | 42 | gem 'autotest' |
| 40 | 43 | gem 'autotest-rails' | ... | ... |
Gemfile.lock
| ... | ... | @@ -54,6 +54,8 @@ GEM |
| 54 | 54 | activesupport (= 3.1.0) |
| 55 | 55 | activesupport (3.1.0) |
| 56 | 56 | multi_json (~> 1.0) |
| 57 | + acts-as-taggable-on (2.1.1) | |
| 58 | + rails | |
| 57 | 59 | acts_as_list (0.1.4) |
| 58 | 60 | addressable (2.2.6) |
| 59 | 61 | ansi (1.3.0) |
| ... | ... | @@ -119,6 +121,8 @@ GEM |
| 119 | 121 | rails (>= 3.0.0) |
| 120 | 122 | launchy (2.0.5) |
| 121 | 123 | addressable (~> 2.2.6) |
| 124 | + letter_opener (0.0.2) | |
| 125 | + launchy | |
| 122 | 126 | libv8 (3.3.10.2) |
| 123 | 127 | linecache19 (0.5.12) |
| 124 | 128 | ruby_core_source (>= 0.1.4) |
| ... | ... | @@ -161,6 +165,7 @@ GEM |
| 161 | 165 | rdoc (~> 3.4) |
| 162 | 166 | thor (~> 0.14.6) |
| 163 | 167 | rake (0.9.2) |
| 168 | + rdiscount (1.6.8) | |
| 164 | 169 | rdoc (3.9.4) |
| 165 | 170 | rspec (2.6.0) |
| 166 | 171 | rspec-core (~> 2.6.0) |
| ... | ... | @@ -200,7 +205,11 @@ GEM |
| 200 | 205 | ffi (>= 1.0.7) |
| 201 | 206 | json_pure |
| 202 | 207 | rubyzip |
| 203 | - shoulda (2.11.3) | |
| 208 | + shoulda (3.0.0.beta2) | |
| 209 | + shoulda-context (~> 1.0.0.beta1) | |
| 210 | + shoulda-matchers (~> 1.0.0.beta1) | |
| 211 | + shoulda-context (1.0.0.beta1) | |
| 212 | + shoulda-matchers (1.0.0.beta3) | |
| 204 | 213 | simplecov (0.5.3) |
| 205 | 214 | multi_json (~> 1.0.3) |
| 206 | 215 | simplecov-html (~> 0.5.3) |
| ... | ... | @@ -232,7 +241,6 @@ GEM |
| 232 | 241 | multi_json (>= 1.0.2) |
| 233 | 242 | warden (1.0.5) |
| 234 | 243 | rack (>= 1.0) |
| 235 | - will_paginate (3.0.0) | |
| 236 | 244 | xpath (0.1.4) |
| 237 | 245 | nokogiri (~> 1.3) |
| 238 | 246 | |
| ... | ... | @@ -240,6 +248,7 @@ PLATFORMS |
| 240 | 248 | ruby |
| 241 | 249 | |
| 242 | 250 | DEPENDENCIES |
| 251 | + acts-as-taggable-on (~> 2.1.0) | |
| 243 | 252 | acts_as_list |
| 244 | 253 | annotate! |
| 245 | 254 | autotest |
| ... | ... | @@ -258,14 +267,16 @@ DEPENDENCIES |
| 258 | 267 | jquery-rails |
| 259 | 268 | kaminari |
| 260 | 269 | launchy |
| 270 | + letter_opener | |
| 261 | 271 | pygments.rb (= 0.2.3) |
| 262 | 272 | rails (= 3.1.0) |
| 263 | 273 | rails-footnotes (>= 3.7.5.rc4) |
| 274 | + rdiscount | |
| 264 | 275 | rspec-rails |
| 265 | 276 | ruby-debug19 |
| 266 | 277 | sass-rails (~> 3.1.0) |
| 267 | 278 | seed-fu! |
| 268 | - shoulda | |
| 279 | + shoulda (~> 3.0.0.beta2) | |
| 269 | 280 | simplecov |
| 270 | 281 | six |
| 271 | 282 | sqlite3 |
| ... | ... | @@ -274,4 +285,3 @@ DEPENDENCIES |
| 274 | 285 | thin |
| 275 | 286 | turn |
| 276 | 287 | uglifier |
| 277 | - will_paginate (~> 3.0) | ... | ... |
app/assets/images/.directory
212 Bytes
396 Bytes
422 Bytes
8.49 KB
1.4 KB
app/assets/javascripts/application.js
| ... | ... | @@ -5,11 +5,15 @@ |
| 5 | 5 | // the compiled file. |
| 6 | 6 | // |
| 7 | 7 | //= require jquery |
| 8 | +//= require jquery-ui | |
| 8 | 9 | //= require jquery_ujs |
| 10 | +//= require jquery.ui.selectmenu | |
| 11 | +//= require jquery.tagify | |
| 12 | +//= require jquery.cookie | |
| 9 | 13 | //= require_tree . |
| 10 | 14 | |
| 11 | 15 | $(function(){ |
| 12 | - $(".one_click_select").click(function(){ | |
| 16 | + $(".one_click_select").live("click", function(){ | |
| 13 | 17 | $(this).select(); |
| 14 | 18 | }); |
| 15 | 19 | |
| ... | ... | @@ -17,6 +21,6 @@ $(function(){ |
| 17 | 21 | $('select#tag').selectmenu({style:'popup', width:200}); |
| 18 | 22 | }); |
| 19 | 23 | |
| 20 | -function updatePage(){ | |
| 21 | - $.ajax({type: "GET", url: location.href, dataType: "script"}); | |
| 24 | +function updatePage(data){ | |
| 25 | + $.ajax({type: "GET", url: location.href, data: data, dataType: "script"}); | |
| 22 | 26 | } | ... | ... |
| ... | ... | @@ -0,0 +1,901 @@ |
| 1 | +// Chosen, a Select Box Enhancer for jQuery and Protoype | |
| 2 | +// by Patrick Filler for Harvest, http://getharvest.com | |
| 3 | +// | |
| 4 | +// Version 0.9.5 | |
| 5 | +// Full source at https://github.com/harvesthq/chosen | |
| 6 | +// Copyright (c) 2011 Harvest http://getharvest.com | |
| 7 | + | |
| 8 | +// MIT License, https://github.com/harvesthq/chosen/blob/master/LICENSE.md | |
| 9 | +// This file is generated by `cake build`, do not edit it by hand. | |
| 10 | +(function() { | |
| 11 | + var SelectParser; | |
| 12 | + SelectParser = (function() { | |
| 13 | + function SelectParser() { | |
| 14 | + this.options_index = 0; | |
| 15 | + this.parsed = []; | |
| 16 | + } | |
| 17 | + SelectParser.prototype.add_node = function(child) { | |
| 18 | + if (child.nodeName === "OPTGROUP") { | |
| 19 | + return this.add_group(child); | |
| 20 | + } else { | |
| 21 | + return this.add_option(child); | |
| 22 | + } | |
| 23 | + }; | |
| 24 | + SelectParser.prototype.add_group = function(group) { | |
| 25 | + var group_position, option, _i, _len, _ref, _results; | |
| 26 | + group_position = this.parsed.length; | |
| 27 | + this.parsed.push({ | |
| 28 | + array_index: group_position, | |
| 29 | + group: true, | |
| 30 | + label: group.label, | |
| 31 | + children: 0, | |
| 32 | + disabled: group.disabled | |
| 33 | + }); | |
| 34 | + _ref = group.childNodes; | |
| 35 | + _results = []; | |
| 36 | + for (_i = 0, _len = _ref.length; _i < _len; _i++) { | |
| 37 | + option = _ref[_i]; | |
| 38 | + _results.push(this.add_option(option, group_position, group.disabled)); | |
| 39 | + } | |
| 40 | + return _results; | |
| 41 | + }; | |
| 42 | + SelectParser.prototype.add_option = function(option, group_position, group_disabled) { | |
| 43 | + if (option.nodeName === "OPTION") { | |
| 44 | + if (option.text !== "") { | |
| 45 | + if (group_position != null) { | |
| 46 | + this.parsed[group_position].children += 1; | |
| 47 | + } | |
| 48 | + this.parsed.push({ | |
| 49 | + array_index: this.parsed.length, | |
| 50 | + options_index: this.options_index, | |
| 51 | + value: option.value, | |
| 52 | + text: option.text, | |
| 53 | + html: option.innerHTML, | |
| 54 | + selected: option.selected, | |
| 55 | + disabled: group_disabled === true ? group_disabled : option.disabled, | |
| 56 | + group_array_index: group_position, | |
| 57 | + classes: option.className, | |
| 58 | + style: option.style.cssText | |
| 59 | + }); | |
| 60 | + } else { | |
| 61 | + this.parsed.push({ | |
| 62 | + array_index: this.parsed.length, | |
| 63 | + options_index: this.options_index, | |
| 64 | + empty: true | |
| 65 | + }); | |
| 66 | + } | |
| 67 | + return this.options_index += 1; | |
| 68 | + } | |
| 69 | + }; | |
| 70 | + return SelectParser; | |
| 71 | + })(); | |
| 72 | + SelectParser.select_to_array = function(select) { | |
| 73 | + var child, parser, _i, _len, _ref; | |
| 74 | + parser = new SelectParser(); | |
| 75 | + _ref = select.childNodes; | |
| 76 | + for (_i = 0, _len = _ref.length; _i < _len; _i++) { | |
| 77 | + child = _ref[_i]; | |
| 78 | + parser.add_node(child); | |
| 79 | + } | |
| 80 | + return parser.parsed; | |
| 81 | + }; | |
| 82 | + this.SelectParser = SelectParser; | |
| 83 | +}).call(this); | |
| 84 | +(function() { | |
| 85 | + /* | |
| 86 | + Chosen source: generate output using 'cake build' | |
| 87 | + Copyright (c) 2011 by Harvest | |
| 88 | + */ | |
| 89 | + var AbstractChosen, root; | |
| 90 | + var __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; }; | |
| 91 | + root = this; | |
| 92 | + AbstractChosen = (function() { | |
| 93 | + function AbstractChosen(form_field, options) { | |
| 94 | + this.form_field = form_field; | |
| 95 | + this.options = options != null ? options : {}; | |
| 96 | + this.set_default_values(); | |
| 97 | + this.is_multiple = this.form_field.multiple; | |
| 98 | + this.default_text_default = this.is_multiple ? "Select Some Options" : "Select an Option"; | |
| 99 | + this.setup(); | |
| 100 | + this.set_up_html(); | |
| 101 | + this.register_observers(); | |
| 102 | + this.finish_setup(); | |
| 103 | + } | |
| 104 | + AbstractChosen.prototype.set_default_values = function() { | |
| 105 | + this.click_test_action = __bind(function(evt) { | |
| 106 | + return this.test_active_click(evt); | |
| 107 | + }, this); | |
| 108 | + this.activate_action = __bind(function(evt) { | |
| 109 | + return this.activate_field(evt); | |
| 110 | + }, this); | |
| 111 | + this.active_field = false; | |
| 112 | + this.mouse_on_container = false; | |
| 113 | + this.results_showing = false; | |
| 114 | + this.result_highlighted = null; | |
| 115 | + this.result_single_selected = null; | |
| 116 | + this.allow_single_deselect = (this.options.allow_single_deselect != null) && this.form_field.options[0].text === "" ? this.options.allow_single_deselect : false; | |
| 117 | + this.disable_search_threshold = this.options.disable_search_threshold || 0; | |
| 118 | + this.choices = 0; | |
| 119 | + return this.results_none_found = this.options.no_results_text || "No results match"; | |
| 120 | + }; | |
| 121 | + AbstractChosen.prototype.mouse_enter = function() { | |
| 122 | + return this.mouse_on_container = true; | |
| 123 | + }; | |
| 124 | + AbstractChosen.prototype.mouse_leave = function() { | |
| 125 | + return this.mouse_on_container = false; | |
| 126 | + }; | |
| 127 | + AbstractChosen.prototype.input_focus = function(evt) { | |
| 128 | + if (!this.active_field) { | |
| 129 | + return setTimeout((__bind(function() { | |
| 130 | + return this.container_mousedown(); | |
| 131 | + }, this)), 50); | |
| 132 | + } | |
| 133 | + }; | |
| 134 | + AbstractChosen.prototype.input_blur = function(evt) { | |
| 135 | + if (!this.mouse_on_container) { | |
| 136 | + this.active_field = false; | |
| 137 | + return setTimeout((__bind(function() { | |
| 138 | + return this.blur_test(); | |
| 139 | + }, this)), 100); | |
| 140 | + } | |
| 141 | + }; | |
| 142 | + AbstractChosen.prototype.result_add_option = function(option) { | |
| 143 | + var classes, style; | |
| 144 | + if (!option.disabled) { | |
| 145 | + option.dom_id = this.container_id + "_o_" + option.array_index; | |
| 146 | + classes = option.selected && this.is_multiple ? [] : ["active-result"]; | |
| 147 | + if (option.selected) { | |
| 148 | + classes.push("result-selected"); | |
| 149 | + } | |
| 150 | + if (option.group_array_index != null) { | |
| 151 | + classes.push("group-option"); | |
| 152 | + } | |
| 153 | + if (option.classes !== "") { | |
| 154 | + classes.push(option.classes); | |
| 155 | + } | |
| 156 | + style = option.style.cssText !== "" ? " style=\"" + option.style + "\"" : ""; | |
| 157 | + return '<li id="' + option.dom_id + '" class="' + classes.join(' ') + '"' + style + '>' + option.html + '</li>'; | |
| 158 | + } else { | |
| 159 | + return ""; | |
| 160 | + } | |
| 161 | + }; | |
| 162 | + AbstractChosen.prototype.results_update_field = function() { | |
| 163 | + this.result_clear_highlight(); | |
| 164 | + this.result_single_selected = null; | |
| 165 | + return this.results_build(); | |
| 166 | + }; | |
| 167 | + AbstractChosen.prototype.results_toggle = function() { | |
| 168 | + if (this.results_showing) { | |
| 169 | + return this.results_hide(); | |
| 170 | + } else { | |
| 171 | + return this.results_show(); | |
| 172 | + } | |
| 173 | + }; | |
| 174 | + AbstractChosen.prototype.results_search = function(evt) { | |
| 175 | + if (this.results_showing) { | |
| 176 | + return this.winnow_results(); | |
| 177 | + } else { | |
| 178 | + return this.results_show(); | |
| 179 | + } | |
| 180 | + }; | |
| 181 | + AbstractChosen.prototype.keyup_checker = function(evt) { | |
| 182 | + var stroke, _ref; | |
| 183 | + stroke = (_ref = evt.which) != null ? _ref : evt.keyCode; | |
| 184 | + this.search_field_scale(); | |
| 185 | + switch (stroke) { | |
| 186 | + case 8: | |
| 187 | + if (this.is_multiple && this.backstroke_length < 1 && this.choices > 0) { | |
| 188 | + return this.keydown_backstroke(); | |
| 189 | + } else if (!this.pending_backstroke) { | |
| 190 | + this.result_clear_highlight(); | |
| 191 | + return this.results_search(); | |
| 192 | + } | |
| 193 | + break; | |
| 194 | + case 13: | |
| 195 | + evt.preventDefault(); | |
| 196 | + if (this.results_showing) { | |
| 197 | + return this.result_select(evt); | |
| 198 | + } | |
| 199 | + break; | |
| 200 | + case 27: | |
| 201 | + if (this.results_showing) { | |
| 202 | + return this.results_hide(); | |
| 203 | + } | |
| 204 | + break; | |
| 205 | + case 9: | |
| 206 | + case 38: | |
| 207 | + case 40: | |
| 208 | + case 16: | |
| 209 | + case 91: | |
| 210 | + case 17: | |
| 211 | + break; | |
| 212 | + default: | |
| 213 | + return this.results_search(); | |
| 214 | + } | |
| 215 | + }; | |
| 216 | + AbstractChosen.prototype.generate_field_id = function() { | |
| 217 | + var new_id; | |
| 218 | + new_id = this.generate_random_id(); | |
| 219 | + this.form_field.id = new_id; | |
| 220 | + return new_id; | |
| 221 | + }; | |
| 222 | + AbstractChosen.prototype.generate_random_char = function() { | |
| 223 | + var chars, newchar, rand; | |
| 224 | + chars = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXTZ"; | |
| 225 | + rand = Math.floor(Math.random() * chars.length); | |
| 226 | + return newchar = chars.substring(rand, rand + 1); | |
| 227 | + }; | |
| 228 | + return AbstractChosen; | |
| 229 | + })(); | |
| 230 | + root.AbstractChosen = AbstractChosen; | |
| 231 | +}).call(this); | |
| 232 | +(function() { | |
| 233 | + /* | |
| 234 | + Chosen source: generate output using 'cake build' | |
| 235 | + Copyright (c) 2011 by Harvest | |
| 236 | + */ | |
| 237 | + var $, Chosen, get_side_border_padding, root; | |
| 238 | + var __hasProp = Object.prototype.hasOwnProperty, __extends = function(child, parent) { | |
| 239 | + for (var key in parent) { if (__hasProp.call(parent, key)) child[key] = parent[key]; } | |
| 240 | + function ctor() { this.constructor = child; } | |
| 241 | + ctor.prototype = parent.prototype; | |
| 242 | + child.prototype = new ctor; | |
| 243 | + child.__super__ = parent.prototype; | |
| 244 | + return child; | |
| 245 | + }, __bind = function(fn, me){ return function(){ return fn.apply(me, arguments); }; }; | |
| 246 | + root = this; | |
| 247 | + $ = jQuery; | |
| 248 | + $.fn.extend({ | |
| 249 | + chosen: function(options) { | |
| 250 | + if ($.browser.msie && ($.browser.version === "6.0" || $.browser.version === "7.0")) { | |
| 251 | + return this; | |
| 252 | + } | |
| 253 | + return $(this).each(function(input_field) { | |
| 254 | + if (!($(this)).hasClass("chzn-done")) { | |
| 255 | + return new Chosen(this, options); | |
| 256 | + } | |
| 257 | + }); | |
| 258 | + } | |
| 259 | + }); | |
| 260 | + Chosen = (function() { | |
| 261 | + __extends(Chosen, AbstractChosen); | |
| 262 | + function Chosen() { | |
| 263 | + Chosen.__super__.constructor.apply(this, arguments); | |
| 264 | + } | |
| 265 | + Chosen.prototype.setup = function() { | |
| 266 | + this.form_field_jq = $(this.form_field); | |
| 267 | + return this.is_rtl = this.form_field_jq.hasClass("chzn-rtl"); | |
| 268 | + }; | |
| 269 | + Chosen.prototype.finish_setup = function() { | |
| 270 | + return this.form_field_jq.addClass("chzn-done"); | |
| 271 | + }; | |
| 272 | + Chosen.prototype.set_up_html = function() { | |
| 273 | + var container_div, dd_top, dd_width, sf_width; | |
| 274 | + this.container_id = this.form_field.id.length ? this.form_field.id.replace(/(:|\.)/g, '_') : this.generate_field_id(); | |
| 275 | + this.container_id += "_chzn"; | |
| 276 | + this.f_width = this.form_field_jq.outerWidth(); | |
| 277 | + this.default_text = this.form_field_jq.data('placeholder') ? this.form_field_jq.data('placeholder') : this.default_text_default; | |
| 278 | + container_div = $("<div />", { | |
| 279 | + id: this.container_id, | |
| 280 | + "class": "chzn-container" + (this.is_rtl ? ' chzn-rtl' : ''), | |
| 281 | + style: 'width: ' + this.f_width + 'px;' | |
| 282 | + }); | |
| 283 | + if (this.is_multiple) { | |
| 284 | + container_div.html('<ul class="chzn-choices"><li class="search-field"><input type="text" value="' + this.default_text + '" class="default" autocomplete="off" style="width:25px;" /></li></ul><div class="chzn-drop" style="left:-9000px;"><ul class="chzn-results"></ul></div>'); | |
| 285 | + } else { | |
| 286 | + container_div.html('<a href="javascript:void(0)" class="chzn-single"><span>' + this.default_text + '</span><div><b></b></div></a><div class="chzn-drop" style="left:-9000px;"><div class="chzn-search"><input type="text" autocomplete="off" /></div><ul class="chzn-results"></ul></div>'); | |
| 287 | + } | |
| 288 | + this.form_field_jq.hide().after(container_div); | |
| 289 | + this.container = $('#' + this.container_id); | |
| 290 | + this.container.addClass("chzn-container-" + (this.is_multiple ? "multi" : "single")); | |
| 291 | + this.dropdown = this.container.find('div.chzn-drop').first(); | |
| 292 | + dd_top = this.container.height(); | |
| 293 | + dd_width = this.f_width - get_side_border_padding(this.dropdown); | |
| 294 | + this.dropdown.css({ | |
| 295 | + "width": dd_width + "px", | |
| 296 | + "top": dd_top + "px" | |
| 297 | + }); | |
| 298 | + this.search_field = this.container.find('input').first(); | |
| 299 | + this.search_results = this.container.find('ul.chzn-results').first(); | |
| 300 | + this.search_field_scale(); | |
| 301 | + this.search_no_results = this.container.find('li.no-results').first(); | |
| 302 | + if (this.is_multiple) { | |
| 303 | + this.search_choices = this.container.find('ul.chzn-choices').first(); | |
| 304 | + this.search_container = this.container.find('li.search-field').first(); | |
| 305 | + } else { | |
| 306 | + this.search_container = this.container.find('div.chzn-search').first(); | |
| 307 | + this.selected_item = this.container.find('.chzn-single').first(); | |
| 308 | + sf_width = dd_width - get_side_border_padding(this.search_container) - get_side_border_padding(this.search_field); | |
| 309 | + this.search_field.css({ | |
| 310 | + "width": sf_width + "px" | |
| 311 | + }); | |
| 312 | + } | |
| 313 | + this.results_build(); | |
| 314 | + this.set_tab_index(); | |
| 315 | + return this.form_field_jq.trigger("liszt:ready", { | |
| 316 | + chosen: this | |
| 317 | + }); | |
| 318 | + }; | |
| 319 | + Chosen.prototype.register_observers = function() { | |
| 320 | + this.container.mousedown(__bind(function(evt) { | |
| 321 | + return this.container_mousedown(evt); | |
| 322 | + }, this)); | |
| 323 | + this.container.mouseup(__bind(function(evt) { | |
| 324 | + return this.container_mouseup(evt); | |
| 325 | + }, this)); | |
| 326 | + this.container.mouseenter(__bind(function(evt) { | |
| 327 | + return this.mouse_enter(evt); | |
| 328 | + }, this)); | |
| 329 | + this.container.mouseleave(__bind(function(evt) { | |
| 330 | + return this.mouse_leave(evt); | |
| 331 | + }, this)); | |
| 332 | + this.search_results.mouseup(__bind(function(evt) { | |
| 333 | + return this.search_results_mouseup(evt); | |
| 334 | + }, this)); | |
| 335 | + this.search_results.mouseover(__bind(function(evt) { | |
| 336 | + return this.search_results_mouseover(evt); | |
| 337 | + }, this)); | |
| 338 | + this.search_results.mouseout(__bind(function(evt) { | |
| 339 | + return this.search_results_mouseout(evt); | |
| 340 | + }, this)); | |
| 341 | + this.form_field_jq.bind("liszt:updated", __bind(function(evt) { | |
| 342 | + return this.results_update_field(evt); | |
| 343 | + }, this)); | |
| 344 | + this.search_field.blur(__bind(function(evt) { | |
| 345 | + return this.input_blur(evt); | |
| 346 | + }, this)); | |
| 347 | + this.search_field.keyup(__bind(function(evt) { | |
| 348 | + return this.keyup_checker(evt); | |
| 349 | + }, this)); | |
| 350 | + this.search_field.keydown(__bind(function(evt) { | |
| 351 | + return this.keydown_checker(evt); | |
| 352 | + }, this)); | |
| 353 | + if (this.is_multiple) { | |
| 354 | + this.search_choices.click(__bind(function(evt) { | |
| 355 | + return this.choices_click(evt); | |
| 356 | + }, this)); | |
| 357 | + return this.search_field.focus(__bind(function(evt) { | |
| 358 | + return this.input_focus(evt); | |
| 359 | + }, this)); | |
| 360 | + } | |
| 361 | + }; | |
| 362 | + Chosen.prototype.search_field_disabled = function() { | |
| 363 | + this.is_disabled = this.form_field_jq[0].disabled; | |
| 364 | + if (this.is_disabled) { | |
| 365 | + this.container.addClass('chzn-disabled'); | |
| 366 | + this.search_field[0].disabled = true; | |
| 367 | + if (!this.is_multiple) { | |
| 368 | + this.selected_item.unbind("focus", this.activate_action); | |
| 369 | + } | |
| 370 | + return this.close_field(); | |
| 371 | + } else { | |
| 372 | + this.container.removeClass('chzn-disabled'); | |
| 373 | + this.search_field[0].disabled = false; | |
| 374 | + if (!this.is_multiple) { | |
| 375 | + return this.selected_item.bind("focus", this.activate_action); | |
| 376 | + } | |
| 377 | + } | |
| 378 | + }; | |
| 379 | + Chosen.prototype.container_mousedown = function(evt) { | |
| 380 | + var target_closelink; | |
| 381 | + if (!this.is_disabled) { | |
| 382 | + target_closelink = evt != null ? ($(evt.target)).hasClass("search-choice-close") : false; | |
| 383 | + if (evt && evt.type === "mousedown") { | |
| 384 | + evt.stopPropagation(); | |
| 385 | + } | |
| 386 | + if (!this.pending_destroy_click && !target_closelink) { | |
| 387 | + if (!this.active_field) { | |
| 388 | + if (this.is_multiple) { | |
| 389 | + this.search_field.val(""); | |
| 390 | + } | |
| 391 | + $(document).click(this.click_test_action); | |
| 392 | + this.results_show(); | |
| 393 | + } else if (!this.is_multiple && evt && ($(evt.target) === this.selected_item || $(evt.target).parents("a.chzn-single").length)) { | |
| 394 | + evt.preventDefault(); | |
| 395 | + this.results_toggle(); | |
| 396 | + } | |
| 397 | + return this.activate_field(); | |
| 398 | + } else { | |
| 399 | + return this.pending_destroy_click = false; | |
| 400 | + } | |
| 401 | + } | |
| 402 | + }; | |
| 403 | + Chosen.prototype.container_mouseup = function(evt) { | |
| 404 | + if (evt.target.nodeName === "ABBR") { | |
| 405 | + return this.results_reset(evt); | |
| 406 | + } | |
| 407 | + }; | |
| 408 | + Chosen.prototype.blur_test = function(evt) { | |
| 409 | + if (!this.active_field && this.container.hasClass("chzn-container-active")) { | |
| 410 | + return this.close_field(); | |
| 411 | + } | |
| 412 | + }; | |
| 413 | + Chosen.prototype.close_field = function() { | |
| 414 | + $(document).unbind("click", this.click_test_action); | |
| 415 | + if (!this.is_multiple) { | |
| 416 | + this.selected_item.attr("tabindex", this.search_field.attr("tabindex")); | |
| 417 | + this.search_field.attr("tabindex", -1); | |
| 418 | + } | |
| 419 | + this.active_field = false; | |
| 420 | + this.results_hide(); | |
| 421 | + this.container.removeClass("chzn-container-active"); | |
| 422 | + this.winnow_results_clear(); | |
| 423 | + this.clear_backstroke(); | |
| 424 | + this.show_search_field_default(); | |
| 425 | + return this.search_field_scale(); | |
| 426 | + }; | |
| 427 | + Chosen.prototype.activate_field = function() { | |
| 428 | + if (!this.is_multiple && !this.active_field) { | |
| 429 | + this.search_field.attr("tabindex", this.selected_item.attr("tabindex")); | |
| 430 | + this.selected_item.attr("tabindex", -1); | |
| 431 | + } | |
| 432 | + this.container.addClass("chzn-container-active"); | |
| 433 | + this.active_field = true; | |
| 434 | + this.search_field.val(this.search_field.val()); | |
| 435 | + return this.search_field.focus(); | |
| 436 | + }; | |
| 437 | + Chosen.prototype.test_active_click = function(evt) { | |
| 438 | + if ($(evt.target).parents('#' + this.container_id).length) { | |
| 439 | + return this.active_field = true; | |
| 440 | + } else { | |
| 441 | + return this.close_field(); | |
| 442 | + } | |
| 443 | + }; | |
| 444 | + Chosen.prototype.results_build = function() { | |
| 445 | + var content, data, startTime, _i, _len, _ref; | |
| 446 | + startTime = new Date(); | |
| 447 | + this.parsing = true; | |
| 448 | + this.results_data = root.SelectParser.select_to_array(this.form_field); | |
| 449 | + if (this.is_multiple && this.choices > 0) { | |
| 450 | + this.search_choices.find("li.search-choice").remove(); | |
| 451 | + this.choices = 0; | |
| 452 | + } else if (!this.is_multiple) { | |
| 453 | + this.selected_item.find("span").text(this.default_text); | |
| 454 | + if (this.form_field.options.length <= this.disable_search_threshold) { | |
| 455 | + this.container.addClass("chzn-container-single-nosearch"); | |
| 456 | + } else { | |
| 457 | + this.container.removeClass("chzn-container-single-nosearch"); | |
| 458 | + } | |
| 459 | + } | |
| 460 | + content = ''; | |
| 461 | + _ref = this.results_data; | |
| 462 | + for (_i = 0, _len = _ref.length; _i < _len; _i++) { | |
| 463 | + data = _ref[_i]; | |
| 464 | + if (data.group) { | |
| 465 | + content += this.result_add_group(data); | |
| 466 | + } else if (!data.empty) { | |
| 467 | + content += this.result_add_option(data); | |
| 468 | + if (data.selected && this.is_multiple) { | |
| 469 | + this.choice_build(data); | |
| 470 | + } else if (data.selected && !this.is_multiple) { | |
| 471 | + this.selected_item.find("span").text(data.text); | |
| 472 | + if (this.allow_single_deselect) { | |
| 473 | + this.single_deselect_control_build(); | |
| 474 | + } | |
| 475 | + } | |
| 476 | + } | |
| 477 | + } | |
| 478 | + this.search_field_disabled(); | |
| 479 | + this.show_search_field_default(); | |
| 480 | + this.search_field_scale(); | |
| 481 | + this.search_results.html(content); | |
| 482 | + return this.parsing = false; | |
| 483 | + }; | |
| 484 | + Chosen.prototype.result_add_group = function(group) { | |
| 485 | + if (!group.disabled) { | |
| 486 | + group.dom_id = this.container_id + "_g_" + group.array_index; | |
| 487 | + return '<li id="' + group.dom_id + '" class="group-result">' + $("<div />").text(group.label).html() + '</li>'; | |
| 488 | + } else { | |
| 489 | + return ""; | |
| 490 | + } | |
| 491 | + }; | |
| 492 | + Chosen.prototype.result_do_highlight = function(el) { | |
| 493 | + var high_bottom, high_top, maxHeight, visible_bottom, visible_top; | |
| 494 | + if (el.length) { | |
| 495 | + this.result_clear_highlight(); | |
| 496 | + this.result_highlight = el; | |
| 497 | + this.result_highlight.addClass("highlighted"); | |
| 498 | + maxHeight = parseInt(this.search_results.css("maxHeight"), 10); | |
| 499 | + visible_top = this.search_results.scrollTop(); | |
| 500 | + visible_bottom = maxHeight + visible_top; | |
| 501 | + high_top = this.result_highlight.position().top + this.search_results.scrollTop(); | |
| 502 | + high_bottom = high_top + this.result_highlight.outerHeight(); | |
| 503 | + if (high_bottom >= visible_bottom) { | |
| 504 | + return this.search_results.scrollTop((high_bottom - maxHeight) > 0 ? high_bottom - maxHeight : 0); | |
| 505 | + } else if (high_top < visible_top) { | |
| 506 | + return this.search_results.scrollTop(high_top); | |
| 507 | + } | |
| 508 | + } | |
| 509 | + }; | |
| 510 | + Chosen.prototype.result_clear_highlight = function() { | |
| 511 | + if (this.result_highlight) { | |
| 512 | + this.result_highlight.removeClass("highlighted"); | |
| 513 | + } | |
| 514 | + return this.result_highlight = null; | |
| 515 | + }; | |
| 516 | + Chosen.prototype.results_show = function() { | |
| 517 | + var dd_top; | |
| 518 | + if (!this.is_multiple) { | |
| 519 | + this.selected_item.addClass("chzn-single-with-drop"); | |
| 520 | + if (this.result_single_selected) { | |
| 521 | + this.result_do_highlight(this.result_single_selected); | |
| 522 | + } | |
| 523 | + } | |
| 524 | + dd_top = this.is_multiple ? this.container.height() : this.container.height() - 1; | |
| 525 | + this.dropdown.css({ | |
| 526 | + "top": dd_top + "px", | |
| 527 | + "left": 0 | |
| 528 | + }); | |
| 529 | + this.results_showing = true; | |
| 530 | + this.search_field.focus(); | |
| 531 | + this.search_field.val(this.search_field.val()); | |
| 532 | + return this.winnow_results(); | |
| 533 | + }; | |
| 534 | + Chosen.prototype.results_hide = function() { | |
| 535 | + if (!this.is_multiple) { | |
| 536 | + this.selected_item.removeClass("chzn-single-with-drop"); | |
| 537 | + } | |
| 538 | + this.result_clear_highlight(); | |
| 539 | + this.dropdown.css({ | |
| 540 | + "left": "-9000px" | |
| 541 | + }); | |
| 542 | + return this.results_showing = false; | |
| 543 | + }; | |
| 544 | + Chosen.prototype.set_tab_index = function(el) { | |
| 545 | + var ti; | |
| 546 | + if (this.form_field_jq.attr("tabindex")) { | |
| 547 | + ti = this.form_field_jq.attr("tabindex"); | |
| 548 | + this.form_field_jq.attr("tabindex", -1); | |
| 549 | + if (this.is_multiple) { | |
| 550 | + return this.search_field.attr("tabindex", ti); | |
| 551 | + } else { | |
| 552 | + this.selected_item.attr("tabindex", ti); | |
| 553 | + return this.search_field.attr("tabindex", -1); | |
| 554 | + } | |
| 555 | + } | |
| 556 | + }; | |
| 557 | + Chosen.prototype.show_search_field_default = function() { | |
| 558 | + if (this.is_multiple && this.choices < 1 && !this.active_field) { | |
| 559 | + this.search_field.val(this.default_text); | |
| 560 | + return this.search_field.addClass("default"); | |
| 561 | + } else { | |
| 562 | + this.search_field.val(""); | |
| 563 | + return this.search_field.removeClass("default"); | |
| 564 | + } | |
| 565 | + }; | |
| 566 | + Chosen.prototype.search_results_mouseup = function(evt) { | |
| 567 | + var target; | |
| 568 | + target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first(); | |
| 569 | + if (target.length) { | |
| 570 | + this.result_highlight = target; | |
| 571 | + return this.result_select(evt); | |
| 572 | + } | |
| 573 | + }; | |
| 574 | + Chosen.prototype.search_results_mouseover = function(evt) { | |
| 575 | + var target; | |
| 576 | + target = $(evt.target).hasClass("active-result") ? $(evt.target) : $(evt.target).parents(".active-result").first(); | |
| 577 | + if (target) { | |
| 578 | + return this.result_do_highlight(target); | |
| 579 | + } | |
| 580 | + }; | |
| 581 | + Chosen.prototype.search_results_mouseout = function(evt) { | |
| 582 | + if ($(evt.target).hasClass("active-result" || $(evt.target).parents('.active-result').first())) { | |
| 583 | + return this.result_clear_highlight(); | |
| 584 | + } | |
| 585 | + }; | |
| 586 | + Chosen.prototype.choices_click = function(evt) { | |
| 587 | + evt.preventDefault(); | |
| 588 | + if (this.active_field && !($(evt.target).hasClass("search-choice" || $(evt.target).parents('.search-choice').first)) && !this.results_showing) { | |
| 589 | + return this.results_show(); | |
| 590 | + } | |
| 591 | + }; | |
| 592 | + Chosen.prototype.choice_build = function(item) { | |
| 593 | + var choice_id, link; | |
| 594 | + choice_id = this.container_id + "_c_" + item.array_index; | |
| 595 | + this.choices += 1; | |
| 596 | + this.search_container.before('<li class="search-choice" id="' + choice_id + '"><span>' + item.html + '</span><a href="javascript:void(0)" class="search-choice-close" rel="' + item.array_index + '"></a></li>'); | |
| 597 | + link = $('#' + choice_id).find("a").first(); | |
| 598 | + return link.click(__bind(function(evt) { | |
| 599 | + return this.choice_destroy_link_click(evt); | |
| 600 | + }, this)); | |
| 601 | + }; | |
| 602 | + Chosen.prototype.choice_destroy_link_click = function(evt) { | |
| 603 | + evt.preventDefault(); | |
| 604 | + if (!this.is_disabled) { | |
| 605 | + this.pending_destroy_click = true; | |
| 606 | + return this.choice_destroy($(evt.target)); | |
| 607 | + } else { | |
| 608 | + return evt.stopPropagation; | |
| 609 | + } | |
| 610 | + }; | |
| 611 | + Chosen.prototype.choice_destroy = function(link) { | |
| 612 | + this.choices -= 1; | |
| 613 | + this.show_search_field_default(); | |
| 614 | + if (this.is_multiple && this.choices > 0 && this.search_field.val().length < 1) { | |
| 615 | + this.results_hide(); | |
| 616 | + } | |
| 617 | + this.result_deselect(link.attr("rel")); | |
| 618 | + return link.parents('li').first().remove(); | |
| 619 | + }; | |
| 620 | + Chosen.prototype.results_reset = function(evt) { | |
| 621 | + this.form_field.options[0].selected = true; | |
| 622 | + this.selected_item.find("span").text(this.default_text); | |
| 623 | + this.show_search_field_default(); | |
| 624 | + $(evt.target).remove(); | |
| 625 | + this.form_field_jq.trigger("change"); | |
| 626 | + if (this.active_field) { | |
| 627 | + return this.results_hide(); | |
| 628 | + } | |
| 629 | + }; | |
| 630 | + Chosen.prototype.result_select = function(evt) { | |
| 631 | + var high, high_id, item, position; | |
| 632 | + if (this.result_highlight) { | |
| 633 | + high = this.result_highlight; | |
| 634 | + high_id = high.attr("id"); | |
| 635 | + this.result_clear_highlight(); | |
| 636 | + if (this.is_multiple) { | |
| 637 | + this.result_deactivate(high); | |
| 638 | + } else { | |
| 639 | + this.search_results.find(".result-selected").removeClass("result-selected"); | |
| 640 | + this.result_single_selected = high; | |
| 641 | + } | |
| 642 | + high.addClass("result-selected"); | |
| 643 | + position = high_id.substr(high_id.lastIndexOf("_") + 1); | |
| 644 | + item = this.results_data[position]; | |
| 645 | + item.selected = true; | |
| 646 | + this.form_field.options[item.options_index].selected = true; | |
| 647 | + if (this.is_multiple) { | |
| 648 | + this.choice_build(item); | |
| 649 | + } else { | |
| 650 | + this.selected_item.find("span").first().text(item.text); | |
| 651 | + if (this.allow_single_deselect) { | |
| 652 | + this.single_deselect_control_build(); | |
| 653 | + } | |
| 654 | + } | |
| 655 | + if (!(evt.metaKey && this.is_multiple)) { | |
| 656 | + this.results_hide(); | |
| 657 | + } | |
| 658 | + this.search_field.val(""); | |
| 659 | + this.form_field_jq.trigger("change"); | |
| 660 | + return this.search_field_scale(); | |
| 661 | + } | |
| 662 | + }; | |
| 663 | + Chosen.prototype.result_activate = function(el) { | |
| 664 | + return el.addClass("active-result"); | |
| 665 | + }; | |
| 666 | + Chosen.prototype.result_deactivate = function(el) { | |
| 667 | + return el.removeClass("active-result"); | |
| 668 | + }; | |
| 669 | + Chosen.prototype.result_deselect = function(pos) { | |
| 670 | + var result, result_data; | |
| 671 | + result_data = this.results_data[pos]; | |
| 672 | + result_data.selected = false; | |
| 673 | + this.form_field.options[result_data.options_index].selected = false; | |
| 674 | + result = $("#" + this.container_id + "_o_" + pos); | |
| 675 | + result.removeClass("result-selected").addClass("active-result").show(); | |
| 676 | + this.result_clear_highlight(); | |
| 677 | + this.winnow_results(); | |
| 678 | + this.form_field_jq.trigger("change"); | |
| 679 | + return this.search_field_scale(); | |
| 680 | + }; | |
| 681 | + Chosen.prototype.single_deselect_control_build = function() { | |
| 682 | + if (this.allow_single_deselect && this.selected_item.find("abbr").length < 1) { | |
| 683 | + return this.selected_item.find("span").first().after("<abbr class=\"search-choice-close\"></abbr>"); | |
| 684 | + } | |
| 685 | + }; | |
| 686 | + Chosen.prototype.winnow_results = function() { | |
| 687 | + var found, option, part, parts, regex, result_id, results, searchText, startTime, startpos, text, zregex, _i, _j, _len, _len2, _ref; | |
| 688 | + startTime = new Date(); | |
| 689 | + this.no_results_clear(); | |
| 690 | + results = 0; | |
| 691 | + searchText = this.search_field.val() === this.default_text ? "" : $('<div/>').text($.trim(this.search_field.val())).html(); | |
| 692 | + regex = new RegExp('^' + searchText.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&"), 'i'); | |
| 693 | + zregex = new RegExp(searchText.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, "\\$&"), 'i'); | |
| 694 | + _ref = this.results_data; | |
| 695 | + for (_i = 0, _len = _ref.length; _i < _len; _i++) { | |
| 696 | + option = _ref[_i]; | |
| 697 | + if (!option.disabled && !option.empty) { | |
| 698 | + if (option.group) { | |
| 699 | + $('#' + option.dom_id).hide(); | |
| 700 | + } else if (!(this.is_multiple && option.selected)) { | |
| 701 | + found = false; | |
| 702 | + result_id = option.dom_id; | |
| 703 | + if (regex.test(option.html)) { | |
| 704 | + found = true; | |
| 705 | + results += 1; | |
| 706 | + } else if (option.html.indexOf(" ") >= 0 || option.html.indexOf("[") === 0) { | |
| 707 | + parts = option.html.replace(/\[|\]/g, "").split(" "); | |
| 708 | + if (parts.length) { | |
| 709 | + for (_j = 0, _len2 = parts.length; _j < _len2; _j++) { | |
| 710 | + part = parts[_j]; | |
| 711 | + if (regex.test(part)) { | |
| 712 | + found = true; | |
| 713 | + results += 1; | |
| 714 | + } | |
| 715 | + } | |
| 716 | + } | |
| 717 | + } | |
| 718 | + if (found) { | |
| 719 | + if (searchText.length) { | |
| 720 | + startpos = option.html.search(zregex); | |
| 721 | + text = option.html.substr(0, startpos + searchText.length) + '</em>' + option.html.substr(startpos + searchText.length); | |
| 722 | + text = text.substr(0, startpos) + '<em>' + text.substr(startpos); | |
| 723 | + } else { | |
| 724 | + text = option.html; | |
| 725 | + } | |
| 726 | + if ($("#" + result_id).html !== text) { | |
| 727 | + $("#" + result_id).html(text); | |
| 728 | + } | |
| 729 | + this.result_activate($("#" + result_id)); | |
| 730 | + if (option.group_array_index != null) { | |
| 731 | + $("#" + this.results_data[option.group_array_index].dom_id).show(); | |
| 732 | + } | |
| 733 | + } else { | |
| 734 | + if (this.result_highlight && result_id === this.result_highlight.attr('id')) { | |
| 735 | + this.result_clear_highlight(); | |
| 736 | + } | |
| 737 | + this.result_deactivate($("#" + result_id)); | |
| 738 | + } | |
| 739 | + } | |
| 740 | + } | |
| 741 | + } | |
| 742 | + if (results < 1 && searchText.length) { | |
| 743 | + return this.no_results(searchText); | |
| 744 | + } else { | |
| 745 | + return this.winnow_results_set_highlight(); | |
| 746 | + } | |
| 747 | + }; | |
| 748 | + Chosen.prototype.winnow_results_clear = function() { | |
| 749 | + var li, lis, _i, _len, _results; | |
| 750 | + this.search_field.val(""); | |
| 751 | + lis = this.search_results.find("li"); | |
| 752 | + _results = []; | |
| 753 | + for (_i = 0, _len = lis.length; _i < _len; _i++) { | |
| 754 | + li = lis[_i]; | |
| 755 | + li = $(li); | |
| 756 | + _results.push(li.hasClass("group-result") ? li.show() : !this.is_multiple || !li.hasClass("result-selected") ? this.result_activate(li) : void 0); | |
| 757 | + } | |
| 758 | + return _results; | |
| 759 | + }; | |
| 760 | + Chosen.prototype.winnow_results_set_highlight = function() { | |
| 761 | + var do_high, selected_results; | |
| 762 | + if (!this.result_highlight) { | |
| 763 | + selected_results = !this.is_multiple ? this.search_results.find(".result-selected.active-result") : []; | |
| 764 | + do_high = selected_results.length ? selected_results.first() : this.search_results.find(".active-result").first(); | |
| 765 | + if (do_high != null) { | |
| 766 | + return this.result_do_highlight(do_high); | |
| 767 | + } | |
| 768 | + } | |
| 769 | + }; | |
| 770 | + Chosen.prototype.no_results = function(terms) { | |
| 771 | + var no_results_html; | |
| 772 | + no_results_html = $('<li class="no-results">' + this.results_none_found + ' "<span></span>"</li>'); | |
| 773 | + no_results_html.find("span").first().html(terms); | |
| 774 | + return this.search_results.append(no_results_html); | |
| 775 | + }; | |
| 776 | + Chosen.prototype.no_results_clear = function() { | |
| 777 | + return this.search_results.find(".no-results").remove(); | |
| 778 | + }; | |
| 779 | + Chosen.prototype.keydown_arrow = function() { | |
| 780 | + var first_active, next_sib; | |
| 781 | + if (!this.result_highlight) { | |
| 782 | + first_active = this.search_results.find("li.active-result").first(); | |
| 783 | + if (first_active) { | |
| 784 | + this.result_do_highlight($(first_active)); | |
| 785 | + } | |
| 786 | + } else if (this.results_showing) { | |
| 787 | + next_sib = this.result_highlight.nextAll("li.active-result").first(); | |
| 788 | + if (next_sib) { | |
| 789 | + this.result_do_highlight(next_sib); | |
| 790 | + } | |
| 791 | + } | |
| 792 | + if (!this.results_showing) { | |
| 793 | + return this.results_show(); | |
| 794 | + } | |
| 795 | + }; | |
| 796 | + Chosen.prototype.keyup_arrow = function() { | |
| 797 | + var prev_sibs; | |
| 798 | + if (!this.results_showing && !this.is_multiple) { | |
| 799 | + return this.results_show(); | |
| 800 | + } else if (this.result_highlight) { | |
| 801 | + prev_sibs = this.result_highlight.prevAll("li.active-result"); | |
| 802 | + if (prev_sibs.length) { | |
| 803 | + return this.result_do_highlight(prev_sibs.first()); | |
| 804 | + } else { | |
| 805 | + if (this.choices > 0) { | |
| 806 | + this.results_hide(); | |
| 807 | + } | |
| 808 | + return this.result_clear_highlight(); | |
| 809 | + } | |
| 810 | + } | |
| 811 | + }; | |
| 812 | + Chosen.prototype.keydown_backstroke = function() { | |
| 813 | + if (this.pending_backstroke) { | |
| 814 | + this.choice_destroy(this.pending_backstroke.find("a").first()); | |
| 815 | + return this.clear_backstroke(); | |
| 816 | + } else { | |
| 817 | + this.pending_backstroke = this.search_container.siblings("li.search-choice").last(); | |
| 818 | + return this.pending_backstroke.addClass("search-choice-focus"); | |
| 819 | + } | |
| 820 | + }; | |
| 821 | + Chosen.prototype.clear_backstroke = function() { | |
| 822 | + if (this.pending_backstroke) { | |
| 823 | + this.pending_backstroke.removeClass("search-choice-focus"); | |
| 824 | + } | |
| 825 | + return this.pending_backstroke = null; | |
| 826 | + }; | |
| 827 | + Chosen.prototype.keydown_checker = function(evt) { | |
| 828 | + var stroke, _ref; | |
| 829 | + stroke = (_ref = evt.which) != null ? _ref : evt.keyCode; | |
| 830 | + this.search_field_scale(); | |
| 831 | + if (stroke !== 8 && this.pending_backstroke) { | |
| 832 | + this.clear_backstroke(); | |
| 833 | + } | |
| 834 | + switch (stroke) { | |
| 835 | + case 8: | |
| 836 | + this.backstroke_length = this.search_field.val().length; | |
| 837 | + break; | |
| 838 | + case 9: | |
| 839 | + if (this.results_showing && !this.is_multiple) { | |
| 840 | + this.result_select(evt); | |
| 841 | + } | |
| 842 | + this.mouse_on_container = false; | |
| 843 | + break; | |
| 844 | + case 13: | |
| 845 | + evt.preventDefault(); | |
| 846 | + break; | |
| 847 | + case 38: | |
| 848 | + evt.preventDefault(); | |
| 849 | + this.keyup_arrow(); | |
| 850 | + break; | |
| 851 | + case 40: | |
| 852 | + this.keydown_arrow(); | |
| 853 | + break; | |
| 854 | + } | |
| 855 | + }; | |
| 856 | + Chosen.prototype.search_field_scale = function() { | |
| 857 | + var dd_top, div, h, style, style_block, styles, w, _i, _len; | |
| 858 | + if (this.is_multiple) { | |
| 859 | + h = 0; | |
| 860 | + w = 0; | |
| 861 | + style_block = "position:absolute; left: -1000px; top: -1000px; display:none;"; | |
| 862 | + styles = ['font-size', 'font-style', 'font-weight', 'font-family', 'line-height', 'text-transform', 'letter-spacing']; | |
| 863 | + for (_i = 0, _len = styles.length; _i < _len; _i++) { | |
| 864 | + style = styles[_i]; | |
| 865 | + style_block += style + ":" + this.search_field.css(style) + ";"; | |
| 866 | + } | |
| 867 | + div = $('<div />', { | |
| 868 | + 'style': style_block | |
| 869 | + }); | |
| 870 | + div.text(this.search_field.val()); | |
| 871 | + $('body').append(div); | |
| 872 | + w = div.width() + 25; | |
| 873 | + div.remove(); | |
| 874 | + if (w > this.f_width - 10) { | |
| 875 | + w = this.f_width - 10; | |
| 876 | + } | |
| 877 | + this.search_field.css({ | |
| 878 | + 'width': w + 'px' | |
| 879 | + }); | |
| 880 | + dd_top = this.container.height(); | |
| 881 | + return this.dropdown.css({ | |
| 882 | + "top": dd_top + "px" | |
| 883 | + }); | |
| 884 | + } | |
| 885 | + }; | |
| 886 | + Chosen.prototype.generate_random_id = function() { | |
| 887 | + var string; | |
| 888 | + string = "sel" + this.generate_random_char() + this.generate_random_char() + this.generate_random_char(); | |
| 889 | + while ($("#" + string).length > 0) { | |
| 890 | + string += this.generate_random_char(); | |
| 891 | + } | |
| 892 | + return string; | |
| 893 | + }; | |
| 894 | + return Chosen; | |
| 895 | + })(); | |
| 896 | + get_side_border_padding = function(elmt) { | |
| 897 | + var side_border_padding; | |
| 898 | + return side_border_padding = elmt.outerWidth() - elmt.width(); | |
| 899 | + }; | |
| 900 | + root.get_side_border_padding = get_side_border_padding; | |
| 901 | +}).call(this); | ... | ... |
app/assets/javascripts/commits.js
| ... | ... | @@ -7,3 +7,51 @@ $(document).ready(function(){ |
| 7 | 7 | } |
| 8 | 8 | }); |
| 9 | 9 | }); |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | +var CommitsList = { | |
| 14 | + | |
| 15 | +ref:null, | |
| 16 | +limit:0, | |
| 17 | +offset:0, | |
| 18 | + | |
| 19 | +init: | |
| 20 | + function(ref, limit) { | |
| 21 | + this.ref=ref; | |
| 22 | + this.limit=limit; | |
| 23 | + this.offset=limit; | |
| 24 | + this.initLoadMore(); | |
| 25 | + $('.loading').show(); | |
| 26 | + }, | |
| 27 | + | |
| 28 | +getOld: | |
| 29 | + function() { | |
| 30 | + $('.loading').show(); | |
| 31 | + $.ajax({ | |
| 32 | + type: "GET", | |
| 33 | + url: location.href, | |
| 34 | + data: "limit=" + this.limit + "&offset=" + this.offset + "&ref=" + this.ref, | |
| 35 | + complete: function(){ $('.loading').hide()}, | |
| 36 | + dataType: "script"}); | |
| 37 | + }, | |
| 38 | + | |
| 39 | +append: | |
| 40 | + function(count, html) { | |
| 41 | + $("#commits_list").append(html); | |
| 42 | + if(count > 0) { | |
| 43 | + this.offset += count; | |
| 44 | + this.initLoadMore(); | |
| 45 | + } | |
| 46 | + }, | |
| 47 | + | |
| 48 | +initLoadMore: | |
| 49 | + function() { | |
| 50 | + $(window).bind('scroll', function(){ | |
| 51 | + if($(window).scrollTop() == $(document).height() - $(window).height()){ | |
| 52 | + $(window).unbind('scroll'); | |
| 53 | + CommitsList.getOld(); | |
| 54 | + } | |
| 55 | + }); | |
| 56 | + } | |
| 57 | +} | ... | ... |
| ... | ... | @@ -0,0 +1,4 @@ |
| 1 | +/* Modernizr 2.0.6 | MIT & BSD | |
| 2 | + * Contains: All core tests, html5shiv, yepnope, respond.js. Get your own custom build at www.modernizr.com/download/ | |
| 3 | + */ | |
| 4 | +;window.Modernizr=function(a,b,c){function I(){e.input=function(a){for(var b=0,c=a.length;b<c;b++)t[a[b]]=a[b]in l;return t}("autocomplete autofocus list placeholder max min multiple pattern required step".split(" ")),e.inputtypes=function(a){for(var d=0,e,f,h,i=a.length;d<i;d++)l.setAttribute("type",f=a[d]),e=l.type!=="text",e&&(l.value=m,l.style.cssText="position:absolute;visibility:hidden;",/^range$/.test(f)&&l.style.WebkitAppearance!==c?(g.appendChild(l),h=b.defaultView,e=h.getComputedStyle&&h.getComputedStyle(l,null).WebkitAppearance!=="textfield"&&l.offsetHeight!==0,g.removeChild(l)):/^(search|tel)$/.test(f)||(/^(url|email)$/.test(f)?e=l.checkValidity&&l.checkValidity()===!1:/^color$/.test(f)?(g.appendChild(l),g.offsetWidth,e=l.value!=m,g.removeChild(l)):e=l.value!=m)),s[a[d]]=!!e;return s}("search tel url email datetime date month week time datetime-local number range color".split(" "))}function G(a,b){var c=a.charAt(0).toUpperCase()+a.substr(1),d=(a+" "+p.join(c+" ")+c).split(" ");return F(d,b)}function F(a,b){for(var d in a)if(k[a[d]]!==c)return b=="pfx"?a[d]:!0;return!1}function E(a,b){return!!~(""+a).indexOf(b)}function D(a,b){return typeof a===b}function C(a,b){return B(o.join(a+";")+(b||""))}function B(a){k.cssText=a}var d="2.0.6",e={},f=!0,g=b.documentElement,h=b.head||b.getElementsByTagName("head")[0],i="modernizr",j=b.createElement(i),k=j.style,l=b.createElement("input"),m=":)",n=Object.prototype.toString,o=" -webkit- -moz- -o- -ms- -khtml- ".split(" "),p="Webkit Moz O ms Khtml".split(" "),q={svg:"http://www.w3.org/2000/svg"},r={},s={},t={},u=[],v=function(a,c,d,e){var f,h,j,k=b.createElement("div");if(parseInt(d,10))while(d--)j=b.createElement("div"),j.id=e?e[d]:i+(d+1),k.appendChild(j);f=["­","<style>",a,"</style>"].join(""),k.id=i,k.innerHTML+=f,g.appendChild(k),h=c(k,a),k.parentNode.removeChild(k);return!!h},w=function(b){if(a.matchMedia)return matchMedia(b).matches;var c;v("@media "+b+" { #"+i+" { position: absolute; } }",function(b){c=(a.getComputedStyle?getComputedStyle(b,null):b.currentStyle).position=="absolute"});return c},x=function(){function d(d,e){e=e||b.createElement(a[d]||"div"),d="on"+d;var f=d in e;f||(e.setAttribute||(e=b.createElement("div")),e.setAttribute&&e.removeAttribute&&(e.setAttribute(d,""),f=D(e[d],"function"),D(e[d],c)||(e[d]=c),e.removeAttribute(d))),e=null;return f}var a={select:"input",change:"input",submit:"form",reset:"form",error:"img",load:"img",abort:"img"};return d}(),y,z={}.hasOwnProperty,A;!D(z,c)&&!D(z.call,c)?A=function(a,b){return z.call(a,b)}:A=function(a,b){return b in a&&D(a.constructor.prototype[b],c)};var H=function(c,d){var f=c.join(""),g=d.length;v(f,function(c,d){var f=b.styleSheets[b.styleSheets.length-1],h=f.cssRules&&f.cssRules[0]?f.cssRules[0].cssText:f.cssText||"",i=c.childNodes,j={};while(g--)j[i[g].id]=i[g];e.touch="ontouchstart"in a||j.touch.offsetTop===9,e.csstransforms3d=j.csstransforms3d.offsetLeft===9,e.generatedcontent=j.generatedcontent.offsetHeight>=1,e.fontface=/src/i.test(h)&&h.indexOf(d.split(" ")[0])===0},g,d)}(['@font-face {font-family:"font";src:url("https://")}',["@media (",o.join("touch-enabled),("),i,")","{#touch{top:9px;position:absolute}}"].join(""),["@media (",o.join("transform-3d),("),i,")","{#csstransforms3d{left:9px;position:absolute}}"].join(""),['#generatedcontent:after{content:"',m,'";visibility:hidden}'].join("")],["fontface","touch","csstransforms3d","generatedcontent"]);r.flexbox=function(){function c(a,b,c,d){a.style.cssText=o.join(b+":"+c+";")+(d||"")}function a(a,b,c,d){b+=":",a.style.cssText=(b+o.join(c+";"+b)).slice(0,-b.length)+(d||"")}var d=b.createElement("div"),e=b.createElement("div");a(d,"display","box","width:42px;padding:0;"),c(e,"box-flex","1","width:10px;"),d.appendChild(e),g.appendChild(d);var f=e.offsetWidth===42;d.removeChild(e),g.removeChild(d);return f},r.canvas=function(){var a=b.createElement("canvas");return!!a.getContext&&!!a.getContext("2d")},r.canvastext=function(){return!!e.canvas&&!!D(b.createElement("canvas").getContext("2d").fillText,"function")},r.webgl=function(){return!!a.WebGLRenderingContext},r.touch=function(){return e.touch},r.geolocation=function(){return!!navigator.geolocation},r.postmessage=function(){return!!a.postMessage},r.websqldatabase=function(){var b=!!a.openDatabase;return b},r.indexedDB=function(){for(var b=-1,c=p.length;++b<c;)if(a[p[b].toLowerCase()+"IndexedDB"])return!0;return!!a.indexedDB},r.hashchange=function(){return x("hashchange",a)&&(b.documentMode===c||b.documentMode>7)},r.history=function(){return!!a.history&&!!history.pushState},r.draganddrop=function(){return x("dragstart")&&x("drop")},r.websockets=function(){for(var b=-1,c=p.length;++b<c;)if(a[p[b]+"WebSocket"])return!0;return"WebSocket"in a},r.rgba=function(){B("background-color:rgba(150,255,150,.5)");return E(k.backgroundColor,"rgba")},r.hsla=function(){B("background-color:hsla(120,40%,100%,.5)");return E(k.backgroundColor,"rgba")||E(k.backgroundColor,"hsla")},r.multiplebgs=function(){B("background:url(https://),url(https://),red url(https://)");return/(url\s*\(.*?){3}/.test(k.background)},r.backgroundsize=function(){return G("backgroundSize")},r.borderimage=function(){return G("borderImage")},r.borderradius=function(){return G("borderRadius")},r.boxshadow=function(){return G("boxShadow")},r.textshadow=function(){return b.createElement("div").style.textShadow===""},r.opacity=function(){C("opacity:.55");return/^0.55$/.test(k.opacity)},r.cssanimations=function(){return G("animationName")},r.csscolumns=function(){return G("columnCount")},r.cssgradients=function(){var a="background-image:",b="gradient(linear,left top,right bottom,from(#9f9),to(white));",c="linear-gradient(left top,#9f9, white);";B((a+o.join(b+a)+o.join(c+a)).slice(0,-a.length));return E(k.backgroundImage,"gradient")},r.cssreflections=function(){return G("boxReflect")},r.csstransforms=function(){return!!F(["transformProperty","WebkitTransform","MozTransform","OTransform","msTransform"])},r.csstransforms3d=function(){var a=!!F(["perspectiveProperty","WebkitPerspective","MozPerspective","OPerspective","msPerspective"]);a&&"webkitPerspective"in g.style&&(a=e.csstransforms3d);return a},r.csstransitions=function(){return G("transitionProperty")},r.fontface=function(){return e.fontface},r.generatedcontent=function(){return e.generatedcontent},r.video=function(){var a=b.createElement("video"),c=!1;try{if(c=!!a.canPlayType){c=new Boolean(c),c.ogg=a.canPlayType('video/ogg; codecs="theora"');var d='video/mp4; codecs="avc1.42E01E';c.h264=a.canPlayType(d+'"')||a.canPlayType(d+', mp4a.40.2"'),c.webm=a.canPlayType('video/webm; codecs="vp8, vorbis"')}}catch(e){}return c},r.audio=function(){var a=b.createElement("audio"),c=!1;try{if(c=!!a.canPlayType)c=new Boolean(c),c.ogg=a.canPlayType('audio/ogg; codecs="vorbis"'),c.mp3=a.canPlayType("audio/mpeg;"),c.wav=a.canPlayType('audio/wav; codecs="1"'),c.m4a=a.canPlayType("audio/x-m4a;")||a.canPlayType("audio/aac;")}catch(d){}return c},r.localstorage=function(){try{return!!localStorage.getItem}catch(a){return!1}},r.sessionstorage=function(){try{return!!sessionStorage.getItem}catch(a){return!1}},r.webworkers=function(){return!!a.Worker},r.applicationcache=function(){return!!a.applicationCache},r.svg=function(){return!!b.createElementNS&&!!b.createElementNS(q.svg,"svg").createSVGRect},r.inlinesvg=function(){var a=b.createElement("div");a.innerHTML="<svg/>";return(a.firstChild&&a.firstChild.namespaceURI)==q.svg},r.smil=function(){return!!b.createElementNS&&/SVG/.test(n.call(b.createElementNS(q.svg,"animate")))},r.svgclippaths=function(){return!!b.createElementNS&&/SVG/.test(n.call(b.createElementNS(q.svg,"clipPath")))};for(var J in r)A(r,J)&&(y=J.toLowerCase(),e[y]=r[J](),u.push((e[y]?"":"no-")+y));e.input||I(),e.addTest=function(a,b){if(typeof a=="object")for(var d in a)A(a,d)&&e.addTest(d,a[d]);else{a=a.toLowerCase();if(e[a]!==c)return;b=typeof b=="boolean"?b:!!b(),g.className+=" "+(b?"":"no-")+a,e[a]=b}return e},B(""),j=l=null,a.attachEvent&&function(){var a=b.createElement("div");a.innerHTML="<elem></elem>";return a.childNodes.length!==1}()&&function(a,b){function s(a){var b=-1;while(++b<g)a.createElement(f[b])}a.iepp=a.iepp||{};var d=a.iepp,e=d.html5elements||"abbr|article|aside|audio|canvas|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",f=e.split("|"),g=f.length,h=new RegExp("(^|\\s)("+e+")","gi"),i=new RegExp("<(/*)("+e+")","gi"),j=/^\s*[\{\}]\s*$/,k=new RegExp("(^|[^\\n]*?\\s)("+e+")([^\\n]*)({[\\n\\w\\W]*?})","gi"),l=b.createDocumentFragment(),m=b.documentElement,n=m.firstChild,o=b.createElement("body"),p=b.createElement("style"),q=/print|all/,r;d.getCSS=function(a,b){if(a+""===c)return"";var e=-1,f=a.length,g,h=[];while(++e<f){g=a[e];if(g.disabled)continue;b=g.media||b,q.test(b)&&h.push(d.getCSS(g.imports,b),g.cssText),b="all"}return h.join("")},d.parseCSS=function(a){var b=[],c;while((c=k.exec(a))!=null)b.push(((j.exec(c[1])?"\n":c[1])+c[2]+c[3]).replace(h,"$1.iepp_$2")+c[4]);return b.join("\n")},d.writeHTML=function(){var a=-1;r=r||b.body;while(++a<g){var c=b.getElementsByTagName(f[a]),d=c.length,e=-1;while(++e<d)c[e].className.indexOf("iepp_")<0&&(c[e].className+=" iepp_"+f[a])}l.appendChild(r),m.appendChild(o),o.className=r.className,o.id=r.id,o.innerHTML=r.innerHTML.replace(i,"<$1font")},d._beforePrint=function(){p.styleSheet.cssText=d.parseCSS(d.getCSS(b.styleSheets,"all")),d.writeHTML()},d.restoreHTML=function(){o.innerHTML="",m.removeChild(o),m.appendChild(r)},d._afterPrint=function(){d.restoreHTML(),p.styleSheet.cssText=""},s(b),s(l);d.disablePP||(n.insertBefore(p,n.firstChild),p.media="print",p.className="iepp-printshim",a.attachEvent("onbeforeprint",d._beforePrint),a.attachEvent("onafterprint",d._afterPrint))}(a,b),e._version=d,e._prefixes=o,e._domPrefixes=p,e.mq=w,e.hasEvent=x,e.testProp=function(a){return F([a])},e.testAllProps=G,e.testStyles=v,e.prefixed=function(a){return G(a,"pfx")},g.className=g.className.replace(/\bno-js\b/,"")+(f?" js "+u.join(" "):"");return e}(this,this.document),function(a,b){function u(){r(!0)}a.respond={},respond.update=function(){},respond.mediaQueriesSupported=b;if(!b){var c=a.document,d=c.documentElement,e=[],f=[],g=[],h={},i=30,j=c.getElementsByTagName("head")[0]||d,k=j.getElementsByTagName("link"),l=[],m=function(){var b=k,c=b.length,d=0,e,f,g,i;for(;d<c;d++)e=b[d],f=e.href,g=e.media,i=e.rel&&e.rel.toLowerCase()==="stylesheet",!!f&&i&&!h[f]&&(!/^([a-zA-Z]+?:(\/\/)?(www\.)?)/.test(f)||f.replace(RegExp.$1,"").split("/")[0]===a.location.host?l.push({href:f,media:g}):h[f]=!0);n()},n=function(){if(l.length){var a=l.shift();s(a.href,function(b){o(b,a.href,a.media),h[a.href]=!0,n()})}},o=function(a,b,c){var d=a.match(/@media[^\{]+\{([^\{\}]+\{[^\}\{]+\})+/gi),g=d&&d.length||0,b=b.substring(0,b.lastIndexOf("/")),h=function(a){return a.replace(/(url\()['"]?([^\/\)'"][^:\)'"]+)['"]?(\))/g,"$1"+b+"$2$3")},i=!g&&c,j=0,k,l,m,n,o;b.length&&(b+="/"),i&&(g=1);for(;j<g;j++){k=0,i?(l=c,f.push(h(a))):(l=d[j].match(/@media ([^\{]+)\{([\S\s]+?)$/)&&RegExp.$1,f.push(RegExp.$2&&h(RegExp.$2))),n=l.split(","),o=n.length;for(;k<o;k++)m=n[k],e.push({media:m.match(/(only\s+)?([a-zA-Z]+)(\sand)?/)&&RegExp.$2,rules:f.length-1,minw:m.match(/\(min\-width:[\s]*([\s]*[0-9]+)px[\s]*\)/)&&parseFloat(RegExp.$1),maxw:m.match(/\(max\-width:[\s]*([\s]*[0-9]+)px[\s]*\)/)&&parseFloat(RegExp.$1)})}r()},p,q,r=function(a){var b="clientWidth",h=d[b],l=c.compatMode==="CSS1Compat"&&h||c.body[b]||h,m={},n=c.createDocumentFragment(),o=k[k.length-1],s=(new Date).getTime();if(a&&p&&s-p<i)clearTimeout(q),q=setTimeout(r,i);else{p=s;for(var t in e){var u=e[t];if(!u.minw&&!u.maxw||(!u.minw||u.minw&&l>=u.minw)&&(!u.maxw||u.maxw&&l<=u.maxw))m[u.media]||(m[u.media]=[]),m[u.media].push(f[u.rules])}for(var t in g)g[t]&&g[t].parentNode===j&&j.removeChild(g[t]);for(var t in m){var v=c.createElement("style"),w=m[t].join("\n");v.type="text/css",v.media=t,v.styleSheet?v.styleSheet.cssText=w:v.appendChild(c.createTextNode(w)),n.appendChild(v),g.push(v)}j.insertBefore(n,o.nextSibling)}},s=function(a,b){var c=t();if(!!c){c.open("GET",a,!0),c.onreadystatechange=function(){c.readyState==4&&(c.status==200||c.status==304)&&b(c.responseText)};if(c.readyState==4)return;c.send()}},t=function(){var a=!1,b=[function(){return new ActiveXObject("Microsoft.XMLHTTP")},function(){return new XMLHttpRequest}],c=b.length;while(c--){try{a=b[c]()}catch(d){continue}break}return function(){return a}}();m(),respond.update=m,a.addEventListener?a.addEventListener("resize",u,!1):a.attachEvent&&a.attachEvent("onresize",u)}}(this,Modernizr.mq("only all")),function(a,b,c){function k(a){return!a||a=="loaded"||a=="complete"}function j(){var a=1,b=-1;while(p.length- ++b)if(p[b].s&&!(a=p[b].r))break;a&&g()}function i(a){var c=b.createElement("script"),d;c.src=a.s,c.onreadystatechange=c.onload=function(){!d&&k(c.readyState)&&(d=1,j(),c.onload=c.onreadystatechange=null)},m(function(){d||(d=1,j())},H.errorTimeout),a.e?c.onload():n.parentNode.insertBefore(c,n)}function h(a){var c=b.createElement("link"),d;c.href=a.s,c.rel="stylesheet",c.type="text/css";if(!a.e&&(w||r)){var e=function(a){m(function(){if(!d)try{a.sheet.cssRules.length?(d=1,j()):e(a)}catch(b){b.code==1e3||b.message=="security"||b.message=="denied"?(d=1,m(function(){j()},0)):e(a)}},0)};e(c)}else c.onload=function(){d||(d=1,m(function(){j()},0))},a.e&&c.onload();m(function(){d||(d=1,j())},H.errorTimeout),!a.e&&n.parentNode.insertBefore(c,n)}function g(){var a=p.shift();q=1,a?a.t?m(function(){a.t=="c"?h(a):i(a)},0):(a(),j()):q=0}function f(a,c,d,e,f,h){function i(){!o&&k(l.readyState)&&(r.r=o=1,!q&&j(),l.onload=l.onreadystatechange=null,m(function(){u.removeChild(l)},0))}var l=b.createElement(a),o=0,r={t:d,s:c,e:h};l.src=l.data=c,!s&&(l.style.display="none"),l.width=l.height="0",a!="object"&&(l.type=d),l.onload=l.onreadystatechange=i,a=="img"?l.onerror=i:a=="script"&&(l.onerror=function(){r.e=r.r=1,g()}),p.splice(e,0,r),u.insertBefore(l,s?null:n),m(function(){o||(u.removeChild(l),r.r=r.e=o=1,j())},H.errorTimeout)}function e(a,b,c){var d=b=="c"?z:y;q=0,b=b||"j",C(a)?f(d,a,b,this.i++,l,c):(p.splice(this.i++,0,a),p.length==1&&g());return this}function d(){var a=H;a.loader={load:e,i:0};return a}var l=b.documentElement,m=a.setTimeout,n=b.getElementsByTagName("script")[0],o={}.toString,p=[],q=0,r="MozAppearance"in l.style,s=r&&!!b.createRange().compareNode,t=r&&!s,u=s?l:n.parentNode,v=a.opera&&o.call(a.opera)=="[object Opera]",w="webkitAppearance"in l.style,x=w&&"async"in b.createElement("script"),y=r?"object":v||x?"img":"script",z=w?"img":y,A=Array.isArray||function(a){return o.call(a)=="[object Array]"},B=function(a){return Object(a)===a},C=function(a){return typeof a=="string"},D=function(a){return o.call(a)=="[object Function]"},E=[],F={},G,H;H=function(a){function f(a){var b=a.split("!"),c=E.length,d=b.pop(),e=b.length,f={url:d,origUrl:d,prefixes:b},g,h;for(h=0;h<e;h++)g=F[b[h]],g&&(f=g(f));for(h=0;h<c;h++)f=E[h](f);return f}function e(a,b,e,g,h){var i=f(a),j=i.autoCallback;if(!i.bypass){b&&(b=D(b)?b:b[a]||b[g]||b[a.split("/").pop().split("?")[0]]);if(i.instead)return i.instead(a,b,e,g,h);e.load(i.url,i.forceCSS||!i.forceJS&&/css$/.test(i.url)?"c":c,i.noexec),(D(b)||D(j))&&e.load(function(){d(),b&&b(i.origUrl,h,g),j&&j(i.origUrl,h,g)})}}function b(a,b){function c(a){if(C(a))e(a,h,b,0,d);else if(B(a))for(i in a)a.hasOwnProperty(i)&&e(a[i],h,b,i,d)}var d=!!a.test,f=d?a.yep:a.nope,g=a.load||a.both,h=a.callback,i;c(f),c(g),a.complete&&b.load(a.complete)}var g,h,i=this.yepnope.loader;if(C(a))e(a,0,i,0);else if(A(a))for(g=0;g<a.length;g++)h=a[g],C(h)?e(h,0,i,0):A(h)?H(h):B(h)&&b(h,i);else B(a)&&b(a,i)},H.addPrefix=function(a,b){F[a]=b},H.addFilter=function(a){E.push(a)},H.errorTimeout=1e4,b.readyState==null&&b.addEventListener&&(b.readyState="loading",b.addEventListener("DOMContentLoaded",G=function(){b.removeEventListener("DOMContentLoaded",G,0),b.readyState="complete"},0)),a.yepnope=d()}(this,this.document),Modernizr.load=function(){yepnope.apply(window,[].slice.call(arguments,0))}; | |
| 0 | 5 | \ No newline at end of file | ... | ... |
| ... | ... | @@ -0,0 +1,87 @@ |
| 1 | +var NoteList = { | |
| 2 | + | |
| 3 | +first_id: 0, | |
| 4 | +last_id: 0, | |
| 5 | +resource_name: null, | |
| 6 | + | |
| 7 | +init: | |
| 8 | + function(resource_name, first_id, last_id) { | |
| 9 | + this.resource_name = resource_name; | |
| 10 | + this.first_id = first_id; | |
| 11 | + this.last_id = last_id; | |
| 12 | + this.initRefresh(); | |
| 13 | + this.initLoadMore(); | |
| 14 | + }, | |
| 15 | + | |
| 16 | +getOld: | |
| 17 | + function() { | |
| 18 | + $('.loading').show(); | |
| 19 | + $.ajax({ | |
| 20 | + type: "GET", | |
| 21 | + url: location.href, | |
| 22 | + data: "first_id=" + this.first_id, | |
| 23 | + complete: function(){ $('.loading').hide()}, | |
| 24 | + dataType: "script"}); | |
| 25 | + }, | |
| 26 | + | |
| 27 | +append: | |
| 28 | + function(id, html) { | |
| 29 | + this.first_id = id; | |
| 30 | + $("#notes-list").append(html); | |
| 31 | + this.initLoadMore(); | |
| 32 | + }, | |
| 33 | + | |
| 34 | +replace: | |
| 35 | + function(fid, lid, html) { | |
| 36 | + this.first_id = fid; | |
| 37 | + this.last_id = lid; | |
| 38 | + $("#notes-list").html(html); | |
| 39 | + this.initLoadMore(); | |
| 40 | + }, | |
| 41 | + | |
| 42 | + | |
| 43 | +prepend: | |
| 44 | + function(id, html) { | |
| 45 | + this.last_id = id; | |
| 46 | + $("#notes-list").prepend(html); | |
| 47 | + }, | |
| 48 | + | |
| 49 | +getNew: | |
| 50 | + function() { | |
| 51 | + // refersh notes list | |
| 52 | + $.ajax({ | |
| 53 | + type: "GET", | |
| 54 | + url: location.href, | |
| 55 | + data: "last_id=" + this.last_id, | |
| 56 | + dataType: "script"}); | |
| 57 | + }, | |
| 58 | + | |
| 59 | +refresh: | |
| 60 | + function() { | |
| 61 | + // refersh notes list | |
| 62 | + $.ajax({ | |
| 63 | + type: "GET", | |
| 64 | + url: location.href, | |
| 65 | + data: "first_id=" + this.first_id + "&last_id=" + this.last_id, | |
| 66 | + dataType: "script"}); | |
| 67 | + }, | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | +initRefresh: | |
| 72 | + function() { | |
| 73 | + // init timer | |
| 74 | + var intNew = setInterval("NoteList.getNew()", 15000); | |
| 75 | + var intRefresh = setInterval("NoteList.refresh()", 90000); | |
| 76 | + }, | |
| 77 | + | |
| 78 | +initLoadMore: | |
| 79 | + function() { | |
| 80 | + $(window).bind('scroll', function(){ | |
| 81 | + if($(window).scrollTop() == $(document).height() - $(window).height()){ | |
| 82 | + $(window).unbind('scroll'); | |
| 83 | + NoteList.getOld(); | |
| 84 | + } | |
| 85 | + }); | |
| 86 | + } | |
| 87 | +} | ... | ... |
app/assets/javascripts/projects.js
app/assets/stylesheets/application.css
| ... | ... | @@ -2,6 +2,9 @@ |
| 2 | 2 | * This is a manifest file that'll automatically include all the stylesheets available in this directory |
| 3 | 3 | * and any sub-directories. You're free to add application-wide styles to this file and they'll appear at |
| 4 | 4 | * the top of the compiled file, but it's generally better to create a new file per style scope. |
| 5 | + *= require jquery-ui/jquery-ui | |
| 6 | + *= require jquery-ui/jquery.ui.selectmenu | |
| 7 | + *= require jquery-ui/jquery.tagify | |
| 5 | 8 | *= require_self |
| 6 | - *= require_tree . | |
| 9 | + *= require_tree . | |
| 7 | 10 | */ | ... | ... |
| ... | ... | @@ -0,0 +1,367 @@ |
| 1 | +/* @group Base */ | |
| 2 | +.chzn-container { | |
| 3 | + font-size: 13px; | |
| 4 | + position: relative; | |
| 5 | + display: inline-block; | |
| 6 | + zoom: 1; | |
| 7 | + *display: inline; | |
| 8 | +} | |
| 9 | +.chzn-container .chzn-drop { | |
| 10 | + background: #fff; | |
| 11 | + border: 1px solid #aaa; | |
| 12 | + border-top: 0; | |
| 13 | + position: absolute; | |
| 14 | + top: 29px; | |
| 15 | + left: 0; | |
| 16 | + -webkit-box-shadow: 0 4px 5px rgba(0,0,0,.15); | |
| 17 | + -moz-box-shadow : 0 4px 5px rgba(0,0,0,.15); | |
| 18 | + -o-box-shadow : 0 4px 5px rgba(0,0,0,.15); | |
| 19 | + box-shadow : 0 4px 5px rgba(0,0,0,.15); | |
| 20 | + z-index: 999; | |
| 21 | +} | |
| 22 | +/* @end */ | |
| 23 | + | |
| 24 | +/* @group Single Chosen */ | |
| 25 | +.chzn-container-single .chzn-single { | |
| 26 | + background-color: #fff; | |
| 27 | + background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #eeeeee), color-stop(0.5, white)); | |
| 28 | + background-image: -webkit-linear-gradient(center bottom, #eeeeee 0%, white 50%); | |
| 29 | + background-image: -moz-linear-gradient(center bottom, #eeeeee 0%, white 50%); | |
| 30 | + background-image: -o-linear-gradient(top, #eeeeee 0%,#ffffff 50%); | |
| 31 | + background-image: -ms-linear-gradient(top, #eeeeee 0%,#ffffff 50%); | |
| 32 | + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#eeeeee', endColorstr='#ffffff',GradientType=0 ); | |
| 33 | + background-image: linear-gradient(top, #eeeeee 0%,#ffffff 50%); | |
| 34 | + -webkit-border-radius: 4px; | |
| 35 | + -moz-border-radius : 4px; | |
| 36 | + border-radius : 4px; | |
| 37 | + -moz-background-clip : padding; | |
| 38 | + -webkit-background-clip: padding-box; | |
| 39 | + background-clip : padding-box; | |
| 40 | + border: 1px solid #aaa; | |
| 41 | + display: block; | |
| 42 | + overflow: hidden; | |
| 43 | + white-space: nowrap; | |
| 44 | + position: relative; | |
| 45 | + height: 26px; | |
| 46 | + line-height: 26px; | |
| 47 | + padding: 0 0 0 8px; | |
| 48 | + color: #444; | |
| 49 | + text-decoration: none; | |
| 50 | +} | |
| 51 | +.chzn-container-single .chzn-single span { | |
| 52 | + margin-right: 26px; | |
| 53 | + display: block; | |
| 54 | + overflow: hidden; | |
| 55 | + white-space: nowrap; | |
| 56 | + -o-text-overflow: ellipsis; | |
| 57 | + -ms-text-overflow: ellipsis; | |
| 58 | + text-overflow: ellipsis; | |
| 59 | +} | |
| 60 | +.chzn-container-single .chzn-single abbr { | |
| 61 | + display: block; | |
| 62 | + position: absolute; | |
| 63 | + right: 26px; | |
| 64 | + top: 8px; | |
| 65 | + width: 12px; | |
| 66 | + height: 13px; | |
| 67 | + font-size: 1px; | |
| 68 | + background: url(chosen-sprite.png) right top no-repeat; | |
| 69 | +} | |
| 70 | +.chzn-container-single .chzn-single abbr:hover { | |
| 71 | + background-position: right -11px; | |
| 72 | +} | |
| 73 | +.chzn-container-single .chzn-single div { | |
| 74 | + -webkit-border-radius: 0 4px 4px 0; | |
| 75 | + -moz-border-radius : 0 4px 4px 0; | |
| 76 | + border-radius : 0 4px 4px 0; | |
| 77 | + -moz-background-clip : padding; | |
| 78 | + -webkit-background-clip: padding-box; | |
| 79 | + background-clip : padding-box; | |
| 80 | + background: #ccc; | |
| 81 | + background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #ccc), color-stop(0.6, #eee)); | |
| 82 | + background-image: -webkit-linear-gradient(center bottom, #ccc 0%, #eee 60%); | |
| 83 | + background-image: -moz-linear-gradient(center bottom, #ccc 0%, #eee 60%); | |
| 84 | + background-image: -o-linear-gradient(bottom, #ccc 0%, #eee 60%); | |
| 85 | + background-image: -ms-linear-gradient(top, #cccccc 0%,#eeeeee 60%); | |
| 86 | + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#cccccc', endColorstr='#eeeeee',GradientType=0 ); | |
| 87 | + background-image: linear-gradient(top, #cccccc 0%,#eeeeee 60%); | |
| 88 | + border-left: 1px solid #aaa; | |
| 89 | + position: absolute; | |
| 90 | + right: 0; | |
| 91 | + top: 0; | |
| 92 | + display: block; | |
| 93 | + height: 100%; | |
| 94 | + width: 18px; | |
| 95 | +} | |
| 96 | +.chzn-container-single .chzn-single div b { | |
| 97 | + background: url('chosen-sprite.png') no-repeat 0 1px; | |
| 98 | + display: block; | |
| 99 | + width: 100%; | |
| 100 | + height: 100%; | |
| 101 | +} | |
| 102 | +.chzn-container-single .chzn-search { | |
| 103 | + padding: 3px 4px; | |
| 104 | + position: relative; | |
| 105 | + margin: 0; | |
| 106 | + white-space: nowrap; | |
| 107 | + z-index: 1010; | |
| 108 | +} | |
| 109 | +.chzn-container-single .chzn-search input { | |
| 110 | + background: #fff url('chosen-sprite.png') no-repeat 100% -22px; | |
| 111 | + background: url('chosen-sprite.png') no-repeat 100% -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); | |
| 112 | + background: url('chosen-sprite.png') no-repeat 100% -22px, -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 113 | + background: url('chosen-sprite.png') no-repeat 100% -22px, -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 114 | + background: url('chosen-sprite.png') no-repeat 100% -22px, -o-linear-gradient(bottom, white 85%, #eeeeee 99%); | |
| 115 | + background: url('chosen-sprite.png') no-repeat 100% -22px, -ms-linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 116 | + background: url('chosen-sprite.png') no-repeat 100% -22px, linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 117 | + margin: 1px 0; | |
| 118 | + padding: 4px 20px 4px 5px; | |
| 119 | + outline: 0; | |
| 120 | + border: 1px solid #aaa; | |
| 121 | + font-family: sans-serif; | |
| 122 | + font-size: 1em; | |
| 123 | +} | |
| 124 | +.chzn-container-single .chzn-drop { | |
| 125 | + -webkit-border-radius: 0 0 4px 4px; | |
| 126 | + -moz-border-radius : 0 0 4px 4px; | |
| 127 | + border-radius : 0 0 4px 4px; | |
| 128 | + -moz-background-clip : padding; | |
| 129 | + -webkit-background-clip: padding-box; | |
| 130 | + background-clip : padding-box; | |
| 131 | +} | |
| 132 | +/* @end */ | |
| 133 | + | |
| 134 | +.chzn-container-single-nosearch .chzn-search input { | |
| 135 | + position: absolute; | |
| 136 | + left: -9000px; | |
| 137 | +} | |
| 138 | + | |
| 139 | +/* @group Multi Chosen */ | |
| 140 | +.chzn-container-multi .chzn-choices { | |
| 141 | + background-color: #fff; | |
| 142 | + background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); | |
| 143 | + background-image: -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 144 | + background-image: -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 145 | + background-image: -o-linear-gradient(bottom, white 85%, #eeeeee 99%); | |
| 146 | + background-image: -ms-linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 147 | + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eeeeee',GradientType=0 ); | |
| 148 | + background-image: linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 149 | + border: 1px solid #aaa; | |
| 150 | + margin: 0; | |
| 151 | + padding: 0; | |
| 152 | + cursor: text; | |
| 153 | + overflow: hidden; | |
| 154 | + height: auto !important; | |
| 155 | + height: 1%; | |
| 156 | + position: relative; | |
| 157 | +} | |
| 158 | +.chzn-container-multi .chzn-choices li { | |
| 159 | + float: left; | |
| 160 | + list-style: none; | |
| 161 | +} | |
| 162 | +.chzn-container-multi .chzn-choices .search-field { | |
| 163 | + white-space: nowrap; | |
| 164 | + margin: 0; | |
| 165 | + padding: 0; | |
| 166 | +} | |
| 167 | +.chzn-container-multi .chzn-choices .search-field input { | |
| 168 | + color: #666; | |
| 169 | + background: transparent !important; | |
| 170 | + border: 0 !important; | |
| 171 | + padding: 5px; | |
| 172 | + margin: 1px 0; | |
| 173 | + outline: 0; | |
| 174 | + -webkit-box-shadow: none; | |
| 175 | + -moz-box-shadow : none; | |
| 176 | + -o-box-shadow : none; | |
| 177 | + box-shadow : none; | |
| 178 | +} | |
| 179 | +.chzn-container-multi .chzn-choices .search-field .default { | |
| 180 | + color: #999; | |
| 181 | +} | |
| 182 | +.chzn-container-multi .chzn-choices .search-choice { | |
| 183 | + -webkit-border-radius: 3px; | |
| 184 | + -moz-border-radius : 3px; | |
| 185 | + border-radius : 3px; | |
| 186 | + -moz-background-clip : padding; | |
| 187 | + -webkit-background-clip: padding-box; | |
| 188 | + background-clip : padding-box; | |
| 189 | + background-color: #e4e4e4; | |
| 190 | + background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #e4e4e4), color-stop(0.7, #eeeeee)); | |
| 191 | + background-image: -webkit-linear-gradient(center bottom, #e4e4e4 0%, #eeeeee 70%); | |
| 192 | + background-image: -moz-linear-gradient(center bottom, #e4e4e4 0%, #eeeeee 70%); | |
| 193 | + background-image: -o-linear-gradient(bottom, #e4e4e4 0%, #eeeeee 70%); | |
| 194 | + background-image: -ms-linear-gradient(top, #e4e4e4 0%,#eeeeee 70%); | |
| 195 | + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e4e4e4', endColorstr='#eeeeee',GradientType=0 ); | |
| 196 | + background-image: linear-gradient(top, #e4e4e4 0%,#eeeeee 70%); | |
| 197 | + color: #333; | |
| 198 | + border: 1px solid #b4b4b4; | |
| 199 | + line-height: 13px; | |
| 200 | + padding: 3px 19px 3px 6px; | |
| 201 | + margin: 3px 0 3px 5px; | |
| 202 | + position: relative; | |
| 203 | +} | |
| 204 | +.chzn-container-multi .chzn-choices .search-choice span { | |
| 205 | + cursor: default; | |
| 206 | +} | |
| 207 | +.chzn-container-multi .chzn-choices .search-choice-focus { | |
| 208 | + background: #d4d4d4; | |
| 209 | +} | |
| 210 | +.chzn-container-multi .chzn-choices .search-choice .search-choice-close { | |
| 211 | + display: block; | |
| 212 | + position: absolute; | |
| 213 | + right: 3px; | |
| 214 | + top: 4px; | |
| 215 | + width: 12px; | |
| 216 | + height: 13px; | |
| 217 | + font-size: 1px; | |
| 218 | + background: url(chosen-sprite.png) right top no-repeat; | |
| 219 | +} | |
| 220 | +.chzn-container-multi .chzn-choices .search-choice .search-choice-close:hover { | |
| 221 | + background-position: right -11px; | |
| 222 | +} | |
| 223 | +.chzn-container-multi .chzn-choices .search-choice-focus .search-choice-close { | |
| 224 | + background-position: right -11px; | |
| 225 | +} | |
| 226 | +/* @end */ | |
| 227 | + | |
| 228 | +/* @group Results */ | |
| 229 | +.chzn-container .chzn-results { | |
| 230 | + margin: 0 4px 4px 0; | |
| 231 | + max-height: 190px; | |
| 232 | + padding: 0 0 0 4px; | |
| 233 | + position: relative; | |
| 234 | + overflow-x: hidden; | |
| 235 | + overflow-y: auto; | |
| 236 | +} | |
| 237 | +.chzn-container-multi .chzn-results { | |
| 238 | + margin: -1px 0 0; | |
| 239 | + padding: 0; | |
| 240 | +} | |
| 241 | +.chzn-container .chzn-results li { | |
| 242 | + display: none; | |
| 243 | + line-height: 80%; | |
| 244 | + padding: 7px 7px 8px; | |
| 245 | + margin: 0; | |
| 246 | + list-style: none; | |
| 247 | +} | |
| 248 | +.chzn-container .chzn-results .active-result { | |
| 249 | + cursor: pointer; | |
| 250 | + display: list-item; | |
| 251 | +} | |
| 252 | +.chzn-container .chzn-results .highlighted { | |
| 253 | + background: #3875d7; | |
| 254 | + color: #fff; | |
| 255 | +} | |
| 256 | +.chzn-container .chzn-results li em { | |
| 257 | + background: #feffde; | |
| 258 | + font-style: normal; | |
| 259 | +} | |
| 260 | +.chzn-container .chzn-results .highlighted em { | |
| 261 | + background: transparent; | |
| 262 | +} | |
| 263 | +.chzn-container .chzn-results .no-results { | |
| 264 | + background: #f4f4f4; | |
| 265 | + display: list-item; | |
| 266 | +} | |
| 267 | +.chzn-container .chzn-results .group-result { | |
| 268 | + cursor: default; | |
| 269 | + color: #999; | |
| 270 | + font-weight: bold; | |
| 271 | +} | |
| 272 | +.chzn-container .chzn-results .group-option { | |
| 273 | + padding-left: 20px; | |
| 274 | +} | |
| 275 | +.chzn-container-multi .chzn-drop .result-selected { | |
| 276 | + display: none; | |
| 277 | +} | |
| 278 | +/* @end */ | |
| 279 | + | |
| 280 | +/* @group Active */ | |
| 281 | +.chzn-container-active .chzn-single { | |
| 282 | + -webkit-box-shadow: 0 0 5px rgba(0,0,0,.3); | |
| 283 | + -moz-box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 284 | + -o-box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 285 | + box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 286 | + border: 1px solid #5897fb; | |
| 287 | +} | |
| 288 | +.chzn-container-active .chzn-single-with-drop { | |
| 289 | + border: 1px solid #aaa; | |
| 290 | + -webkit-box-shadow: 0 1px 0 #fff inset; | |
| 291 | + -moz-box-shadow : 0 1px 0 #fff inset; | |
| 292 | + -o-box-shadow : 0 1px 0 #fff inset; | |
| 293 | + box-shadow : 0 1px 0 #fff inset; | |
| 294 | + background-color: #eee; | |
| 295 | + background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, white), color-stop(0.5, #eeeeee)); | |
| 296 | + background-image: -webkit-linear-gradient(center bottom, white 0%, #eeeeee 50%); | |
| 297 | + background-image: -moz-linear-gradient(center bottom, white 0%, #eeeeee 50%); | |
| 298 | + background-image: -o-linear-gradient(bottom, white 0%, #eeeeee 50%); | |
| 299 | + background-image: -ms-linear-gradient(top, #ffffff 0%,#eeeeee 50%); | |
| 300 | + filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eeeeee',GradientType=0 ); | |
| 301 | + background-image: linear-gradient(top, #ffffff 0%,#eeeeee 50%); | |
| 302 | + -webkit-border-bottom-left-radius : 0; | |
| 303 | + -webkit-border-bottom-right-radius: 0; | |
| 304 | + -moz-border-radius-bottomleft : 0; | |
| 305 | + -moz-border-radius-bottomright: 0; | |
| 306 | + border-bottom-left-radius : 0; | |
| 307 | + border-bottom-right-radius: 0; | |
| 308 | +} | |
| 309 | +.chzn-container-active .chzn-single-with-drop div { | |
| 310 | + background: transparent; | |
| 311 | + border-left: none; | |
| 312 | +} | |
| 313 | +.chzn-container-active .chzn-single-with-drop div b { | |
| 314 | + background-position: -18px 1px; | |
| 315 | +} | |
| 316 | +.chzn-container-active .chzn-choices { | |
| 317 | + -webkit-box-shadow: 0 0 5px rgba(0,0,0,.3); | |
| 318 | + -moz-box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 319 | + -o-box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 320 | + box-shadow : 0 0 5px rgba(0,0,0,.3); | |
| 321 | + border: 1px solid #5897fb; | |
| 322 | +} | |
| 323 | +.chzn-container-active .chzn-choices .search-field input { | |
| 324 | + color: #111 !important; | |
| 325 | +} | |
| 326 | +/* @end */ | |
| 327 | + | |
| 328 | +/* @group Disabled Support */ | |
| 329 | +.chzn-disabled { | |
| 330 | + cursor: default; | |
| 331 | + opacity:0.5 !important; | |
| 332 | +} | |
| 333 | +.chzn-disabled .chzn-single { | |
| 334 | + cursor: default; | |
| 335 | +} | |
| 336 | +.chzn-disabled .chzn-choices .search-choice .search-choice-close { | |
| 337 | + cursor: default; | |
| 338 | +} | |
| 339 | + | |
| 340 | +/* @group Right to Left */ | |
| 341 | +.chzn-rtl { direction:rtl;text-align: right; } | |
| 342 | +.chzn-rtl .chzn-single { padding-left: 0; padding-right: 8px; } | |
| 343 | +.chzn-rtl .chzn-single span { margin-left: 26px; margin-right: 0; } | |
| 344 | +.chzn-rtl .chzn-single div { | |
| 345 | + left: 0; right: auto; | |
| 346 | + border-left: none; border-right: 1px solid #aaaaaa; | |
| 347 | + -webkit-border-radius: 4px 0 0 4px; | |
| 348 | + -moz-border-radius : 4px 0 0 4px; | |
| 349 | + border-radius : 4px 0 0 4px; | |
| 350 | +} | |
| 351 | +.chzn-rtl .chzn-choices li { float: right; } | |
| 352 | +.chzn-rtl .chzn-choices .search-choice { padding: 3px 6px 3px 19px; margin: 3px 5px 3px 0; } | |
| 353 | +.chzn-rtl .chzn-choices .search-choice .search-choice-close { left: 5px; right: auto; background-position: right top;} | |
| 354 | +.chzn-rtl.chzn-container-single .chzn-results { margin-left: 4px; margin-right: 0; padding-left: 0; padding-right: 4px; } | |
| 355 | +.chzn-rtl .chzn-results .group-option { padding-left: 0; padding-right: 20px; } | |
| 356 | +.chzn-rtl.chzn-container-active .chzn-single-with-drop div { border-right: none; } | |
| 357 | +.chzn-rtl .chzn-search input { | |
| 358 | + background: url('chosen-sprite.png') no-repeat -38px -22px, #ffffff; | |
| 359 | + background: url('chosen-sprite.png') no-repeat -38px -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); | |
| 360 | + background: url('chosen-sprite.png') no-repeat -38px -22px, -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 361 | + background: url('chosen-sprite.png') no-repeat -38px -22px, -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); | |
| 362 | + background: url('chosen-sprite.png') no-repeat -38px -22px, -o-linear-gradient(bottom, white 85%, #eeeeee 99%); | |
| 363 | + background: url('chosen-sprite.png') no-repeat -38px -22px, -ms-linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 364 | + background: url('chosen-sprite.png') no-repeat -38px -22px, linear-gradient(top, #ffffff 85%,#eeeeee 99%); | |
| 365 | + padding: 4px 5px 4px 20px; | |
| 366 | +} | |
| 367 | +/* @end */ | ... | ... |
app/assets/stylesheets/highlight.css.scss
| 1 | -@mixin round-borders-all($radius) { | |
| 1 | +@mixin round-borders-all($radius) { | |
| 2 | 2 | border: 1px solid #eaeaea; |
| 3 | 3 | -moz-border-radius: $radius; |
| 4 | 4 | -webkit-border-radius: $radius; |
| ... | ... | @@ -28,11 +28,11 @@ td.linenos{ |
| 28 | 28 | .highlight pre{ |
| 29 | 29 | } |
| 30 | 30 | |
| 31 | -.linenodiv pre { | |
| 31 | +.linenodiv pre { | |
| 32 | 32 | white-space:pre-line; |
| 33 | 33 | } |
| 34 | 34 | |
| 35 | -td.linenos { | |
| 35 | +td.linenos { | |
| 36 | 36 | background:#ECECEC; |
| 37 | 37 | color:#777; |
| 38 | 38 | padding:10px 0px 0px 10px; |
| ... | ... | @@ -42,7 +42,7 @@ td.linenos { |
| 42 | 42 | |
| 43 | 43 | } |
| 44 | 44 | |
| 45 | -td.code .highlight { | |
| 45 | +td.code .highlight { | |
| 46 | 46 | overflow: auto; |
| 47 | 47 | } |
| 48 | 48 | table.highlighttable pre{ |
| ... | ... | @@ -53,9 +53,8 @@ table.highlighttable pre{ |
| 53 | 53 | text-align:left; |
| 54 | 54 | } |
| 55 | 55 | |
| 56 | - | |
| 57 | 56 | .git-empty .highlight { |
| 58 | - @include round-borders-all(4px); | |
| 57 | + @include round-borders-all(4px); | |
| 59 | 58 | background:#eee; |
| 60 | 59 | padding:5px; |
| 61 | 60 | //overflow-x:scroll; |
| ... | ... | @@ -71,10 +70,9 @@ table.highlighttable pre{ |
| 71 | 70 | .shadow{ |
| 72 | 71 | -webkit-box-shadow:0 5px 15px #000; |
| 73 | 72 | -moz-box-shadow:0 5px 15px #000; |
| 74 | - box-shadow:0 5px 15px #000; | |
| 73 | + box-shadow:0 5px 15px #000; | |
| 75 | 74 | } |
| 76 | 75 | |
| 77 | - | |
| 78 | 76 | .hll { background-color: #ffffff } |
| 79 | 77 | .c { color: #888888; font-style: italic } /* Comment */ |
| 80 | 78 | .err { color: #a61717; background-color: #e3d2d2 } /* Error */ |
| ... | ... | @@ -105,7 +103,7 @@ table.highlighttable pre{ |
| 105 | 103 | .highlight .nb{color:#0086B3;} /* Name.Builtin */ |
| 106 | 104 | .highlight .nc{color:#458;font-weight:bold;} /* Name.Class */ |
| 107 | 105 | .highlight .no{color:#008080;} /* Name.Constant */ |
| 108 | -.highlight .ni{color:#800080;} | |
| 106 | +.highlight .ni{color:#800080;} | |
| 109 | 107 | .highlight .ne{color:#900;font-weight:bold;} /* Name.Exception */ |
| 110 | 108 | .highlight .nf{color:#900;font-weight:bold;} /* Name.Function */ |
| 111 | 109 | .highlight .nn{color:#005;font-weight:bold;} /* Name.Namespace */ | ... | ... |
app/assets/stylesheets/projects.css.scss
| ... | ... | @@ -2,7 +2,7 @@ |
| 2 | 2 | // They will automatically be included in application.css. |
| 3 | 3 | // You can use Sass (SCSS) here: http://sass-lang.com/ |
| 4 | 4 | |
| 5 | -@mixin round-borders-bottom($radius) { | |
| 5 | +@mixin round-borders-bottom($radius) { | |
| 6 | 6 | border-top: 1px solid #eaeaea; |
| 7 | 7 | |
| 8 | 8 | -moz-border-radius-bottomright: $radius; |
| ... | ... | @@ -15,7 +15,7 @@ |
| 15 | 15 | -webkit-border-bottom-right-radius: $radius; |
| 16 | 16 | } |
| 17 | 17 | |
| 18 | -@mixin round-borders-top($radius) { | |
| 18 | +@mixin round-borders-top($radius) { | |
| 19 | 19 | border-top: 1px solid #eaeaea; |
| 20 | 20 | |
| 21 | 21 | -moz-border-radius-topright: $radius; |
| ... | ... | @@ -28,14 +28,14 @@ |
| 28 | 28 | -webkit-border-top-right-radius: $radius; |
| 29 | 29 | } |
| 30 | 30 | |
| 31 | -@mixin round-borders-all($radius) { | |
| 31 | +@mixin round-borders-all($radius) { | |
| 32 | 32 | border: 1px solid #eaeaea; |
| 33 | 33 | -moz-border-radius: $radius; |
| 34 | 34 | -webkit-border-radius: $radius; |
| 35 | 35 | border-radius: $radius; |
| 36 | 36 | } |
| 37 | 37 | |
| 38 | -@mixin hover-color { | |
| 38 | +@mixin hover-color { | |
| 39 | 39 | background: #fff !important; |
| 40 | 40 | background: -webkit-gradient(linear,left top,left bottom,from(#fff),to(#FFF6BF)) !important; |
| 41 | 41 | background: -moz-linear-gradient(top,#fff,#FFF6BF) !important; |
| ... | ... | @@ -46,47 +46,48 @@ |
| 46 | 46 | border:1px solid #CCC; |
| 47 | 47 | margin-bottom:1em; |
| 48 | 48 | |
| 49 | - .diff_file_header { | |
| 49 | + .diff_file_header { | |
| 50 | 50 | padding:5px 5px; |
| 51 | 51 | border-bottom:1px solid #CCC; |
| 52 | 52 | background: #eee; |
| 53 | 53 | } |
| 54 | - .diff_file_content { | |
| 55 | - overflow-x: scroll; | |
| 54 | + .diff_file_content { | |
| 55 | + overflow:auto; | |
| 56 | + overflow-y:hidden; | |
| 56 | 57 | background:#fff; |
| 57 | 58 | color:#333; |
| 58 | 59 | font-size: 12px; |
| 59 | 60 | font-family: 'Courier New', 'andale mono','lucida console',monospace; |
| 60 | 61 | } |
| 61 | - .diff_file_content_image { | |
| 62 | + .diff_file_content_image { | |
| 62 | 63 | background:#eee; |
| 63 | 64 | text-align:center; |
| 64 | - img { | |
| 65 | + img { | |
| 65 | 66 | padding:100px; |
| 66 | 67 | max-width:300px; |
| 67 | 68 | } |
| 68 | 69 | } |
| 69 | 70 | } |
| 70 | 71 | |
| 71 | -#logo { | |
| 72 | - &:hover { | |
| 72 | +#logo { | |
| 73 | + &:hover { | |
| 73 | 74 | background:none; |
| 74 | 75 | } |
| 75 | 76 | } |
| 76 | 77 | |
| 77 | -.file_stats { | |
| 78 | +.file_stats { | |
| 78 | 79 | margin-bottom:10px; |
| 79 | 80 | @include round-borders-all(4px); |
| 80 | 81 | |
| 81 | - span { | |
| 82 | + span { | |
| 82 | 83 | border-top: 1px solid #eaeaea; |
| 83 | 84 | padding:5px 5px; |
| 84 | 85 | display:block; |
| 85 | - &:first-child { | |
| 86 | + &:first-child { | |
| 86 | 87 | border-top:none; |
| 87 | 88 | } |
| 88 | 89 | |
| 89 | - img { | |
| 90 | + img { | |
| 90 | 91 | width:18px; |
| 91 | 92 | float:left; |
| 92 | 93 | margin-right: 6px; |
| ... | ... | @@ -94,71 +95,22 @@ |
| 94 | 95 | } |
| 95 | 96 | } |
| 96 | 97 | |
| 97 | -.round-borders { | |
| 98 | +.round-borders { | |
| 98 | 99 | @include round-borders-all(4px); |
| 99 | 100 | padding: 4px 0px; |
| 100 | 101 | } |
| 101 | -table.round-borders { | |
| 102 | +table.round-borders { | |
| 102 | 103 | float:left; |
| 103 | 104 | } |
| 104 | 105 | |
| 105 | -.day-commits-table { | |
| 106 | - @include round-borders-all(4px); | |
| 107 | - padding: 4px 0px; | |
| 108 | - margin-bottom:10px; | |
| 109 | - display:block; | |
| 110 | - width:100%; | |
| 111 | - background: #E6F1F6; | |
| 112 | - | |
| 113 | - .day-header { | |
| 114 | - padding:10px; | |
| 115 | - h3 { | |
| 116 | - margin:0px; | |
| 117 | - } | |
| 118 | - } | |
| 119 | - | |
| 120 | - ul { | |
| 121 | - display:block; | |
| 122 | - list-style:none; | |
| 123 | - margin:0px; | |
| 124 | - padding:0px; | |
| 125 | - | |
| 126 | - li.commit { | |
| 127 | - display:list-item; | |
| 128 | - padding:8px; | |
| 129 | - margin:0px; | |
| 130 | - background: #F7FBFC; | |
| 131 | - border-top: 1px solid #E2EAEE; | |
| 132 | - | |
| 133 | - &:first-child { | |
| 134 | - border-top: 1px solid #E2EAEE; | |
| 135 | - } | |
| 136 | - &:nth-child(2n+1) { | |
| 137 | - background: white; | |
| 138 | - } | |
| 139 | - | |
| 140 | - a.button { | |
| 141 | - width:85px; | |
| 142 | - padding:10px; | |
| 143 | - margin:0px; | |
| 144 | - float:right; | |
| 145 | - } | |
| 146 | - p { | |
| 147 | - margin-bottom: 3px; | |
| 148 | - font-size: 13px; | |
| 149 | - } | |
| 150 | - } | |
| 151 | - } | |
| 152 | -} | |
| 153 | -@mixin panel-color { | |
| 106 | +@mixin panel-color { | |
| 154 | 107 | background: #111 !important; |
| 155 | 108 | background: -webkit-gradient(linear,left top,left bottom,from(#333),to(#111)) !important; |
| 156 | 109 | background: -moz-linear-gradient(top,#333,#111) !important; |
| 157 | 110 | background: transparent 9 !important; |
| 158 | 111 | } |
| 159 | 112 | |
| 160 | - | |
| 161 | -#header-panel { | |
| 113 | +#header-panel { | |
| 162 | 114 | @include panel-color; |
| 163 | 115 | height:40px; |
| 164 | 116 | position:fixed; |
| ... | ... | @@ -178,23 +130,23 @@ table.round-borders { |
| 178 | 130 | color:white; |
| 179 | 131 | } |
| 180 | 132 | |
| 181 | - &.current { | |
| 133 | + &.current { | |
| 182 | 134 | border-bottom: 3px solid #EAEAEA !important; |
| 183 | 135 | padding: 10px 20px 0; |
| 184 | 136 | color: #eaeaea; |
| 185 | 137 | } |
| 186 | 138 | } |
| 187 | - .search-holder { | |
| 139 | + .search-holder { | |
| 188 | 140 | float:left; |
| 189 | - width:290px; | |
| 141 | + width:290px; | |
| 190 | 142 | input { |
| 191 | 143 | @include round-borders-all(4px); |
| 192 | - width:290px; | |
| 144 | + width:290px; | |
| 193 | 145 | border-color:#888; |
| 194 | 146 | padding:5px; |
| 195 | 147 | background:#666; |
| 196 | 148 | color:#222; |
| 197 | - &:focus { | |
| 149 | + &:focus { | |
| 198 | 150 | background:#fff; |
| 199 | 151 | color:#000; |
| 200 | 152 | } |
| ... | ... | @@ -211,28 +163,23 @@ table.round-borders { |
| 211 | 163 | padding:20px; |
| 212 | 164 | } |
| 213 | 165 | |
| 214 | -body { | |
| 215 | - background: #eaeaea; | |
| 216 | -} | |
| 217 | - | |
| 218 | 166 | a { |
| 219 | 167 | color: #111; |
| 220 | 168 | } |
| 221 | 169 | |
| 222 | 170 | .diff_file_content{ |
| 223 | - .old_line, .new_line { | |
| 171 | + .old_line, .new_line { | |
| 224 | 172 | background:#ECECEC; |
| 225 | 173 | color:#777; |
| 226 | - width:15px; | |
| 174 | + width:30px; | |
| 227 | 175 | float:left; |
| 228 | - padding: 0px 10px; | |
| 176 | + padding: 0px 5px; | |
| 229 | 177 | border-right: 1px solid #ccc; |
| 230 | 178 | } |
| 231 | 179 | } |
| 232 | 180 | |
| 233 | - | |
| 234 | 181 | .view_file_content{ |
| 235 | - .old_line, .new_line { | |
| 182 | + .old_line, .new_line { | |
| 236 | 183 | background:#ECECEC; |
| 237 | 184 | color:#777; |
| 238 | 185 | width:15px; |
| ... | ... | @@ -249,20 +196,20 @@ a { |
| 249 | 196 | border:1px solid #CCC; |
| 250 | 197 | margin-bottom:1em; |
| 251 | 198 | |
| 252 | - .view_file_header { | |
| 199 | + .view_file_header { | |
| 253 | 200 | padding:5px 5px; |
| 254 | 201 | border-bottom:1px solid #CCC; |
| 255 | 202 | background: #eee; |
| 256 | 203 | } |
| 257 | - .view_file_content { | |
| 204 | + .view_file_content { | |
| 258 | 205 | background:#fff; |
| 259 | 206 | color:#514721; |
| 260 | 207 | font-size: 11px; |
| 261 | 208 | } |
| 262 | - .view_file_content_image { | |
| 209 | + .view_file_content_image { | |
| 263 | 210 | background:#eee; |
| 264 | 211 | text-align:center; |
| 265 | - img { | |
| 212 | + img { | |
| 266 | 213 | padding:100px; |
| 267 | 214 | max-width:300px; |
| 268 | 215 | } |
| ... | ... | @@ -273,7 +220,7 @@ a { |
| 273 | 220 | |
| 274 | 221 | } |
| 275 | 222 | |
| 276 | -input.ssh_project_url { | |
| 223 | +input.ssh_project_url { | |
| 277 | 224 | padding:5px; |
| 278 | 225 | margin:0px; |
| 279 | 226 | float:right; |
| ... | ... | @@ -281,53 +228,23 @@ input.ssh_project_url { |
| 281 | 228 | text-align:center; |
| 282 | 229 | } |
| 283 | 230 | |
| 284 | - | |
| 285 | - | |
| 286 | -.day-commits-table li.commit { | |
| 287 | - cursor:pointer; | |
| 288 | - | |
| 289 | - &:hover { | |
| 290 | - @include hover-color; | |
| 291 | - } | |
| 292 | -} | |
| 293 | - | |
| 294 | -/* | |
| 295 | -#FFF6BF | |
| 296 | -#FFD324 | |
| 297 | -*/ | |
| 298 | -#tree-slider tr.tree-item { | |
| 299 | - cursor:pointer; | |
| 300 | - | |
| 301 | - &:hover { | |
| 302 | - @include hover-color; | |
| 303 | - td { | |
| 304 | - @include hover-color; | |
| 305 | - } | |
| 306 | - } | |
| 307 | -} | |
| 308 | -#projects-list .project { | |
| 231 | +#projects-list .project { | |
| 309 | 232 | height:50px; |
| 310 | 233 | } |
| 311 | 234 | |
| 235 | +#tree-slider .tree-item, | |
| 312 | 236 | #projects-list .project, |
| 313 | 237 | #snippets-table .snippet, |
| 314 | -#issues-table .issue{ | |
| 238 | +#issues-table .issue{ | |
| 315 | 239 | cursor:pointer; |
| 316 | - | |
| 317 | - &:hover { | |
| 318 | - @include hover-color; | |
| 319 | - td { | |
| 320 | - @include hover-color; | |
| 321 | - } | |
| 322 | - } | |
| 323 | 240 | } |
| 324 | 241 | |
| 325 | -.clear { | |
| 242 | +.clear { | |
| 326 | 243 | clear: both; |
| 327 | 244 | } |
| 328 | 245 | |
| 329 | -.top_project_menu { | |
| 330 | - a { | |
| 246 | +.top_project_menu { | |
| 247 | + a { | |
| 331 | 248 | border-right: 1px solid #FFFFFF; |
| 332 | 249 | box-shadow: -1px 0 #DDDDDD inset; |
| 333 | 250 | color: #666; |
| ... | ... | @@ -339,7 +256,7 @@ input.ssh_project_url { |
| 339 | 256 | text-shadow: 0 1px 0 #FFFFFF; |
| 340 | 257 | float:left; |
| 341 | 258 | |
| 342 | - &.current { | |
| 259 | + &.current { | |
| 343 | 260 | background-color: #FFFFFF; |
| 344 | 261 | color: #222222; |
| 345 | 262 | } |
| ... | ... | @@ -363,11 +280,11 @@ input.ssh_project_url { |
| 363 | 280 | .new_project, |
| 364 | 281 | .new_snippet, |
| 365 | 282 | .edit_snippet, |
| 366 | -.edit_project { | |
| 283 | +.edit_project { | |
| 367 | 284 | input[type='text'], |
| 368 | 285 | input[type='email'], |
| 369 | 286 | input[type='password'], |
| 370 | - textarea { | |
| 287 | + textarea { | |
| 371 | 288 | width:400px; |
| 372 | 289 | padding:8px; |
| 373 | 290 | font-size:14px; |
| ... | ... | @@ -375,7 +292,7 @@ input.ssh_project_url { |
| 375 | 292 | } |
| 376 | 293 | } |
| 377 | 294 | |
| 378 | -.input_button { | |
| 295 | +.input_button { | |
| 379 | 296 | //@include round-borders-all(4px); |
| 380 | 297 | padding:8px; |
| 381 | 298 | font-size:14px; |
| ... | ... | @@ -387,23 +304,19 @@ input.ssh_project_url { |
| 387 | 304 | border-width: 1px; |
| 388 | 305 | } |
| 389 | 306 | |
| 390 | -tbody tr:nth-child(2n) td, tbody tr.even td { | |
| 391 | - background: none repeat scroll 0 0 #F7FBFC; | |
| 392 | - border-top: 1px solid #E2EAEE; | |
| 393 | - border-bottom: 1px solid #E2EAEE; | |
| 394 | -} | |
| 395 | 307 | |
| 396 | -.top_menu_count { | |
| 397 | - background: none repeat scroll 0 0 #FFF6BF; | |
| 398 | - border-color: #FFD324; | |
| 399 | - color: #514721; | |
| 400 | - border: 1px solid #DDDDDD; | |
| 308 | +.top_menu_count { | |
| 309 | + background: none repeat scroll 0 0 white; | |
| 310 | + color: #333; | |
| 311 | + border-color: #4BB8D2; | |
| 401 | 312 | padding: 2px; |
| 402 | - font-size:12px; | |
| 403 | - position:relative; | |
| 404 | - top:-14px; | |
| 405 | - left:10px; | |
| 313 | + font-size:10px; | |
| 406 | 314 | border-top:none; |
| 315 | + text-align:center; | |
| 316 | + float:right; | |
| 317 | + width:25px; | |
| 318 | + | |
| 319 | + | |
| 407 | 320 | } |
| 408 | 321 | |
| 409 | 322 | #logo { |
| ... | ... | @@ -415,9 +328,9 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 415 | 328 | text-shadow: #555 1px 1px; |
| 416 | 329 | } |
| 417 | 330 | |
| 418 | -/** FALSH **/ | |
| 331 | +/** FLASH **/ | |
| 419 | 332 | |
| 420 | -#flash_container { | |
| 333 | +#flash_container { | |
| 421 | 334 | height:40px; |
| 422 | 335 | position:fixed; |
| 423 | 336 | z-index:1009; |
| ... | ... | @@ -429,10 +342,11 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 429 | 342 | cursor:pointer; |
| 430 | 343 | border-bottom:1px solid #777; |
| 431 | 344 | |
| 432 | - h4 { | |
| 345 | + h4 { | |
| 433 | 346 | color:#444; |
| 434 | 347 | font-size:22px; |
| 435 | 348 | padding-top:5px; |
| 349 | + margin:2px; | |
| 436 | 350 | } |
| 437 | 351 | } |
| 438 | 352 | |
| ... | ... | @@ -460,50 +374,25 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 460 | 374 | color: #0099FF; |
| 461 | 375 | } |
| 462 | 376 | |
| 463 | - &.hm { | |
| 377 | + &.hm { | |
| 464 | 378 | margin: 0px 0px; |
| 465 | 379 | } |
| 466 | 380 | |
| 467 | - &.vm { | |
| 381 | + &.vm { | |
| 468 | 382 | margin: 5px 0px; |
| 469 | 383 | } |
| 470 | 384 | } |
| 471 | 385 | |
| 472 | 386 | /** Notes **/ |
| 473 | 387 | |
| 474 | -#notes-list { | |
| 388 | +#notes-list { | |
| 475 | 389 | display:block; |
| 476 | 390 | list-style:none; |
| 477 | 391 | margin:0px; |
| 478 | 392 | padding:0px; |
| 479 | - | |
| 480 | - li { | |
| 481 | - display:list-item; | |
| 482 | - padding:8px; | |
| 483 | - margin:0px; | |
| 484 | - background: #F7FBFC; | |
| 485 | - border-top: 1px solid #E2EAEE; | |
| 486 | - | |
| 487 | - &:first-child { | |
| 488 | - border-top: none; | |
| 489 | - } | |
| 490 | - &:nth-child(2n+1) { | |
| 491 | - background: white; | |
| 492 | - } | |
| 493 | - p { | |
| 494 | - margin-bottom: 4px; | |
| 495 | - font-size: 13px; | |
| 496 | - color:#111; | |
| 497 | - } | |
| 498 | - } | |
| 499 | - cite { | |
| 500 | - &.ago { | |
| 501 | - color:#666; | |
| 502 | - } | |
| 503 | - } | |
| 504 | 393 | } |
| 505 | 394 | |
| 506 | -.notes_count { | |
| 395 | +.notes_count { | |
| 507 | 396 | background: none repeat scroll 0 0 #FFF6BF; |
| 508 | 397 | border-color: #FFD324; |
| 509 | 398 | color: #514721; |
| ... | ... | @@ -515,36 +404,28 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 515 | 404 | right: 6px; |
| 516 | 405 | top: 6px; |
| 517 | 406 | } |
| 518 | -.note_author { | |
| 519 | - float:left; | |
| 520 | - width:60px; | |
| 521 | -} | |
| 522 | -.note_content { | |
| 523 | - float:left; | |
| 524 | - width:650px; | |
| 525 | -} | |
| 526 | 407 | |
| 527 | -.issue_notes { | |
| 528 | - .note_content { | |
| 408 | +.issue_notes { | |
| 409 | + .note_content { | |
| 529 | 410 | float:left; |
| 530 | 411 | width:400px; |
| 531 | 412 | } |
| 532 | 413 | } |
| 533 | 414 | |
| 534 | 415 | #user_projects_limit{ |
| 535 | - width: 60px; | |
| 416 | + width: 60px; | |
| 536 | 417 | } |
| 537 | 418 | |
| 538 | -.project_thumb { | |
| 419 | +.project_thumb { | |
| 539 | 420 | margin:20px 0; |
| 540 | 421 | width: 250px; |
| 541 | 422 | float:left; |
| 542 | 423 | padding:20px; |
| 543 | 424 | text-align:center; |
| 544 | - p, h4 { | |
| 425 | + p, h4 { | |
| 545 | 426 | text-align:left; |
| 546 | 427 | } |
| 547 | - .lbutton { | |
| 428 | + .lbutton { | |
| 548 | 429 | float:left; |
| 549 | 430 | } |
| 550 | 431 | } |
| ... | ... | @@ -559,8 +440,8 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 559 | 440 | padding: 10px; |
| 560 | 441 | } |
| 561 | 442 | |
| 562 | -.recent_message_parent { | |
| 563 | - img { | |
| 443 | +.recent_message_parent { | |
| 444 | + img { | |
| 564 | 445 | padding-right:10px; |
| 565 | 446 | } |
| 566 | 447 | |
| ... | ... | @@ -571,7 +452,7 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 571 | 452 | |
| 572 | 453 | &.dash_wall{ |
| 573 | 454 | border-bottom: 2px solid orange; |
| 574 | - span { | |
| 455 | + span { | |
| 575 | 456 | background: orange; |
| 576 | 457 | color:black; |
| 577 | 458 | } |
| ... | ... | @@ -579,14 +460,14 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 579 | 460 | |
| 580 | 461 | &.dash_issue{ |
| 581 | 462 | border-bottom: 2px solid #ffbbbb; |
| 582 | - span { | |
| 463 | + span { | |
| 583 | 464 | background: #ffbbbb; |
| 584 | 465 | } |
| 585 | 466 | } |
| 586 | 467 | &.dash_commit{ |
| 587 | 468 | border-bottom: 2px solid #bbbbff; |
| 588 | 469 | |
| 589 | - span{ | |
| 470 | + span{ | |
| 590 | 471 | background: #bbbbff; |
| 591 | 472 | } |
| 592 | 473 | } |
| ... | ... | @@ -594,27 +475,25 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 594 | 475 | &.dash_snippet{ |
| 595 | 476 | border-bottom: 2px solid #bbffbb; |
| 596 | 477 | |
| 597 | - span{ | |
| 478 | + span{ | |
| 598 | 479 | background: #bbffbb; |
| 599 | 480 | } |
| 600 | 481 | } |
| 601 | 482 | |
| 602 | - | |
| 603 | - span{ | |
| 483 | + span{ | |
| 604 | 484 | border: 1px solid #aaa; |
| 605 | 485 | color:black; |
| 606 | 486 | padding:1px 4px; |
| 607 | 487 | } |
| 608 | 488 | |
| 609 | - h4 { | |
| 489 | + h4 { | |
| 610 | 490 | margin-bottom:3px; |
| 611 | 491 | } |
| 612 | 492 | |
| 613 | 493 | } |
| 614 | 494 | .commit, |
| 615 | -.message, | |
| 616 | -#notes-list{ | |
| 617 | - .author { | |
| 495 | +.message{ | |
| 496 | + .author { | |
| 618 | 497 | background: #eaeaea; |
| 619 | 498 | color: #333; |
| 620 | 499 | border: 1px solid #aaa; |
| ... | ... | @@ -624,17 +503,17 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 624 | 503 | } |
| 625 | 504 | |
| 626 | 505 | /* Note textare */ |
| 627 | -#note_note { | |
| 506 | +#note_note { | |
| 628 | 507 | height:100px; |
| 629 | 508 | width:97%; |
| 630 | 509 | font-size:14px; |
| 631 | 510 | } |
| 632 | 511 | |
| 633 | -.wall_page { | |
| 634 | - #note_note { | |
| 512 | +#new_note { | |
| 513 | + #note_note { | |
| 635 | 514 | height:25px; |
| 636 | 515 | } |
| 637 | - .attach_holder { | |
| 516 | + .attach_holder { | |
| 638 | 517 | display:none; |
| 639 | 518 | } |
| 640 | 519 | } |
| ... | ... | @@ -652,32 +531,146 @@ tbody tr:nth-child(2n) td, tbody tr.even td { |
| 652 | 531 | @include round-borders-all(4px); |
| 653 | 532 | padding:2px 4px; |
| 654 | 533 | border:none; |
| 534 | + text-shadow:none; | |
| 655 | 535 | |
| 656 | - &.high { | |
| 536 | + &.high { | |
| 657 | 537 | background: #D12F19; |
| 658 | 538 | color:white; |
| 659 | 539 | } |
| 660 | 540 | |
| 661 | - &.today { | |
| 541 | + &.today { | |
| 662 | 542 | background: #44aa22; |
| 663 | 543 | color:white; |
| 664 | 544 | } |
| 665 | 545 | |
| 666 | - &.yours { | |
| 546 | + &.yours { | |
| 667 | 547 | background: #4466cc; |
| 668 | 548 | color:white; |
| 669 | 549 | } |
| 550 | + &.normal { | |
| 551 | + background: #2c5ca6; | |
| 552 | + color:white; | |
| 553 | + } | |
| 670 | 554 | &.notes { |
| 671 | 555 | background: #2c5c66; |
| 672 | 556 | color:white; |
| 673 | 557 | } |
| 674 | 558 | } |
| 675 | 559 | |
| 676 | -#issues-table .issue { | |
| 677 | - &.critical { | |
| 560 | +#issues-table .issue { | |
| 561 | + &.critical { | |
| 678 | 562 | td { |
| 679 | 563 | //background: #D12F19; |
| 680 | 564 | //color:#fff; |
| 681 | 565 | } |
| 682 | 566 | } |
| 683 | 567 | } |
| 568 | + | |
| 569 | +.top_panel_issues{ | |
| 570 | + #issue_search_form { | |
| 571 | + margin:5px 0; | |
| 572 | + input { | |
| 573 | + border:1px solid #D3D3D3; | |
| 574 | + padding: 3px; | |
| 575 | + height: 28px; | |
| 576 | + width: 300px; | |
| 577 | + -webkit-appearance:none; | |
| 578 | + box-sizing: border-box; | |
| 579 | + -moz-box-sizing: border-box; | |
| 580 | + | |
| 581 | + &:focus { | |
| 582 | + border-color:#c2e1ef; | |
| 583 | + } | |
| 584 | + } | |
| 585 | + } | |
| 586 | +} | |
| 587 | + | |
| 588 | +.left { | |
| 589 | + float:left; | |
| 590 | +} | |
| 591 | +.right { | |
| 592 | + float:right; | |
| 593 | +} | |
| 594 | + | |
| 595 | +.width-50p{ | |
| 596 | + width:50%; | |
| 597 | +} | |
| 598 | +.width-49p{ | |
| 599 | + width:49%; | |
| 600 | +} | |
| 601 | +.width-30p{ | |
| 602 | + width:30%; | |
| 603 | +} | |
| 604 | +.width-65p{ | |
| 605 | + width:65%; | |
| 606 | +} | |
| 607 | +pre.commit_message { | |
| 608 | + white-space: pre-wrap; | |
| 609 | +} | |
| 610 | + | |
| 611 | +#container { | |
| 612 | + min-height:100%; | |
| 613 | +} | |
| 614 | +.ui-selectmenu{ | |
| 615 | + @include round-borders-all(4px); | |
| 616 | + margin-right:10px; | |
| 617 | + font-size:1.5em; | |
| 618 | + height:auto; | |
| 619 | + font-weight:bold; | |
| 620 | + .ui-selectmenu-status { | |
| 621 | + padding:3px 10px; | |
| 622 | + } | |
| 623 | +} | |
| 624 | + | |
| 625 | +td.code { | |
| 626 | + width: 100%; | |
| 627 | + .highlight { | |
| 628 | + margin-left: 55px; | |
| 629 | + overflow:auto; | |
| 630 | + overflow-y:hidden; | |
| 631 | + } | |
| 632 | +} | |
| 633 | +.highlight pre { | |
| 634 | + white-space: pre; | |
| 635 | + word-wrap:normal; | |
| 636 | +} | |
| 637 | + | |
| 638 | +.highlighttable tr:hover { | |
| 639 | + background:white; | |
| 640 | +} | |
| 641 | +table.highlighttable pre{ | |
| 642 | + line-height:16px !important; | |
| 643 | + font-size:12px !important; | |
| 644 | +} | |
| 645 | + | |
| 646 | +.project-refs-form { | |
| 647 | + span { | |
| 648 | + background: none !important; | |
| 649 | + position:static !important; | |
| 650 | + width:auto !important; | |
| 651 | + height: auto !important; | |
| 652 | + } | |
| 653 | +} | |
| 654 | + | |
| 655 | +.project-refs-select { | |
| 656 | + width:200px; | |
| 657 | +} | |
| 658 | + | |
| 659 | +.issues_filter { | |
| 660 | + margin-top:10px; | |
| 661 | + .left { | |
| 662 | + margin-right:15px; | |
| 663 | + } | |
| 664 | +} | |
| 665 | + | |
| 666 | +.cgray { color:gray; } | |
| 667 | +.cred { color:#D12F19; } | |
| 668 | +.cgreen { color:#44aa22; } | |
| 669 | + | |
| 670 | +body.project-page #notes-list .note {padding: 10px; border-bottom: 1px solid #eee; overflow: hidden; display: block;} | |
| 671 | +body.project-page #notes-list .note {padding: 10px; border-bottom: 1px solid #eee; overflow: hidden; display: block;} | |
| 672 | +body.project-page #notes-list .note img{float: left; margin-right: 10px;} | |
| 673 | +body.project-page #notes-list .note span.note-title{display: block;} | |
| 674 | +body.project-page #notes-list .note span.note-title{margin-bottom: 10px} | |
| 675 | +body.project-page #notes-list .note span.note-author{color: #999; font-weight: normal; font-style: italic;} | |
| 676 | +body.project-page #notes-list .note span.note-author strong{font-weight: bold; font-style: normal;} | ... | ... |
| ... | ... | @@ -0,0 +1,661 @@ |
| 1 | +/* HTML5 ✰ Boilerplate | |
| 2 | + * ==|== normalize ========================================================== | |
| 3 | + */ | |
| 4 | + | |
| 5 | +article, aside, details, figcaption, figure, footer, header, hgroup, nav, section { display: block; } | |
| 6 | +audio, canvas, video { display: inline-block; *display: inline; *zoom: 1; } | |
| 7 | +audio:not([controls]) { display: none; } | |
| 8 | +[hidden] { display: none; } | |
| 9 | + | |
| 10 | +html { font-size: 100%; overflow-y: scroll; -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; } | |
| 11 | +body { margin: 0; font-size: 13px; line-height: 1.231; } | |
| 12 | +body, button, input, select, textarea { font-family: sans-serif; color: #222; } | |
| 13 | + | |
| 14 | +::-moz-selection { background: #fe57a1; color: #fff; text-shadow: none; } | |
| 15 | +::selection { background: #fe57a1; color: #fff; text-shadow: none; } | |
| 16 | + | |
| 17 | +a { color: #00e; } | |
| 18 | +a:hover { color: #06e; } | |
| 19 | +a:focus { outline: thin dotted; } | |
| 20 | +a:hover, a:active { outline: 0; } | |
| 21 | + | |
| 22 | +abbr[title] { border-bottom: 1px dotted; } | |
| 23 | +b, strong { font-weight: bold; } | |
| 24 | +blockquote { margin: 1em 40px; } | |
| 25 | +dfn { font-style: italic; } | |
| 26 | +hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; } | |
| 27 | +ins { background: #ff9; color: #000; text-decoration: none; } | |
| 28 | +mark { background: #ff0; color: #000; font-style: italic; font-weight: bold; } | |
| 29 | +pre, code, kbd, samp { font-family: monospace, monospace; _font-family: 'courier new', monospace; font-size: 1em; } | |
| 30 | +pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; } | |
| 31 | +q { quotes: none; } | |
| 32 | +q:before, q:after { content: ""; content: none; } | |
| 33 | +small { font-size: 85%; } | |
| 34 | +sub, sup { font-size: 75%; line-height: 0; position: relative; vertical-align: baseline; } | |
| 35 | +sup { top: -0.5em; } | |
| 36 | +sub { bottom: -0.25em; } | |
| 37 | +ul, ol { margin: 1em 0; padding: 0 0 0 40px; } | |
| 38 | +dd { margin: 0 0 0 40px; } | |
| 39 | +nav ul, nav ol { list-style: none; list-style-image: none; margin: 0; padding: 0; } | |
| 40 | +img { border: 0; -ms-interpolation-mode: bicubic; vertical-align: middle; } | |
| 41 | +svg:not(:root) { overflow: hidden; } | |
| 42 | +figure { margin: 0; } | |
| 43 | + | |
| 44 | +form { margin: 0; } | |
| 45 | +fieldset { border: 0; margin: 0; padding: 0; } | |
| 46 | +label { cursor: pointer; } | |
| 47 | +legend { border: 0; *margin-left: -7px; padding: 0; } | |
| 48 | +button, input, select, textarea { font-size: 100%; margin: 0; vertical-align: baseline; *vertical-align: middle; } | |
| 49 | +button, input { line-height: normal; *overflow: visible; } | |
| 50 | +table button, table input { *overflow: auto; } | |
| 51 | +button, input[type="button"], input[type="reset"], input[type="submit"] { cursor: pointer; -webkit-appearance: button; } | |
| 52 | +input[type="checkbox"], input[type="radio"] { box-sizing: border-box; } | |
| 53 | +input[type="search"] { -webkit-appearance: textfield; -moz-box-sizing: content-box; -webkit-box-sizing: content-box; box-sizing: content-box; } | |
| 54 | +input[type="search"]::-webkit-search-decoration { -webkit-appearance: none; } | |
| 55 | +button::-moz-focus-inner, input::-moz-focus-inner { border: 0; padding: 0; } | |
| 56 | +textarea { overflow: auto; vertical-align: top; resize: vertical; } | |
| 57 | +input:valid, textarea:valid { } | |
| 58 | +input:invalid, textarea:invalid { background-color: #f0dddd; } | |
| 59 | + | |
| 60 | +table { border-collapse: collapse; border-spacing: 0; } | |
| 61 | +td { vertical-align: top; } | |
| 62 | + | |
| 63 | + | |
| 64 | +/* ==|== primary styles ===================================================== | |
| 65 | + Author: Ricardo Rauch | |
| 66 | + ========================================================================== */ | |
| 67 | + | |
| 68 | +/* 960gs */ | |
| 69 | +.container_4{width:98%;margin-left:1%;margin-right:1%}.grid_1,.grid_2,.grid_3,.grid_4{display:inline;float:left;position:relative;margin-left:1%;margin-right:1%}.alpha{margin-left:0}.omega{margin-right:0}.container_4 .grid_1{width:23.0%}.container_4 .grid_2{width:48.0%}.container_4 .grid_3{width:73.0%}.container_4 .grid_4{width:98.0%}.container_4 .prefix_1{padding-left:25.0%}.container_4 .prefix_2{padding-left:50.0%}.container_4 .prefix_3{padding-left:75.0%}.container_4 .suffix_1{padding-right:25.0%}.container_4 .suffix_2{padding-right:50.0%}.container_4 .suffix_3{padding-right:75.0%}.container_4 .push_1{left:25.0%}.container_4 .push_2{left:50.0%}.container_4 .push_3{left:75.0%}.container_4 .pull_1{left:-25.0%}.container_4 .pull_2{left:-50.0%}.container_4 .pull_3{left:-75.0%}.clear{clear:both;display:block;overflow:hidden;visibility:hidden;width:0;height:0}.clearfix:after{clear:both;content:' ';display:block;font-size:0;line-height:0;visibility:hidden;width:0;height:0}.clearfix{display:inline-block}* html .clearfix{height:1%}.clearfix{display:block} | |
| 70 | +/* eo 960gs*/ | |
| 71 | + | |
| 72 | +/* Vars */ | |
| 73 | +$color: "#4BB8D2"; | |
| 74 | +$blue_link: "#2fa0bb"; | |
| 75 | +/* eo Vars */ | |
| 76 | + | |
| 77 | +html{ -webkit-font-smoothing:antialiased; } | |
| 78 | +*{text-shadow: 0 1px 0 white} | |
| 79 | +body{font-size: 12px; background-color: #eee;} | |
| 80 | +a{text-decoration: none; font-weight: bold; color: #666} | |
| 81 | +a:hover{color: #333} | |
| 82 | +/* Typography */ | |
| 83 | +h1,h2,h3,h4,h5{font-weight: normal; color: #666} | |
| 84 | +h2{margin: 1.5em 0} | |
| 85 | +/* eo Typography */ | |
| 86 | + | |
| 87 | +/* Forms */ | |
| 88 | +input[type="text"]:focus, input[type="password"]:focus { outline: none; } | |
| 89 | +input.text{border: 1px solid #ccc; border-radius: 4px; display: block; padding: 10px} | |
| 90 | +/* eo Forms */ | |
| 91 | + | |
| 92 | +/* Tables */ | |
| 93 | +table {width:100%; border: 1px solid #DEE2E3} | |
| 94 | +table thead{ | |
| 95 | + -webkit-border-top-left-radius: 5px; | |
| 96 | + -webkit-border-top-right-radius: 5px; | |
| 97 | + -moz-border-radius-topleft: 5px; | |
| 98 | + -moz-border-radius-topright: 5px; | |
| 99 | + border-top-left-radius: 5px; | |
| 100 | + border-top-right-radius: 5px; | |
| 101 | +} | |
| 102 | +table thead th{ | |
| 103 | + background-image: -webkit-gradient(linear, 0 0, 0 26, color-stop(0.076, #fefefe), to(#F6F7F8)); | |
| 104 | + background-image: -webkit-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 105 | + background-image: -moz-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 106 | + background-image: -o-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 107 | + margin: 0; | |
| 108 | + font-weight: normal; | |
| 109 | + font-weight: bold; | |
| 110 | + text-align: left; | |
| 111 | + color: #97A0A5; | |
| 112 | +} | |
| 113 | +td, th{ padding: .9em 1em; vertical-align: middle; } | |
| 114 | + | |
| 115 | +table thead .image{width:100px} | |
| 116 | +table tr:hover, .listed_items tr.odd:hover{background-color:#FFFFCF} | |
| 117 | +/* eo Tables */ | |
| 118 | + | |
| 119 | + | |
| 120 | +/* Buttons */ | |
| 121 | +.grey-button{ | |
| 122 | + border-radius: 5px; | |
| 123 | + font-size: 12px; | |
| 124 | + font-weight: bold; | |
| 125 | + padding: 6px 20px; | |
| 126 | + border: 1px solid #999; | |
| 127 | + color: #666; | |
| 128 | + display: inline-block; | |
| 129 | + box-shadow: 0 1px 2px rgba(0,0,0,.3); | |
| 130 | + background-image: -webkit-gradient(linear, 0 0, 0 26, color-stop(0.076, #f7f7f7), to(#d5d5d5)); | |
| 131 | + background-image: -webkit-linear-gradient(#f7f7f7 7.6%, #d5d5d5); | |
| 132 | + background-image: -moz-linear-gradient(#f7f7f7 7.6%, #d5d5d5); | |
| 133 | + background-image: -o-linear-gradient(#f7f7f7 7.6%, #d5d5d5); | |
| 134 | +} | |
| 135 | + | |
| 136 | +.button{ | |
| 137 | + padding: 10px 20px; | |
| 138 | + text-align: center; | |
| 139 | + display: inline-block; | |
| 140 | + border-radius: 5px; | |
| 141 | + color: #578E91; | |
| 142 | + font-size: 12px; | |
| 143 | + text-transform: uppercase; | |
| 144 | + border: 1px solid #8CE2E6; | |
| 145 | + background-image: -webkit-gradient(linear, 0 0, 0 34, color-stop(0.794, #dbf5f6), to(#c5eef0)); | |
| 146 | + background-image: -webkit-linear-gradient(#dbf5f6 79.4%, #c5eef0); | |
| 147 | + background-image: -moz-linear-gradient(#dbf5f6 79.4%, #c5eef0); | |
| 148 | + background-image: -o-linear-gradient(#dbf5f6 79.4%, #c5eef0); | |
| 149 | +} | |
| 150 | + | |
| 151 | +.button:hover {color: rgba(0,0,0,.8)} | |
| 152 | + | |
| 153 | +.button.green {margin-right: 0; } | |
| 154 | + | |
| 155 | +.button.yellow{ | |
| 156 | + color: #908054; | |
| 157 | + border-color: #DDCDA1; | |
| 158 | + background-image: -webkit-gradient(linear, 0 0, 0 34, color-stop(0.794, #FFEFC3), to(#F3E3B7)); | |
| 159 | + background-image: -webkit-linear-gradient(#FFEFC3 79.4%, #F3E3B7); | |
| 160 | + background-image: -moz-linear-gradient(#FFEFC3 79.4%, #F3E3B7); | |
| 161 | + background-image: -o-linear-gradient(#FFEFC3 79.4%, #F3E3B7); | |
| 162 | +} | |
| 163 | + | |
| 164 | +.button.blue{ | |
| 165 | + color: #417E97; | |
| 166 | + border-color: #b2cdec; | |
| 167 | + background-image: -webkit-gradient(linear, 0 0, 0 34, color-stop(0.794, #dbe8f6), to(#c7daf1)); | |
| 168 | + background-image: -webkit-linear-gradient(#dbe8f6 79.4%, #c7daf1); | |
| 169 | + background-image: -moz-linear-gradient(#dbe8f6 79.4%, #c7daf1); | |
| 170 | + background-image: -o-linear-gradient(#dbe8f6 79.4%, #c7daf1); | |
| 171 | +} | |
| 172 | + | |
| 173 | +.button-small{ text-shadow: none; padding: 4px 10px; } | |
| 174 | +.button-green{background: #A6B807; color: white} | |
| 175 | + | |
| 176 | +/* eo Buttons */ | |
| 177 | + | |
| 178 | +/* UI Box */ | |
| 179 | +.ui-box{border: 1px solid #DEDFE1; float: left; border-radius: 5px} | |
| 180 | +.ui-box h3{ | |
| 181 | + background-image: -webkit-gradient(linear, 0 0, 0 26, color-stop(0.076, #fefefe), to(#F6F7F8)); | |
| 182 | + background-image: -webkit-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 183 | + background-image: -moz-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 184 | + background-image: -o-linear-gradient(#fefefe 7.6%, #F6F7F8); | |
| 185 | + margin: 0; | |
| 186 | + padding: 1em; | |
| 187 | + font-size: 12px; | |
| 188 | + font-weight: normal; | |
| 189 | + font-weight: bold; | |
| 190 | + font-size: 16px; | |
| 191 | + border-bottom: 1px solid #DEDFE1; | |
| 192 | + -webkit-border-top-left-radius: 5px; | |
| 193 | + -webkit-border-top-right-radius: 5px; | |
| 194 | + -moz-border-radius-topleft: 5px; | |
| 195 | + -moz-border-radius-topright: 5px; | |
| 196 | + border-top-left-radius: 5px; | |
| 197 | + border-top-right-radius: 5px; | |
| 198 | +} | |
| 199 | + | |
| 200 | +.ui-box.ui-box-small h3{ | |
| 201 | + padding: 8px 10px; | |
| 202 | + font-size: 12px; | |
| 203 | +} | |
| 204 | + | |
| 205 | + | |
| 206 | +.ui-box .data{padding: .5em 1em} | |
| 207 | + | |
| 208 | +.ui-box .buttons{background-color: #f7f8f9; padding: 1em; | |
| 209 | + -webkit-border-bottom-right-radius: 5px; | |
| 210 | + -webkit-border-bottom-left-radius: 5px; | |
| 211 | + -moz-border-radius-bottomright: 5px; | |
| 212 | + -moz-border-radius-bottomleft: 5px; | |
| 213 | + border-bottom-right-radius: 5px; | |
| 214 | + border-bottom-left-radius: 5px; | |
| 215 | +} | |
| 216 | + | |
| 217 | +.ui-box .buttons .button{padding: 8px 9px; font-size: 11px} | |
| 218 | + | |
| 219 | +.ui-box.hover:hover{box-shadow: 0 0 10px rgba(0,0,0,.1); border: 1px solid #ccc; | |
| 220 | + | |
| 221 | + -webkit-transition: all 200ms cubic-bezier(0.470, 0.000, 0.745, 0.715); | |
| 222 | + -moz-transition: all 200ms cubic-bezier(0.470, 0.000, 0.745, 0.715); | |
| 223 | + -o-transition: all 200ms cubic-bezier(0.470, 0.000, 0.745, 0.715); | |
| 224 | + transition: all 200ms cubic-bezier(0.470, 0.000, 0.745, 0.715); | |
| 225 | +} | |
| 226 | + | |
| 227 | +/* eo UI Box */ | |
| 228 | + | |
| 229 | +/* Login Page */ | |
| 230 | +body.login-page{background-color: #f1f1f1; padding-top: 10%} | |
| 231 | + | |
| 232 | +.login-box{ | |
| 233 | + width: 304px; | |
| 234 | + position: relative; | |
| 235 | + border-radius: 5px; | |
| 236 | + margin: auto; | |
| 237 | + padding: 20px; | |
| 238 | + background: white; | |
| 239 | + box-shadow: rgba(0, 0, 0, 0.07) 0 1px 0,white 0 2px 0,rgba(0, 0, 0, 0.07) 0 3px 0,white 0 4px 0, rgba(0, 0, 0, 0.07) 0 5px 0; | |
| 240 | +} | |
| 241 | + | |
| 242 | +.login-box .login-logo{ | |
| 243 | + margin: 10px 0 30px 0; | |
| 244 | + display: block; | |
| 245 | +} | |
| 246 | + | |
| 247 | +.login-box input.text{background-color: #f1f1f1; font-size: 16px; border-radius: 0; padding: 14px 10px; width: 280px} | |
| 248 | + | |
| 249 | +.login-box input.text.top{ | |
| 250 | + -webkit-border-top-left-radius: 5px; | |
| 251 | + -webkit-border-top-right-radius: 5px; | |
| 252 | + -moz-border-radius-topleft: 5px; | |
| 253 | + -moz-border-radius-topright: 5px; | |
| 254 | + border-top-left-radius: 5px; | |
| 255 | + border-top-right-radius: 5px; | |
| 256 | +} | |
| 257 | + | |
| 258 | +.login-box input.text.bottom{ | |
| 259 | + -webkit-border-bottom-right-radius: 5px; | |
| 260 | + -webkit-border-bottom-left-radius: 5px; | |
| 261 | + -moz-border-radius-bottomright: 5px; | |
| 262 | + -moz-border-radius-bottomleft: 5px; | |
| 263 | + border-bottom-right-radius: 5px; | |
| 264 | + border-bottom-left-radius: 5px; | |
| 265 | + border-top: 0; | |
| 266 | + margin-bottom: 20px; | |
| 267 | +} | |
| 268 | + | |
| 269 | +.login-box a.forgot{float: right; padding-top: 6px} | |
| 270 | + | |
| 271 | + | |
| 272 | +/* Icons */ | |
| 273 | +.directory, .file{ | |
| 274 | + display: inline-block; | |
| 275 | + margin-right: 10px; | |
| 276 | + width: 14px; | |
| 277 | +} | |
| 278 | + | |
| 279 | +.directory{ | |
| 280 | + background: url('images.png') no-repeat -73px -26px; | |
| 281 | + height: 11px; | |
| 282 | + margin-bottom: -1px; | |
| 283 | +} | |
| 284 | + | |
| 285 | +.file{ | |
| 286 | + background: url('images.png') no-repeat -114px -24px; | |
| 287 | + height: 16px; | |
| 288 | + margin-bottom: -3px; | |
| 289 | +} | |
| 290 | + | |
| 291 | +/* eo Icons*/ | |
| 292 | + | |
| 293 | +/* General */ | |
| 294 | +#container{background-color: white; overflow: hidden;} | |
| 295 | +body.collapsed #container{margin: auto; width: 980px; border: 1px solid rgba(0,0,0,.22); border-top: 0; box-shadow: 0 0 0px 4px rgba(0,0,0,.04)} | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | +/* Header */ | |
| 300 | +header{background: #474D57 url('bg-header.png') repeat-x bottom; z-index: 10000; height: 44px; padding: 10px 2% 6px 2%} | |
| 301 | +header a{color: white; text-shadow: 0 -1px 0 black} | |
| 302 | +header a:hover{color: #f1f1f1} | |
| 303 | +header h1{ | |
| 304 | + width: 65px; | |
| 305 | +} | |
| 306 | +header h1.logo{margin: 0; padding: 0} | |
| 307 | +header h1.logo a{ | |
| 308 | + background: url('images.png') no-repeat -3px -7px; | |
| 309 | + width: 65px; | |
| 310 | + height: 26px; | |
| 311 | + margin: 5px 0; | |
| 312 | + padding: 0; | |
| 313 | + display: block; | |
| 314 | + float: left; | |
| 315 | + text-indent: -1000em; | |
| 316 | +} | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | +header nav{border-radius: 4px; box-shadow: 0 1px 2px black; width: 294px; margin: auto; | |
| 321 | + background-image: -webkit-gradient(linear, 0 0, 0 30, color-stop(0.066, #595d63), to(#31363e)); | |
| 322 | + background-image: -webkit-linear-gradient(#595d63 6.6%, #31363e); | |
| 323 | + background-image: -moz-linear-gradient(#595d63 6.6%, #31363e); | |
| 324 | + background-image: -o-linear-gradient(#595d63 6.6%, #31363e); | |
| 325 | + margin-top: 2px; | |
| 326 | + height:30px | |
| 327 | +} | |
| 328 | +header nav a{padding: 8px 12px 8px 34px; display: inline-block; color: #D6DADF; border-right: 1px solid #31363E; position: relative; box-shadow: 1px 0 0 rgba(255,255,255,.1); margin: 0} | |
| 329 | +header nav a span{width: 20px; height: 20px; display: inline-block; background: red; position: absolute; left: 8px; top: 6px;} | |
| 330 | +header nav a:last-child {border: 0; box-shadow: none} | |
| 331 | +header nav a:hover, header nav a.current{ | |
| 332 | + background-image: -webkit-gradient(linear, 0 0, 0 30, color-stop(0.066, #595d63), to(#2c2f35)); | |
| 333 | + background-image: -webkit-linear-gradient(#595d63 6.6%, #2c2f35); | |
| 334 | + background-image: -moz-linear-gradient(#595d63 6.6%, #202227); | |
| 335 | + background-image: -o-linear-gradient(#595d63 6.6%, #202227); | |
| 336 | +} | |
| 337 | + | |
| 338 | +header nav a:active{ | |
| 339 | + box-shadow: 0 1px 4px rgba(0,0,0,.8) inset; | |
| 340 | +} | |
| 341 | + | |
| 342 | + | |
| 343 | +header nav a.dashboard { | |
| 344 | + -webkit-border-top-left-radius: 4px; | |
| 345 | + -webkit-border-bottom-left-radius: 4px; | |
| 346 | + -moz-border-radius-topleft: 4px; | |
| 347 | + -moz-border-radius-bottomleft: 4px; | |
| 348 | + border-top-left-radius: 4px; | |
| 349 | + border-bottom-left-radius: 4px; | |
| 350 | +} | |
| 351 | + | |
| 352 | +header nav a.admin{ | |
| 353 | + -webkit-border-top-right-radius: 4px; | |
| 354 | + -webkit-border-bottom-right-radius: 4px; | |
| 355 | + -moz-border-radius-topright: 4px; | |
| 356 | + -moz-border-radius-bottomright: 4px; | |
| 357 | + border-top-right-radius: 4px; | |
| 358 | + border-bottom-right-radius: 4px; | |
| 359 | +} | |
| 360 | + | |
| 361 | + | |
| 362 | +header .search{ display: inline-block; float: right; margin-right: 10px} | |
| 363 | + | |
| 364 | +header nav a span{width: 20px; height: 20px; display: inline-block; background: red; position: absolute; left: 8px; top: 6px;} | |
| 365 | + | |
| 366 | +header nav a.dashboard span{background: url('images.png') no-repeat -161px 0;} | |
| 367 | +header nav a.admin span{background: url('images.png') no-repeat -184px 0;} | |
| 368 | +header nav a.project span{background: url('images.png') no-repeat -209px -1px; top: 7px} | |
| 369 | +/* | |
| 370 | + | |
| 371 | +header nav a span{width: 20px; height: 20px; display: inline-block; background: red; position: absolute; left: 8px; top: 14px;} | |
| 372 | + | |
| 373 | +header nav a.dashboard.current span{ background-position: -163px -22px; } | |
| 374 | +header nav a.admin.current span{ background-position: -186px -22px;} | |
| 375 | +header nav a.project.current span{ background-position: -211px -23px;} | |
| 376 | + | |
| 377 | +header nav a.project span{background: url('images.png') no-repeat -209px -1px; top: 15px} | |
| 378 | + | |
| 379 | + | |
| 380 | +header nav a span.current{top: 18px} | |
| 381 | + | |
| 382 | + | |
| 383 | +header nav {margin-left: 180px; display: inline-block; float: left;} | |
| 384 | +header nav a{float: left; background: #31363e; padding: 16px 20px 20px 34px; margin-right: 10px; | |
| 385 | + -webkit-border-top-left-radius: 5px; | |
| 386 | + -webkit-border-top-right-radius: 5px; | |
| 387 | + -moz-border-radius-topleft: 5px; | |
| 388 | + -moz-border-radius-topright: 5px; | |
| 389 | + border-top-left-radius: 5px; | |
| 390 | + border-top-right-radius: 5px; | |
| 391 | + position: relative; | |
| 392 | +} | |
| 393 | + | |
| 394 | +header nav a.current{background: white; color: #333; text-shadow: none;} | |
| 395 | +*/ | |
| 396 | + | |
| 397 | +header .login-top{float: right; width: 180px; | |
| 398 | + background-image: -webkit-gradient(linear, 0 0, 0 62, color-stop(0.032, #464c56), to(#363c45)); | |
| 399 | + background-image: -webkit-linear-gradient(#464c56 3.2%, #363c45); | |
| 400 | + background-image: -moz-linear-gradient(#464c56 3.2%, #363c45); | |
| 401 | + background-image: -o-linear-gradient(#464c56 3.2%, #363c45); | |
| 402 | + padding: 0 10px; | |
| 403 | + height: 44px; | |
| 404 | +} | |
| 405 | +header .login-top a{display: block;} | |
| 406 | +header .login-top a.pic{float: left; margin-right: 10px; | |
| 407 | + img{ height: 36px; width: 36px; border: 1px solid black} | |
| 408 | +} | |
| 409 | +header .login-top a.username{margin-bottom: 5px} | |
| 410 | +header .login-top a.logout{color: #ccc} | |
| 411 | +header{margin-bottom: 0; clear: both; } | |
| 412 | + | |
| 413 | +.page-title{background-color: #f1f1f1;display: block; float: left; clear: both; width: 98%; padding: 1% 1%; border-bottom: 1px solid #ccc; box-shadow: 0 -1px 0 white inset; margin-bottom: 1.5em} | |
| 414 | +.page-title h1{font-size: 20px; width: 400px; margin: 0; padding-top: 8px } | |
| 415 | +.page-title a.grey-button{float: right;} | |
| 416 | +.right{float: right;} | |
| 417 | + | |
| 418 | +/* Account box */ | |
| 419 | +header .account-box{position: relative;z-index: 10000; top: -3px; width: 38px; height: 38px; font-size: 11px; float: right; display: block; cursor: pointer; } | |
| 420 | +header .account-box img{ border-radius: 4px; width: 38px; height: 38px; display: block; box-shadow: 0 1px 2px black} | |
| 421 | +header .account-box:after{ | |
| 422 | + content: " "; | |
| 423 | + display: block; | |
| 424 | + position: absolute; | |
| 425 | + top: 0; | |
| 426 | + right: 0; | |
| 427 | +left: 0; | |
| 428 | + bottom: 0; | |
| 429 | +float: right; | |
| 430 | + border-radius: 5px; | |
| 431 | + border: 1px solid rgba(255, 255, 255, .1); | |
| 432 | + border-bottom: 0; | |
| 433 | + background: -webkit-gradient(linear, 0% 0%, 0% 100%, from(rgba(255, 255, 255, .15)), to(rgba(0, 0, 0, .25))), -webkit-gradient(linear, left top, right bottom, color-stop(0, rgba(255, 255, 255, 0)), color-stop(0.5, rgba(255, 255, 255, .1)), color-stop(0.501, rgba(255, 255, 255, 0)), color-stop(1, rgba(255, 255, 255, 0))); | |
| 434 | + background: -moz-linear-gradient(top, rgba(255, 255, 255, .15), rgba(0, 0, 0, .25)), -moz-linear-gradient(left top, rgba(255, 255, 255, 0), rgba(255, 255, 255, .1) 50%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0)); | |
| 435 | + background: linear-gradient(top, rgba(255, 255, 255, .15), rgba(0, 0, 0, .25)), linear-gradient(left top, rgba(255, 255, 255, 0), rgba(255, 255, 255, .1) 50%, rgba(255, 255, 255, 0) 50%, rgba(255, 255, 255, 0)); | |
| 436 | + -webkit-background-origin: border-box; | |
| 437 | + -moz-background-origin: border; | |
| 438 | + background-origin: border-box; | |
| 439 | +} | |
| 440 | + | |
| 441 | +.account-box:hover > .account-links, .account-box:hover > .arrow-up{display: block;} | |
| 442 | +header .account-links{background: white; display: none; border-radius: 5px; width: 100px; margin-top: 0; float: right; box-shadow: 0 1px 1px rgba(0,0,0,.2); } | |
| 443 | +header .account-links a{color: #666; padding: 6px 10px; display: block; text-shadow: none; border-bottom: 1px solid #eee} | |
| 444 | +header .account-links a:hover{background-color: #f1f1f1; text-shadow: none; color: #333} | |
| 445 | + | |
| 446 | +header .account-links a:first-child{ | |
| 447 | + -webkit-border-top-left-radius: 5px; | |
| 448 | + -webkit-border-top-right-radius: 5px; | |
| 449 | + -moz-border-radius-topleft: 5px; | |
| 450 | + -moz-border-radius-topright: 5px; | |
| 451 | + border-top-left-radius: 5px; | |
| 452 | + border-top-right-radius: 5px; | |
| 453 | +} | |
| 454 | + | |
| 455 | +header .account-links a:last-child{ | |
| 456 | + -webkit-border-bottom-right-radius: 5px; | |
| 457 | + -webkit-border-bottom-left-radius: 5px; | |
| 458 | + -moz-border-radius-bottomright: 5px; | |
| 459 | + -moz-border-radius-bottomleft: 5px; | |
| 460 | + border-bottom-right-radius: 5px; | |
| 461 | + border-bottom-left-radius: 5px; | |
| 462 | + border-bottom: 0; | |
| 463 | +} | |
| 464 | + | |
| 465 | +header a.arrow-up{ | |
| 466 | + display: none; | |
| 467 | + width: 0; | |
| 468 | + height: 0; | |
| 469 | + float: right; | |
| 470 | + margin-right: 26px; | |
| 471 | + margin-bottom: 0; | |
| 472 | + border-left: 5px solid transparent; | |
| 473 | + border-right: 5px solid transparent; | |
| 474 | + | |
| 475 | + border-bottom: 5px solid white; | |
| 476 | +} | |
| 477 | +/* eo Account Box */ | |
| 478 | +input.search-input{float: left; text-shadow: none; width: 116px; background-image: url('icon-search.png') ; background-repeat: no-repeat; background-position: 10px; border-radius: 100px; border: 1px solid rgba(0,0,0,.7); box-shadow: 0 1px 0 rgba(255,255,255,.2), 0 2px 2px rgba(0,0,0,.4) inset ; background-color: #D2D5DA; background-color: rgba(255,255,255,.5); padding: 5px; padding-left: 26px; margin-top: 4px; margin-right: 10px } | |
| 479 | +input.search-input:focus{ background-color: white; width: 216px;} | |
| 480 | +input.search-input::-webkit-input-placeholder {color: #666} | |
| 481 | +/* eo Header */ | |
| 482 | + | |
| 483 | + | |
| 484 | +h2.icon{position: relative; padding-left: 40px; float: left; } | |
| 485 | +/*h2 a{font-weight: normal;}*/ | |
| 486 | +h2.icon span{background: #E3E5EA url('images.png'); height: 32px; width: 32px; left: 0; top: -5px; border-radius: 4px; display: inline-block; position: absolute} | |
| 487 | + | |
| 488 | + | |
| 489 | + | |
| 490 | +/* Dashboard Page */ | |
| 491 | +html, body { height: 100%; } | |
| 492 | + | |
| 493 | +body.dashboard-page h2.icon span{ background-position: 9px -69px; } | |
| 494 | +body.dashboard-page header{margin-bottom: 0} | |
| 495 | +body.dashboard-page .news-feed{padding-left: 1em; margin-right: 450px; margin-left: 1%} | |
| 496 | +body.dashboard-page .dashboard-content{ position: relative; float: left; width: 100%; height: 100%; } | |
| 497 | +body.dashboard-page .news-feed h2{float: left;} | |
| 498 | +body.dashboard-page aside{ width: 420px; float: right; right: 0; height: 100%; bottom: 0; position: absolute; background-color: #f7f7f7; border-left: 1px solid #ccc } | |
| 499 | +body.dashboard-page aside h4{margin: 0; border-bottom: 1px solid #ccc; padding: 10px 10px; font-size: 11px; font-weight: bold; text-transform: uppercase;} | |
| 500 | +body.dashboard-page aside h4 a.button-small{float: right; text-transform: none; border-radius: 4px; margin-right: 4%; margin-top: -4px; display: block;} | |
| 501 | +body.dashboard-page aside .project-list {list-style: none; margin: 0; padding: 0;} | |
| 502 | +body.dashboard-page aside .project-list li a {background: white; color: #{$blue_link}; display: block; border-bottom: 1px solid #eee; padding: 14px 6% 14px 14px;} | |
| 503 | +body.dashboard-page aside .project-list li a:hover {background: #f1f1f1} | |
| 504 | +body.dashboard-page aside .project-list li a:hover span.arrow{background-color: #E3E5EA;} | |
| 505 | +body.dashboard-page aside .project-list li a span.project-name{font-size: 14px; display: block; margin-bottom: 8px} | |
| 506 | +body.dashboard-page aside .project-list li a span.time{color: #666; font-weight: normal; font-size: 11px} | |
| 507 | +body.dashboard-page aside .project-list li a span.arrow{float: right; background: #E3E5EA; padding: 10px; border-radius: 5px; margin-top: 2px; text-shadow: none; color: #999} | |
| 508 | +body.dashboard-page .news-feed .project-updates {margin-bottom: 20px; display: block; width: 100%;} | |
| 509 | +body.dashboard-page .news-feed .project-updates .data{ padding: 0} | |
| 510 | +body.dashboard-page .news-feed .project-updates a.project-update {padding: 10px; border-bottom: 1px solid #eee; overflow: hidden; display: block;} | |
| 511 | +body.dashboard-page .news-feed .project-updates a.project-update:last-child{border-bottom: 0} | |
| 512 | +body.dashboard-page .news-feed .project-updates a.project-update img{float: left; margin-right: 10px;} | |
| 513 | +body.dashboard-page .news-feed .project-updates a.project-update span.update-title, .dashboard-page .news-feed .project-updates li a span.update-author{display: block;} | |
| 514 | +body.dashboard-page .news-feed .project-updates a.project-update span.update-title{margin-bottom: 10px} | |
| 515 | +body.dashboard-page .news-feed .project-updates a.project-update span.update-author{color: #999; font-weight: normal; font-style: italic;} | |
| 516 | +body.dashboard-page .news-feed .project-updates a.project-update span.update-author strong{font-weight: bold; font-style: normal;} | |
| 517 | +/* eo Dashboard Page */ | |
| 518 | + | |
| 519 | + | |
| 520 | +.grey-button.right{margin-top: 20px} | |
| 521 | + | |
| 522 | +/* Project Page */ | |
| 523 | + | |
| 524 | +body.project-page h2.icon .project-name, body.project-page h2.icon d{border: 1px solid #eee; padding: 5px 30px 5px 10px; border-radius: 5px; position: relative;} | |
| 525 | +body.project-page h2.icon .project-name i.arrow{float: right; | |
| 526 | + position: absolute; | |
| 527 | + right: 10px; | |
| 528 | + top: 13px; | |
| 529 | + display: block; | |
| 530 | + background: url('images.png') no-repeat -97px -29px; | |
| 531 | + width: 4px; | |
| 532 | + height: 5px; | |
| 533 | +} | |
| 534 | + | |
| 535 | + | |
| 536 | + | |
| 537 | +body.project-page h2.icon span{ background-position: -78px -68px; } | |
| 538 | +body.project-page .project-container{ position: relative; float: left; width: 100%; height: 100%; } | |
| 539 | +body.project-page .page-title{margin-bottom: 0} | |
| 540 | +body.project-page .project-sidebar {width: 220px; left: 0; top: 0; height: 100%; bottom: 0; position: absolute; background-color: #f7f7f7; border-left: 1px solid #ccc; float: left; display: inline-block; background: #f7f7f7; padding: 20px 0 20px 2%; margin: 0; } | |
| 541 | +body.project-page .project-sidebar input.text.git-url{ font-size: 12px; border-radius: 5px; color: #666; box-shadow: 0 1px 2px rgba(0,0,0,.2) inset; padding: 8px 14px 8px 30px; margin-bottom: 20px; background: white url('images.png') no-repeat 8px -40px;} | |
| 542 | +body.project-page .project-sidebar aside{width: 219px} | |
| 543 | +body.project-page .project-sidebar aside a{display: block; position: relative; background: white; padding: 15px 10px; border-bottom: 1px solid #eee} | |
| 544 | +body.project-page .project-sidebar aside a:first-child{ | |
| 545 | + -webkit-border-top-left-radius: 5px; | |
| 546 | + -moz-border-radius-topleft: 5px; | |
| 547 | + border-top-left-radius: 5px; | |
| 548 | +} | |
| 549 | +.project-page .project-sidebar aside a:last-child{ | |
| 550 | + -webkit-border-bottom-left-radius: 5px; | |
| 551 | + -moz-border-radius-bottomleft: 5px; | |
| 552 | + border-bottom-left-radius: 5px; | |
| 553 | +} | |
| 554 | +body.project-page .project-sidebar aside a:hover{background-color: #eee;} | |
| 555 | +body.project-page .project-sidebar aside a span.number{float: right; border-radius: 5px; text-shadow: none; background: rgba(0,0,0,.12); text-align: center; padding: 5px 8px; position: absolute; top: 10px; right: 10px} | |
| 556 | +body.project-page .project-sidebar aside a.current{background-color: #79c3e0; color: white; text-shadow: none; border-color: transparent} | |
| 557 | +body.project-page .project-content{ padding: 20px; display: block; margin-left: 250px } | |
| 558 | +body.project-page .project-content h2{ margin-top: 6px} | |
| 559 | +body.project-page .project-content .button.right{margin-left: 20px} | |
| 560 | +body.project-page table .commit a{color: #{$blue_link}} | |
| 561 | +body.project-page table th, body.project-page table td{ border-bottom: 1px solid #DEE2E3;} | |
| 562 | +body.project-page .fixed{position: fixed; } | |
| 563 | + | |
| 564 | +/* Commit Page */ | |
| 565 | +body.project-page.commits-page .commit-info{float: right;} | |
| 566 | +body.project-page.commits-page .commit-info data{ | |
| 567 | + padding: 4px 10px; | |
| 568 | + font-size: 11px; | |
| 569 | +} | |
| 570 | +body.project-page.commits-page .commit-info data.commit-button{ | |
| 571 | + background-image: -webkit-gradient(linear, 0 0, 0 26, color-stop(0.192, #fff), to(#f4f4f4)); | |
| 572 | + background-image: -webkit-linear-gradient(#fff 19.2%, #f4f4f4); | |
| 573 | + background-image: -moz-linear-gradient(#fff 19.2%, #f4f4f4); | |
| 574 | + background-image: -o-linear-gradient(#fff 19.2%, #f4f4f4); | |
| 575 | + box-shadow: 0 -1px 0 white inset; | |
| 576 | + display: block; | |
| 577 | + border: 1px solid #eee; | |
| 578 | + border-radius: 5px; | |
| 579 | + margin-bottom: 2px; | |
| 580 | + position: relative; | |
| 581 | + padding-right: 20px; | |
| 582 | +} | |
| 583 | + | |
| 584 | + | |
| 585 | +body.project-page.commits-page .commit-button i{ | |
| 586 | + background: url('images.png') no-repeat -138px -27px; | |
| 587 | + width: 6px; | |
| 588 | + height: 9px; | |
| 589 | + float: right; | |
| 590 | + position: absolute; | |
| 591 | + top: 6px; | |
| 592 | + right: 5px; | |
| 593 | +} | |
| 594 | +body.project-page.commits-page .commits-date {display: block; width: 100%; margin-bottom: 20px} | |
| 595 | +body.project-page.commits-page .commits-date .data {padding: 0} | |
| 596 | +body.project-page.commits-page a.commit{padding: 10px; border-bottom: 1px solid #eee; overflow: hidden; display: block;} | |
| 597 | +body.project-page.commits-page .commits-date a.commit {padding: 10px; border-bottom: 1px solid #eee; overflow: hidden; display: block;} | |
| 598 | +body.project-page.commits-page .commits-date a.commit:last-child{border-bottom: 0} | |
| 599 | +body.project-page.commits-page .commits-date a.commit img{float: left; margin-right: 10px;} | |
| 600 | +body.project-page.commits-page .commits-date a.commit span.commit-title{display: block;} | |
| 601 | +body.project-page.commits-page .commits-date a.commit span.commit-title{margin-bottom: 10px} | |
| 602 | +body.project-page.commits-page .commits-date a.commit span.commit-author{color: #999; font-weight: normal; font-style: italic;} | |
| 603 | +body.project-page.commits-page .commits-date a.commit span.commit-author strong{font-weight: bold; font-style: normal;} | |
| 604 | + | |
| 605 | +/* eo Commit Page */ | |
| 606 | + | |
| 607 | +/* eo Project Page */ | |
| 608 | + | |
| 609 | + | |
| 610 | + | |
| 611 | + | |
| 612 | +/* Projects Page */ | |
| 613 | +body.projects-page h2.icon span{background-position: -31px -70px;} | |
| 614 | +body.projects-page .project-box.ui-box .data .repository {margin-bottom: 20px} | |
| 615 | +body.projects-page .project-box.ui-box .data .title span{ font-weight: bold;} | |
| 616 | +body.projects-page .project-box{width: 100%; margin-bottom: 3em} | |
| 617 | +body.projects-page .browse-code{margin-right: 10px} | |
| 618 | +/* eo Projects Page */ | |
| 619 | + | |
| 620 | + | |
| 621 | +/* ==|== non-semantic helper classes ======================================== */ | |
| 622 | +.ir { display: block; border: 0; text-indent: -999em; overflow: hidden; background-color: transparent; background-repeat: no-repeat; text-align: left; direction: ltr; } | |
| 623 | +.ir br { display: none; } | |
| 624 | +.hidden { display: none !important; visibility: hidden; } | |
| 625 | +.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; } | |
| 626 | +.visuallyhidden.focusable:active, .visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; } | |
| 627 | +.invisible { visibility: hidden; } | |
| 628 | +.clearfix:before, .clearfix:after { content: ""; display: table; } | |
| 629 | +.clearfix:after { clear: both; } | |
| 630 | +.clearfix { zoom: 1; } | |
| 631 | + | |
| 632 | + | |
| 633 | +/* ==|== media queries ====================================================== */ | |
| 634 | + | |
| 635 | +@media only screen and (min-width: 480px) { | |
| 636 | + | |
| 637 | + | |
| 638 | +} | |
| 639 | + | |
| 640 | +@media only screen and (min-width: 768px) { | |
| 641 | + | |
| 642 | +} | |
| 643 | + | |
| 644 | + | |
| 645 | + | |
| 646 | +/* ==|== print styles ======================================================= */ | |
| 647 | + | |
| 648 | +@media print { | |
| 649 | + * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; -ms-filter: none !important; } | |
| 650 | + a, a:visited { text-decoration: underline; } | |
| 651 | + a[href]:after { content: " (" attr(href) ")"; } | |
| 652 | + abbr[title]:after { content: " (" attr(title) ")"; } | |
| 653 | + .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; } | |
| 654 | + pre, blockquote { border: 1px solid #999; page-break-inside: avoid; } | |
| 655 | + thead { display: table-header-group; } | |
| 656 | + tr, img { page-break-inside: avoid; } | |
| 657 | + img { max-width: 100% !important; } | |
| 658 | + @page { margin: 0.5cm; } | |
| 659 | + p, h2, h3 { orphans: 3; widows: 3; } | |
| 660 | + h2, h3 { page-break-after: avoid; } | |
| 661 | +} | ... | ... |
| ... | ... | @@ -0,0 +1,30 @@ |
| 1 | +.tags-list { | |
| 2 | + padding : 0px 10px 10px 10px; | |
| 3 | + | |
| 4 | +} | |
| 5 | + | |
| 6 | +.tags-list a { | |
| 7 | + display: inline-block; | |
| 8 | + padding: 8px 11px 8px 11px; | |
| 9 | + margin: 1px 5px 0px 0px; | |
| 10 | + border-radius: 4px; | |
| 11 | + border: 1px solid #72bbdf; | |
| 12 | + background-color: #72bbdf; | |
| 13 | + color: #0f326d; | |
| 14 | + font-weight: bold; | |
| 15 | + font-size: 14px; | |
| 16 | +} | |
| 17 | + | |
| 18 | + | |
| 19 | +.small-tags a{ | |
| 20 | + font-size: 9px; | |
| 21 | + | |
| 22 | + display: inline-block; | |
| 23 | + padding: 2px 3px 1px 3px; | |
| 24 | + margin: 0px 3px 0px 0px; | |
| 25 | + border-radius: 2px; | |
| 26 | + background-color: #72bbdf; | |
| 27 | + color: #FFF; | |
| 28 | + text-shadow: none; | |
| 29 | + font-weight: bold; | |
| 30 | +} | |
| 0 | 31 | \ No newline at end of file | ... | ... |
app/controllers/admin/mailer_controller.rb
| 1 | 1 | class Admin::MailerController < ApplicationController |
| 2 | + layout "admin" | |
| 2 | 3 | before_filter :authenticate_user! |
| 3 | 4 | before_filter :authenticate_admin! |
| 4 | 5 | |
| ... | ... | @@ -20,7 +21,7 @@ class Admin::MailerController < ApplicationController |
| 20 | 21 | else |
| 21 | 22 | render :file => 'notify/note_wall_email.html.haml', :layout => 'notify' |
| 22 | 23 | end |
| 23 | - rescue | |
| 24 | + rescue | |
| 24 | 25 | render :text => "Preview not avaialble" |
| 25 | 26 | end |
| 26 | 27 | |
| ... | ... | @@ -29,7 +30,7 @@ class Admin::MailerController < ApplicationController |
| 29 | 30 | @password = "DHasJKDHAS!" |
| 30 | 31 | |
| 31 | 32 | render :file => 'notify/new_user_email.html.haml', :layout => 'notify' |
| 32 | - rescue | |
| 33 | + rescue | |
| 33 | 34 | render :text => "Preview not avaialble" |
| 34 | 35 | end |
| 35 | 36 | |
| ... | ... | @@ -38,7 +39,7 @@ class Admin::MailerController < ApplicationController |
| 38 | 39 | @user = @issue.assignee |
| 39 | 40 | @project = @issue.project |
| 40 | 41 | render :file => 'notify/new_issue_email.html.haml', :layout => 'notify' |
| 41 | - rescue | |
| 42 | + rescue | |
| 42 | 43 | render :text => "Preview not avaialble" |
| 43 | 44 | end |
| 44 | 45 | end | ... | ... |
app/controllers/admin/projects_controller.rb
| 1 | 1 | class Admin::ProjectsController < ApplicationController |
| 2 | + layout "admin" | |
| 2 | 3 | before_filter :authenticate_user! |
| 3 | 4 | before_filter :authenticate_admin! |
| 4 | 5 | |
| 5 | 6 | def index |
| 6 | 7 | @admin_projects = Project.page(params[:page]) |
| 7 | - | |
| 8 | - respond_to do |format| | |
| 9 | - format.html # index.html.erb | |
| 10 | - format.json { render json: @admin_projects } | |
| 11 | - end | |
| 12 | 8 | end |
| 13 | 9 | |
| 14 | 10 | def show |
| 15 | 11 | @admin_project = Project.find_by_code(params[:id]) |
| 16 | - | |
| 17 | - respond_to do |format| | |
| 18 | - format.html # show.html.erb | |
| 19 | - format.json { render json: @admin_project } | |
| 20 | - end | |
| 21 | 12 | end |
| 22 | 13 | |
| 23 | 14 | def new |
| 24 | 15 | @admin_project = Project.new |
| 25 | - | |
| 26 | - respond_to do |format| | |
| 27 | - format.html # new.html.erb | |
| 28 | - format.json { render json: @admin_project } | |
| 29 | - end | |
| 30 | 16 | end |
| 31 | 17 | |
| 32 | 18 | def edit |
| ... | ... | @@ -37,28 +23,20 @@ class Admin::ProjectsController < ApplicationController |
| 37 | 23 | @admin_project = Project.new(params[:project]) |
| 38 | 24 | @admin_project.owner = current_user |
| 39 | 25 | |
| 40 | - respond_to do |format| | |
| 41 | - if @admin_project.save | |
| 42 | - format.html { redirect_to [:admin, @admin_project], notice: 'Project was successfully created.' } | |
| 43 | - format.json { render json: @admin_project, status: :created, location: @admin_project } | |
| 44 | - else | |
| 45 | - format.html { render action: "new" } | |
| 46 | - format.json { render json: @admin_project.errors, status: :unprocessable_entity } | |
| 47 | - end | |
| 26 | + if @admin_project.save | |
| 27 | + redirect_to [:admin, @admin_project], notice: 'Project was successfully created.' | |
| 28 | + else | |
| 29 | + render :action => "new" | |
| 48 | 30 | end |
| 49 | 31 | end |
| 50 | 32 | |
| 51 | 33 | def update |
| 52 | 34 | @admin_project = Project.find_by_code(params[:id]) |
| 53 | 35 | |
| 54 | - respond_to do |format| | |
| 55 | - if @admin_project.update_attributes(params[:project]) | |
| 56 | - format.html { redirect_to [:admin, @admin_project], notice: 'Project was successfully updated.' } | |
| 57 | - format.json { head :ok } | |
| 58 | - else | |
| 59 | - format.html { render action: "edit" } | |
| 60 | - format.json { render json: @admin_project.errors, status: :unprocessable_entity } | |
| 61 | - end | |
| 36 | + if @admin_project.update_attributes(params[:project]) | |
| 37 | + redirect_to [:admin, @admin_project], notice: 'Project was successfully updated.' | |
| 38 | + else | |
| 39 | + render :action => "edit" | |
| 62 | 40 | end |
| 63 | 41 | end |
| 64 | 42 | |
| ... | ... | @@ -66,9 +44,6 @@ class Admin::ProjectsController < ApplicationController |
| 66 | 44 | @admin_project = Project.find_by_code(params[:id]) |
| 67 | 45 | @admin_project.destroy |
| 68 | 46 | |
| 69 | - respond_to do |format| | |
| 70 | - format.html { redirect_to admin_projects_url } | |
| 71 | - format.json { head :ok } | |
| 72 | - end | |
| 47 | + redirect_to admin_projects_url | |
| 73 | 48 | end |
| 74 | 49 | end | ... | ... |
app/controllers/admin/team_members_controller.rb
| 1 | 1 | class Admin::TeamMembersController < ApplicationController |
| 2 | + layout "admin" | |
| 2 | 3 | before_filter :authenticate_user! |
| 3 | 4 | before_filter :authenticate_admin! |
| 4 | 5 | |
| 5 | 6 | def index |
| 6 | 7 | @admin_team_members = UsersProject.page(params[:page]).per(100).order("project_id DESC") |
| 7 | - | |
| 8 | - respond_to do |format| | |
| 9 | - format.html # index.html.erb | |
| 10 | - format.json { render json: @admin_team_members } | |
| 11 | - end | |
| 12 | 8 | end |
| 13 | 9 | |
| 14 | 10 | def show |
| 15 | 11 | @admin_team_member = UsersProject.find(params[:id]) |
| 16 | - | |
| 17 | - respond_to do |format| | |
| 18 | - format.html # show.html.erb | |
| 19 | - format.json { render json: @admin_team_member } | |
| 20 | - end | |
| 21 | 12 | end |
| 22 | 13 | |
| 23 | 14 | def new |
| 24 | 15 | @admin_team_member = UsersProject.new(params[:team_member]) |
| 25 | - | |
| 26 | - respond_to do |format| | |
| 27 | - format.html # new.html.erb | |
| 28 | - format.json { render json: @admin_team_member } | |
| 29 | - end | |
| 30 | 16 | end |
| 31 | 17 | |
| 32 | 18 | def edit |
| ... | ... | @@ -37,14 +23,10 @@ class Admin::TeamMembersController < ApplicationController |
| 37 | 23 | @admin_team_member = UsersProject.new(params[:team_member]) |
| 38 | 24 | @admin_team_member.project_id = params[:team_member][:project_id] |
| 39 | 25 | |
| 40 | - respond_to do |format| | |
| 41 | - if @admin_team_member.save | |
| 42 | - format.html { redirect_to admin_team_member_path(@admin_team_member), notice: 'UsersProject was successfully created.' } | |
| 43 | - format.json { render json: @admin_team_member, status: :created, location: @team_member } | |
| 44 | - else | |
| 45 | - format.html { render action: "new" } | |
| 46 | - format.json { render json: @admin_team_member.errors, status: :unprocessable_entity } | |
| 47 | - end | |
| 26 | + if @admin_team_member.save | |
| 27 | + redirect_to admin_team_member_path(@admin_team_member), notice: 'UsersProject was successfully created.' | |
| 28 | + else | |
| 29 | + render action: "new" | |
| 48 | 30 | end |
| 49 | 31 | end |
| 50 | 32 | |
| ... | ... | @@ -52,14 +34,10 @@ class Admin::TeamMembersController < ApplicationController |
| 52 | 34 | @admin_team_member = UsersProject.find(params[:id]) |
| 53 | 35 | @admin_team_member.project_id = params[:team_member][:project_id] |
| 54 | 36 | |
| 55 | - respond_to do |format| | |
| 56 | - if @admin_team_member.update_attributes(params[:team_member]) | |
| 57 | - format.html { redirect_to admin_team_member_path(@admin_team_member), notice: 'UsersProject was successfully updated.' } | |
| 58 | - format.json { head :ok } | |
| 59 | - else | |
| 60 | - format.html { render action: "edit" } | |
| 61 | - format.json { render json: @admin_team_member.errors, status: :unprocessable_entity } | |
| 62 | - end | |
| 37 | + if @admin_team_member.update_attributes(params[:team_member]) | |
| 38 | + redirect_to admin_team_member_path(@admin_team_member), notice: 'UsersProject was successfully updated.' | |
| 39 | + else | |
| 40 | + render action: "edit" | |
| 63 | 41 | end |
| 64 | 42 | end |
| 65 | 43 | |
| ... | ... | @@ -67,9 +45,6 @@ class Admin::TeamMembersController < ApplicationController |
| 67 | 45 | @admin_team_member = UsersProject.find(params[:id]) |
| 68 | 46 | @admin_team_member.destroy |
| 69 | 47 | |
| 70 | - respond_to do |format| | |
| 71 | - format.html { redirect_to admin_team_members_url } | |
| 72 | - format.json { head :ok } | |
| 73 | - end | |
| 48 | + redirect_to admin_team_members_url | |
| 74 | 49 | end |
| 75 | 50 | end | ... | ... |
app/controllers/admin/users_controller.rb
| 1 | 1 | class Admin::UsersController < ApplicationController |
| 2 | + layout "admin" | |
| 2 | 3 | before_filter :authenticate_user! |
| 3 | 4 | before_filter :authenticate_admin! |
| 4 | 5 | |
| 5 | 6 | def index |
| 6 | 7 | @admin_users = User.page(params[:page]) |
| 7 | - | |
| 8 | - respond_to do |format| | |
| 9 | - format.html # index.html.erb | |
| 10 | - format.json { render json: @admin_users } | |
| 11 | - end | |
| 12 | 8 | end |
| 13 | 9 | |
| 14 | 10 | def show |
| 15 | 11 | @admin_user = User.find(params[:id]) |
| 16 | - | |
| 17 | - respond_to do |format| | |
| 18 | - format.html # show.html.erb | |
| 19 | - format.json { render json: @admin_user } | |
| 20 | - end | |
| 21 | 12 | end |
| 22 | 13 | |
| 23 | 14 | def new |
| 24 | 15 | @admin_user = User.new(:projects_limit => 10) |
| 25 | - | |
| 26 | - respond_to do |format| | |
| 27 | - format.html # new.html.erb | |
| 28 | - format.json { render json: @admin_user } | |
| 29 | - end | |
| 30 | 16 | end |
| 31 | 17 | |
| 32 | 18 | def edit |
| ... | ... | @@ -36,7 +22,7 @@ class Admin::UsersController < ApplicationController |
| 36 | 22 | def create |
| 37 | 23 | admin = params[:user].delete("admin") |
| 38 | 24 | |
| 39 | - @admin_user = User.new(params[:user]) | |
| 25 | + @admin_user = User.new(params[:user]) | |
| 40 | 26 | @admin_user.admin = (admin && admin.to_i > 0) |
| 41 | 27 | |
| 42 | 28 | respond_to do |format| |
| ... | ... | @@ -54,8 +40,8 @@ class Admin::UsersController < ApplicationController |
| 54 | 40 | def update |
| 55 | 41 | admin = params[:user].delete("admin") |
| 56 | 42 | if params[:user][:password].empty? |
| 57 | - params[:user].delete(:password) | |
| 58 | - params[:user].delete(:password_confirmation) | |
| 43 | + params[:user].delete(:password) | |
| 44 | + params[:user].delete(:password_confirmation) | |
| 59 | 45 | end |
| 60 | 46 | |
| 61 | 47 | @admin_user = User.find(params[:id]) | ... | ... |
app/controllers/application_controller.rb
| 1 | 1 | class ApplicationController < ActionController::Base |
| 2 | 2 | before_filter :authenticate_user! |
| 3 | + before_filter :view_style | |
| 4 | + | |
| 3 | 5 | protect_from_forgery |
| 4 | 6 | |
| 5 | 7 | helper_method :abilities, :can? |
| ... | ... | @@ -8,7 +10,17 @@ class ApplicationController < ActionController::Base |
| 8 | 10 | render :file => File.join(Rails.root, "public", "gitosis_error"), :layout => false |
| 9 | 11 | end |
| 10 | 12 | |
| 11 | - protected | |
| 13 | + layout :layout_by_resource | |
| 14 | + | |
| 15 | + protected | |
| 16 | + | |
| 17 | + def layout_by_resource | |
| 18 | + if devise_controller? | |
| 19 | + "devise" | |
| 20 | + else | |
| 21 | + "application" | |
| 22 | + end | |
| 23 | + end | |
| 12 | 24 | |
| 13 | 25 | def abilities |
| 14 | 26 | @abilities ||= Six.new |
| ... | ... | @@ -18,7 +30,7 @@ class ApplicationController < ActionController::Base |
| 18 | 30 | abilities.allowed?(object, action, subject) |
| 19 | 31 | end |
| 20 | 32 | |
| 21 | - def project | |
| 33 | + def project | |
| 22 | 34 | @project ||= Project.find_by_code(params[:project_id]) |
| 23 | 35 | end |
| 24 | 36 | |
| ... | ... | @@ -47,19 +59,13 @@ class ApplicationController < ActionController::Base |
| 47 | 59 | end |
| 48 | 60 | |
| 49 | 61 | def load_refs |
| 50 | - @branch = unless params[:branch].blank? | |
| 51 | - params[:branch] | |
| 52 | - else | |
| 53 | - nil | |
| 54 | - end | |
| 55 | - | |
| 56 | - @tag = unless params[:tag].blank? | |
| 57 | - params[:tag] | |
| 58 | - else | |
| 59 | - nil | |
| 60 | - end | |
| 61 | - | |
| 62 | - @ref = @branch || @tag || "master" | |
| 62 | + unless params[:ref].blank? | |
| 63 | + @ref = params[:ref] | |
| 64 | + else | |
| 65 | + @branch = params[:branch].blank? ? nil : params[:branch] | |
| 66 | + @tag = params[:tag].blank? ? nil : params[:tag] | |
| 67 | + @ref = @branch || @tag || "master" | |
| 68 | + end | |
| 63 | 69 | end |
| 64 | 70 | |
| 65 | 71 | def render_404 |
| ... | ... | @@ -69,4 +75,30 @@ class ApplicationController < ActionController::Base |
| 69 | 75 | def require_non_empty_project |
| 70 | 76 | redirect_to @project unless @project.repo_exists? |
| 71 | 77 | end |
| 78 | + | |
| 79 | + def view_style | |
| 80 | + if params[:view_style] == "collapsed" | |
| 81 | + cookies[:view_style] = "collapsed" | |
| 82 | + elsif params[:view_style] == "fluid" | |
| 83 | + cookies[:view_style] = "" | |
| 84 | + end | |
| 85 | + | |
| 86 | + @view_mode = if cookies[:view_style] == "collapsed" | |
| 87 | + :fixed | |
| 88 | + else | |
| 89 | + :fluid | |
| 90 | + end | |
| 91 | + end | |
| 92 | + | |
| 93 | + def respond_with_notes | |
| 94 | + if params[:last_id] && params[:first_id] | |
| 95 | + @notes = @notes.where("id >= ?", params[:first_id]) | |
| 96 | + elsif params[:last_id] | |
| 97 | + @notes = @notes.where("id > ?", params[:last_id]) | |
| 98 | + elsif params[:first_id] | |
| 99 | + @notes = @notes.where("id < ?", params[:first_id]) | |
| 100 | + else | |
| 101 | + nil | |
| 102 | + end | |
| 103 | + end | |
| 72 | 104 | end | ... | ... |
app/controllers/commits_controller.rb
| ... | ... | @@ -2,6 +2,7 @@ require "base64" |
| 2 | 2 | |
| 3 | 3 | class CommitsController < ApplicationController |
| 4 | 4 | before_filter :project |
| 5 | + layout "project" | |
| 5 | 6 | |
| 6 | 7 | # Authorize |
| 7 | 8 | before_filter :add_project_abilities |
| ... | ... | @@ -12,11 +13,12 @@ class CommitsController < ApplicationController |
| 12 | 13 | load_refs # load @branch, @tag & @ref |
| 13 | 14 | |
| 14 | 15 | @repo = project.repo |
| 16 | + limit, offset = (params[:limit] || 20), (params[:offset] || 0) | |
| 15 | 17 | |
| 16 | 18 | if params[:path] |
| 17 | - @commits = @repo.log(@ref, params[:path], :max_count => params[:limit] || 100, :skip => params[:offset] || 0) | |
| 19 | + @commits = @repo.log(@ref, params[:path], :max_count => limit, :skip => offset) | |
| 18 | 20 | else |
| 19 | - @commits = @repo.commits(@ref, params[:limit] || 100, params[:offset] || 0) | |
| 21 | + @commits = @repo.commits(@ref, limit, offset) | |
| 20 | 22 | end |
| 21 | 23 | |
| 22 | 24 | respond_to do |format| |
| ... | ... | @@ -27,12 +29,12 @@ class CommitsController < ApplicationController |
| 27 | 29 | |
| 28 | 30 | def show |
| 29 | 31 | @commit = project.repo.commits(params[:id]).first |
| 30 | - @notes = project.notes.where(:noteable_id => @commit.id, :noteable_type => "Commit") | |
| 32 | + @notes = project.notes.where(:noteable_id => @commit.id, :noteable_type => "Commit").order("created_at DESC").limit(20) | |
| 31 | 33 | @note = @project.notes.new(:noteable_id => @commit.id, :noteable_type => "Commit") |
| 32 | 34 | |
| 33 | - respond_to do |format| | |
| 34 | - format.html # show.html.erb | |
| 35 | - format.js | |
| 35 | + respond_to do |format| | |
| 36 | + format.html | |
| 37 | + format.js { respond_with_notes } | |
| 36 | 38 | end |
| 37 | 39 | end |
| 38 | 40 | end | ... | ... |
app/controllers/dashboard_controller.rb
app/controllers/issues_controller.rb
| 1 | 1 | class IssuesController < ApplicationController |
| 2 | 2 | before_filter :authenticate_user! |
| 3 | - before_filter :project | |
| 3 | + before_filter :project | |
| 4 | 4 | before_filter :issue, :only => [:edit, :update, :destroy, :show] |
| 5 | + layout "project" | |
| 5 | 6 | |
| 6 | 7 | # Authorize |
| 7 | 8 | before_filter :add_project_abilities |
| 8 | 9 | before_filter :authorize_read_issue! |
| 9 | - before_filter :authorize_write_issue!, :only => [:new, :create, :close, :edit, :update, :sort] | |
| 10 | + before_filter :authorize_write_issue!, :only => [:new, :create, :close, :edit, :update, :sort] | |
| 10 | 11 | |
| 11 | 12 | respond_to :js |
| 12 | 13 | |
| ... | ... | @@ -34,14 +35,19 @@ class IssuesController < ApplicationController |
| 34 | 35 | end |
| 35 | 36 | |
| 36 | 37 | def show |
| 37 | - @notes = @issue.notes | |
| 38 | + @notes = @issue.notes.order("created_at DESC").limit(20) | |
| 38 | 39 | @note = @project.notes.new(:noteable => @issue) |
| 40 | + | |
| 41 | + respond_to do |format| | |
| 42 | + format.html | |
| 43 | + format.js { respond_with_notes } | |
| 44 | + end | |
| 39 | 45 | end |
| 40 | 46 | |
| 41 | 47 | def create |
| 42 | 48 | @issue = @project.issues.new(params[:issue]) |
| 43 | 49 | @issue.author = current_user |
| 44 | - if @issue.save | |
| 50 | + if @issue.save && @issue.assignee != current_user | |
| 45 | 51 | Notify.new_issue_email(@issue).deliver |
| 46 | 52 | end |
| 47 | 53 | |
| ... | ... | @@ -57,14 +63,13 @@ class IssuesController < ApplicationController |
| 57 | 63 | end |
| 58 | 64 | end |
| 59 | 65 | |
| 60 | - | |
| 61 | 66 | def destroy |
| 62 | 67 | return access_denied! unless can?(current_user, :admin_issue, @issue) |
| 63 | 68 | |
| 64 | 69 | @issue.destroy |
| 65 | 70 | |
| 66 | 71 | respond_to do |format| |
| 67 | - format.js { render :nothing => true } | |
| 72 | + format.js { render :nothing => true } | |
| 68 | 73 | end |
| 69 | 74 | end |
| 70 | 75 | |
| ... | ... | @@ -78,7 +83,23 @@ class IssuesController < ApplicationController |
| 78 | 83 | render :nothing => true |
| 79 | 84 | end |
| 80 | 85 | |
| 81 | - protected | |
| 86 | + def search | |
| 87 | + terms = params['terms'] | |
| 88 | + | |
| 89 | + @project = Project.find(params['project']) | |
| 90 | + @issues = case params[:status].to_i | |
| 91 | + when 1 then @project.issues | |
| 92 | + when 2 then @project.issues.closed | |
| 93 | + when 3 then @project.issues.opened.assigned(current_user) | |
| 94 | + else @project.issues.opened | |
| 95 | + end | |
| 96 | + | |
| 97 | + @issues = @issues.where("title LIKE ? OR content LIKE ?", "%#{terms}%", "%#{terms}%") unless terms.blank? | |
| 98 | + | |
| 99 | + render :partial => 'issues' | |
| 100 | + end | |
| 101 | + | |
| 102 | + protected | |
| 82 | 103 | |
| 83 | 104 | def issue |
| 84 | 105 | @issue ||= @project.issues.find(params[:id]) | ... | ... |
app/controllers/keys_controller.rb
| 1 | 1 | class KeysController < ApplicationController |
| 2 | + layout "profile" | |
| 2 | 3 | respond_to :js |
| 3 | 4 | |
| 4 | 5 | def index |
| ... | ... | @@ -24,7 +25,7 @@ class KeysController < ApplicationController |
| 24 | 25 | |
| 25 | 26 | respond_to do |format| |
| 26 | 27 | format.html { redirect_to keys_url } |
| 27 | - format.js { render :nothing => true } | |
| 28 | + format.js { render :nothing => true } | |
| 28 | 29 | end |
| 29 | 30 | end |
| 30 | 31 | end | ... | ... |
app/controllers/notes_controller.rb
| 1 | 1 | class NotesController < ApplicationController |
| 2 | - before_filter :project | |
| 2 | + before_filter :project | |
| 3 | 3 | |
| 4 | 4 | # Authorize |
| 5 | 5 | before_filter :add_project_abilities |
| 6 | - before_filter :authorize_write_note!, :only => [:create] | |
| 6 | + before_filter :authorize_write_note!, :only => [:create] | |
| 7 | 7 | |
| 8 | 8 | respond_to :js |
| 9 | 9 | |
| ... | ... | @@ -15,10 +15,9 @@ class NotesController < ApplicationController |
| 15 | 15 | notify if params[:notify] == '1' |
| 16 | 16 | end |
| 17 | 17 | |
| 18 | - | |
| 19 | 18 | respond_to do |format| |
| 20 | 19 | format.html {redirect_to :back} |
| 21 | - format.js | |
| 20 | + format.js | |
| 22 | 21 | end |
| 23 | 22 | end |
| 24 | 23 | |
| ... | ... | @@ -30,11 +29,11 @@ class NotesController < ApplicationController |
| 30 | 29 | @note.destroy |
| 31 | 30 | |
| 32 | 31 | respond_to do |format| |
| 33 | - format.js { render :nothing => true } | |
| 32 | + format.js { render :nothing => true } | |
| 34 | 33 | end |
| 35 | 34 | end |
| 36 | 35 | |
| 37 | - protected | |
| 36 | + protected | |
| 38 | 37 | |
| 39 | 38 | def notify |
| 40 | 39 | @project.users.reject { |u| u.id == current_user.id } .each do |u| | ... | ... |
app/controllers/profile_controller.rb
| 1 | 1 | class ProfileController < ApplicationController |
| 2 | + layout "profile" | |
| 2 | 3 | def show |
| 3 | 4 | @user = current_user |
| 4 | 5 | end |
| ... | ... | @@ -14,7 +15,7 @@ class ProfileController < ApplicationController |
| 14 | 15 | end |
| 15 | 16 | |
| 16 | 17 | def password_update |
| 17 | - params[:user].reject!{ |k, v| k != "password" && k != "password_confirmation"} | |
| 18 | + params[:user].reject!{ |k, v| k != "password" && k != "password_confirmation"} | |
| 18 | 19 | @user = current_user |
| 19 | 20 | |
| 20 | 21 | if @user.update_attributes(params[:user]) | ... | ... |
app/controllers/projects_controller.rb
| 1 | 1 | class ProjectsController < ApplicationController |
| 2 | - before_filter :project, :except => [:index, :new, :create] | |
| 2 | + before_filter :project, :except => [:index, :new, :create] | |
| 3 | + layout :determine_layout | |
| 3 | 4 | |
| 4 | 5 | # Authorize |
| 5 | 6 | before_filter :add_project_abilities |
| 6 | - before_filter :authorize_read_project!, :except => [:index, :new, :create] | |
| 7 | - before_filter :authorize_admin_project!, :only => [:edit, :update, :destroy] | |
| 7 | + before_filter :authorize_read_project!, :except => [:index, :new, :create] | |
| 8 | + before_filter :authorize_admin_project!, :only => [:edit, :update, :destroy] | |
| 8 | 9 | |
| 9 | 10 | before_filter :require_non_empty_project, :only => [:blob, :tree] |
| 10 | 11 | |
| 11 | 12 | def index |
| 12 | - @projects = current_user.projects.all | |
| 13 | + source = current_user.projects | |
| 14 | + source = source.tagged_with(params[:tag]) unless params[:tag].blank? | |
| 15 | + @projects = source.all | |
| 13 | 16 | end |
| 14 | 17 | |
| 15 | 18 | def new |
| ... | ... | @@ -23,7 +26,7 @@ class ProjectsController < ApplicationController |
| 23 | 26 | @project = Project.new(params[:project]) |
| 24 | 27 | @project.owner = current_user |
| 25 | 28 | |
| 26 | - Project.transaction do | |
| 29 | + Project.transaction do | |
| 27 | 30 | @project.save! |
| 28 | 31 | @project.users_projects.create!(:admin => true, :read => true, :write => true, :user => current_user) |
| 29 | 32 | end |
| ... | ... | @@ -31,7 +34,7 @@ class ProjectsController < ApplicationController |
| 31 | 34 | respond_to do |format| |
| 32 | 35 | if @project.valid? |
| 33 | 36 | format.html { redirect_to @project, notice: 'Project was successfully created.' } |
| 34 | - format.js | |
| 37 | + format.js | |
| 35 | 38 | else |
| 36 | 39 | format.html { render action: "new" } |
| 37 | 40 | format.js |
| ... | ... | @@ -51,10 +54,10 @@ class ProjectsController < ApplicationController |
| 51 | 54 | respond_to do |format| |
| 52 | 55 | if project.update_attributes(params[:project]) |
| 53 | 56 | format.html { redirect_to project, :notice => 'Project was successfully updated.' } |
| 54 | - format.js | |
| 57 | + format.js | |
| 55 | 58 | else |
| 56 | 59 | format.html { render action: "edit" } |
| 57 | - format.js | |
| 60 | + format.js | |
| 58 | 61 | end |
| 59 | 62 | end |
| 60 | 63 | end |
| ... | ... | @@ -85,13 +88,12 @@ class ProjectsController < ApplicationController |
| 85 | 88 | def wall |
| 86 | 89 | @note = Note.new |
| 87 | 90 | @notes = @project.common_notes.order("created_at DESC") |
| 91 | + @notes = @notes.fresh.limit(20) | |
| 88 | 92 | |
| 89 | - @notes = case params[:view] | |
| 90 | - when "week" then @notes.since((Date.today - 7.days).at_beginning_of_day) | |
| 91 | - when "all" then @notes.all | |
| 92 | - when "day" then @notes.since(Date.today.at_beginning_of_day) | |
| 93 | - else @notes.fresh.limit(10) | |
| 94 | - end | |
| 93 | + respond_to do |format| | |
| 94 | + format.html | |
| 95 | + format.js { respond_with_notes } | |
| 96 | + end | |
| 95 | 97 | end |
| 96 | 98 | |
| 97 | 99 | # |
| ... | ... | @@ -105,7 +107,7 @@ class ProjectsController < ApplicationController |
| 105 | 107 | |
| 106 | 108 | if params[:commit_id] |
| 107 | 109 | @commit = @repo.commits(params[:commit_id]).first |
| 108 | - else | |
| 110 | + else | |
| 109 | 111 | @commit = @repo.commits(@ref || "master").first |
| 110 | 112 | end |
| 111 | 113 | |
| ... | ... | @@ -114,7 +116,7 @@ class ProjectsController < ApplicationController |
| 114 | 116 | |
| 115 | 117 | respond_to do |format| |
| 116 | 118 | format.html # show.html.erb |
| 117 | - format.js do | |
| 119 | + format.js do | |
| 118 | 120 | # diasbale cache to allow back button works |
| 119 | 121 | response.headers["Cache-Control"] = "no-cache, no-store, max-age=0, must-revalidate" |
| 120 | 122 | response.headers["Pragma"] = "no-cache" |
| ... | ... | @@ -132,7 +134,7 @@ class ProjectsController < ApplicationController |
| 132 | 134 | |
| 133 | 135 | if @tree.is_a?(Grit::Blob) |
| 134 | 136 | send_data(@tree.data, :type => @tree.mime_type, :disposition => 'inline', :filename => @tree.name) |
| 135 | - else | |
| 137 | + else | |
| 136 | 138 | head(404) |
| 137 | 139 | end |
| 138 | 140 | rescue |
| ... | ... | @@ -147,9 +149,17 @@ class ProjectsController < ApplicationController |
| 147 | 149 | end |
| 148 | 150 | end |
| 149 | 151 | |
| 150 | - protected | |
| 152 | + protected | |
| 151 | 153 | |
| 152 | - def project | |
| 154 | + def project | |
| 153 | 155 | @project ||= Project.find_by_code(params[:id]) |
| 154 | 156 | end |
| 157 | + | |
| 158 | + def determine_layout | |
| 159 | + if @project && !@project.new_record? | |
| 160 | + "project" | |
| 161 | + else | |
| 162 | + "application" | |
| 163 | + end | |
| 164 | + end | |
| 155 | 165 | end | ... | ... |
app/controllers/snippets_controller.rb
| 1 | 1 | class SnippetsController < ApplicationController |
| 2 | 2 | before_filter :authenticate_user! |
| 3 | - before_filter :project | |
| 3 | + before_filter :project | |
| 4 | + layout "project" | |
| 4 | 5 | |
| 5 | 6 | # Authorize |
| 6 | 7 | before_filter :add_project_abilities |
| 7 | 8 | before_filter :authorize_read_snippet! |
| 8 | - before_filter :authorize_write_snippet!, :only => [:new, :create, :close, :edit, :update, :sort] | |
| 9 | + before_filter :authorize_write_snippet!, :only => [:new, :create, :close, :edit, :update, :sort] | |
| 9 | 10 | |
| 10 | 11 | respond_to :html |
| 11 | 12 | |
| ... | ... | @@ -13,7 +14,7 @@ class SnippetsController < ApplicationController |
| 13 | 14 | @snippets = @project.snippets |
| 14 | 15 | end |
| 15 | 16 | |
| 16 | - def new | |
| 17 | + def new | |
| 17 | 18 | @snippet = @project.snippets.new |
| 18 | 19 | end |
| 19 | 20 | ... | ... |
| ... | ... | @@ -0,0 +1,11 @@ |
| 1 | +class TagsController < ApplicationController | |
| 2 | + def index | |
| 3 | + @tags = Project.tag_counts.order('count DESC') | |
| 4 | + @tags = @tags.where('name like ?', "%#{params[:term]}%") unless params[:term].blank? | |
| 5 | + | |
| 6 | + respond_to do |format| | |
| 7 | + format.html | |
| 8 | + format.json { render json: @tags.limit(8).map {|t| t.name}} | |
| 9 | + end | |
| 10 | + end | |
| 11 | +end | ... | ... |
app/controllers/team_members_controller.rb
| 1 | 1 | class TeamMembersController < ApplicationController |
| 2 | - before_filter :project | |
| 2 | + before_filter :project | |
| 3 | + layout "project" | |
| 3 | 4 | |
| 4 | 5 | # Authorize |
| 5 | 6 | before_filter :add_project_abilities |
| 6 | 7 | before_filter :authorize_read_project! |
| 7 | - before_filter :authorize_admin_project!, :only => [:new, :create, :destroy, :update] | |
| 8 | + before_filter :authorize_admin_project!, :only => [:new, :create, :destroy, :update] | |
| 8 | 9 | |
| 9 | 10 | def show |
| 10 | 11 | @team_member = project.users_projects.find(params[:id]) |
| ... | ... | @@ -26,7 +27,7 @@ class TeamMembersController < ApplicationController |
| 26 | 27 | |
| 27 | 28 | respond_to do |format| |
| 28 | 29 | format.js |
| 29 | - format.html do | |
| 30 | + format.html do | |
| 30 | 31 | unless @team_member.valid? |
| 31 | 32 | flash[:alert] = "User should have at least one role" |
| 32 | 33 | end |
| ... | ... | @@ -41,7 +42,7 @@ class TeamMembersController < ApplicationController |
| 41 | 42 | |
| 42 | 43 | respond_to do |format| |
| 43 | 44 | format.html { redirect_to root_path } |
| 44 | - format.js { render :nothing => true } | |
| 45 | + format.js { render :nothing => true } | |
| 45 | 46 | end |
| 46 | 47 | end |
| 47 | 48 | end | ... | ... |
app/helpers/application_helper.rb
| ... | ... | @@ -4,6 +4,14 @@ module ApplicationHelper |
| 4 | 4 | "http://www.gravatar.com/avatar/#{Digest::MD5.hexdigest(user_email)}?s=40&d=identicon" |
| 5 | 5 | end |
| 6 | 6 | |
| 7 | + def body_class(default_class = nil) | |
| 8 | + main = content_for(:body_class).blank? ? | |
| 9 | + default_class : | |
| 10 | + content_for(:body_class) | |
| 11 | + | |
| 12 | + [main, cookies[:view_style]].join(" ") | |
| 13 | + end | |
| 14 | + | |
| 7 | 15 | def commit_name(project, commit) |
| 8 | 16 | if project.commit.id == commit.id |
| 9 | 17 | "master" |
| ... | ... | @@ -23,18 +31,33 @@ module ApplicationHelper |
| 23 | 31 | end |
| 24 | 32 | |
| 25 | 33 | def last_commit(project) |
| 26 | - if project.repo_exists? | |
| 34 | + if project.repo_exists? | |
| 27 | 35 | time_ago_in_words(project.commit.committed_date) + " ago" |
| 28 | - else | |
| 36 | + else | |
| 29 | 37 | "Never" |
| 30 | 38 | end |
| 39 | + rescue | |
| 40 | + "Never" | |
| 41 | + end | |
| 42 | + | |
| 43 | + def grouped_options_refs | |
| 44 | + options = [ | |
| 45 | + ["Branch", @repo.heads.map(&:name) ], | |
| 46 | + [ "Tag", @project.tags ] | |
| 47 | + ] | |
| 48 | + | |
| 49 | + grouped_options_for_select(options, @ref) | |
| 50 | + end | |
| 51 | + | |
| 52 | + def markdown(text) | |
| 53 | + RDiscount.new(text, :autolink, :no_pseudo_protocols, :safelink, :smart, :filter_html).to_html.html_safe | |
| 31 | 54 | end |
| 32 | 55 | |
| 33 | 56 | def search_autocomplete_source |
| 34 | 57 | projects = current_user.projects.map{ |p| { :label => p.name, :url => project_path(p) } } |
| 35 | 58 | default_nav = [ |
| 36 | - { :label => "Keys", :url => keys_path }, | |
| 37 | - { :label => "Projects", :url => projects_path }, | |
| 59 | + { :label => "Keys", :url => keys_path }, | |
| 60 | + { :label => "Projects", :url => projects_path }, | |
| 38 | 61 | { :label => "Admin", :url => admin_root_path } |
| 39 | 62 | ] |
| 40 | 63 | |
| ... | ... | @@ -42,10 +65,10 @@ module ApplicationHelper |
| 42 | 65 | |
| 43 | 66 | if @project && !@project.new_record? |
| 44 | 67 | project_nav = [ |
| 45 | - { :label => "#{@project.code} / Issues", :url => project_issues_path(@project) }, | |
| 46 | - { :label => "#{@project.code} / Wall", :url => wall_project_path(@project) }, | |
| 47 | - { :label => "#{@project.code} / Tree", :url => tree_project_path(@project) }, | |
| 48 | - { :label => "#{@project.code} / Commits", :url => project_commits_path(@project) }, | |
| 68 | + { :label => "#{@project.code} / Issues", :url => project_issues_path(@project) }, | |
| 69 | + { :label => "#{@project.code} / Wall", :url => wall_project_path(@project) }, | |
| 70 | + { :label => "#{@project.code} / Tree", :url => tree_project_path(@project) }, | |
| 71 | + { :label => "#{@project.code} / Commits", :url => project_commits_path(@project) }, | |
| 49 | 72 | { :label => "#{@project.code} / Team", :url => team_project_path(@project) } |
| 50 | 73 | ] |
| 51 | 74 | end | ... | ... |
app/helpers/commits_helper.rb
| 1 | 1 | module CommitsHelper |
| 2 | 2 | def diff_line(line, line_new = 0, line_old = 0) |
| 3 | 3 | full_line = html_escape(line.gsub(/\n/, '')) |
| 4 | - color = if line[0] == "+" | |
| 4 | + color = if line[0] == "+" | |
| 5 | 5 | full_line = "<span class=\"old_line\"> </span><span class=\"new_line\">#{line_new}</span> " + full_line |
| 6 | 6 | "#DFD" |
| 7 | - elsif line[0] == "-" | |
| 7 | + elsif line[0] == "-" | |
| 8 | 8 | full_line = "<span class=\"old_line\">#{line_old}</span><span class=\"new_line\"> </span> " + full_line |
| 9 | 9 | "#FDD" |
| 10 | - else | |
| 10 | + else | |
| 11 | 11 | full_line = "<span class=\"old_line\">#{line_old}</span><span class=\"new_line\">#{line_new}</span> " + full_line |
| 12 | 12 | "none" |
| 13 | 13 | end | ... | ... |
app/helpers/dashboard_helper.rb
| 1 | 1 | module DashboardHelper |
| 2 | + def dashboard_feed_path(project, object) | |
| 3 | + case object.class.name.to_s | |
| 4 | + when "Issue" then project_issues_path(project, project.issues.find(object.id)) | |
| 5 | + when "Grit::Commit" then project_commit_path(project, project.repo.commits(object.id).first) | |
| 6 | + when "Note" | |
| 7 | + then | |
| 8 | + note = object | |
| 9 | + case note.noteable_type | |
| 10 | + when "Issue" then project_issue_path(project, note.noteable_id) | |
| 11 | + when "Snippet" then project_snippet_path(project, note.noteable_id) | |
| 12 | + when "Commit" then project_commit_path(project, :id => note.noteable_id) | |
| 13 | + else wall_project_path(project) | |
| 14 | + end | |
| 15 | + else "#" | |
| 16 | + end | |
| 17 | + rescue | |
| 18 | + "#" | |
| 19 | + end | |
| 20 | + | |
| 21 | + def dashboard_feed_title(object) | |
| 22 | + title = case object.class.name.to_s | |
| 23 | + when "Note" then markdown(object.note) | |
| 24 | + when "Issue" then object.title | |
| 25 | + when "Grit::Commit" then object.safe_message | |
| 26 | + else "" | |
| 27 | + end | |
| 28 | + "[#{object.class.name}] #{truncate(sanitize(title, :tags => []), :length => 60)} " | |
| 29 | + end | |
| 2 | 30 | end | ... | ... |
app/helpers/projects_helper.rb
app/helpers/snippets_helper.rb
app/models/ability.rb
| ... | ... | @@ -17,14 +17,14 @@ class Ability |
| 17 | 17 | :read_issue, |
| 18 | 18 | :read_snippet, |
| 19 | 19 | :read_team_member, |
| 20 | - :read_note | |
| 20 | + :read_note | |
| 21 | 21 | ] if project.readers.include?(user) |
| 22 | 22 | |
| 23 | 23 | rules << [ |
| 24 | 24 | :write_project, |
| 25 | 25 | :write_issue, |
| 26 | 26 | :write_snippet, |
| 27 | - :write_note | |
| 27 | + :write_note | |
| 28 | 28 | ] if project.writers.include?(user) |
| 29 | 29 | |
| 30 | 30 | rules << [ |
| ... | ... | @@ -32,13 +32,13 @@ class Ability |
| 32 | 32 | :admin_issue, |
| 33 | 33 | :admin_snippet, |
| 34 | 34 | :admin_team_member, |
| 35 | - :admin_note | |
| 35 | + :admin_note | |
| 36 | 36 | ] if project.admins.include?(user) |
| 37 | 37 | |
| 38 | 38 | rules.flatten |
| 39 | 39 | end |
| 40 | 40 | |
| 41 | - class << self | |
| 41 | + class << self | |
| 42 | 42 | [:issue, :note, :snippet].each do |name| |
| 43 | 43 | define_method "#{name}_abilities" do |user, subject| |
| 44 | 44 | if subject.author == user |
| ... | ... | @@ -48,7 +48,7 @@ class Ability |
| 48 | 48 | :"admin_#{name}" |
| 49 | 49 | ] |
| 50 | 50 | else |
| 51 | - subject.respond_to?(:project) ? | |
| 51 | + subject.respond_to?(:project) ? | |
| 52 | 52 | project_abilities(user, subject.project) : [] |
| 53 | 53 | end |
| 54 | 54 | end | ... | ... |
app/models/issue.rb
| ... | ... | @@ -10,13 +10,18 @@ class Issue < ActiveRecord::Base |
| 10 | 10 | validates_presence_of :assignee_id |
| 11 | 11 | validates_presence_of :author_id |
| 12 | 12 | |
| 13 | + delegate :name, | |
| 14 | + :email, | |
| 15 | + :to => :author, | |
| 16 | + :prefix => true | |
| 17 | + | |
| 13 | 18 | validates :title, |
| 14 | 19 | :presence => true, |
| 15 | 20 | :length => { :within => 0..255 } |
| 16 | - | |
| 17 | - validates :content, | |
| 18 | - :presence => true, | |
| 19 | - :length => { :within => 0..2000 } | |
| 21 | + | |
| 22 | + #validates :content, | |
| 23 | + #:presence => true, | |
| 24 | + #:length => { :within => 0..2000 } | |
| 20 | 25 | |
| 21 | 26 | scope :critical, where(:critical => true) |
| 22 | 27 | scope :non_critical, where(:critical => false) |
| ... | ... | @@ -30,7 +35,7 @@ class Issue < ActiveRecord::Base |
| 30 | 35 | def today? |
| 31 | 36 | Date.today == created_at.to_date |
| 32 | 37 | end |
| 33 | - | |
| 38 | + | |
| 34 | 39 | def new? |
| 35 | 40 | today? && created_at == updated_at |
| 36 | 41 | end | ... | ... |
app/models/key.rb
| ... | ... | @@ -8,7 +8,7 @@ class Key < ActiveRecord::Base |
| 8 | 8 | validates :key, |
| 9 | 9 | :presence => true, |
| 10 | 10 | :uniqueness => true, |
| 11 | - :length => { :within => 0..1024 } | |
| 11 | + :length => { :within => 0..1600 } | |
| 12 | 12 | |
| 13 | 13 | before_save :set_identifier |
| 14 | 14 | after_save :update_gitosis |
| ... | ... | @@ -17,11 +17,11 @@ class Key < ActiveRecord::Base |
| 17 | 17 | def set_identifier |
| 18 | 18 | self.identifier = "#{user.identifier}_#{Time.now.to_i}" |
| 19 | 19 | end |
| 20 | - | |
| 20 | + | |
| 21 | 21 | def update_gitosis |
| 22 | 22 | Gitosis.new.configure do |c| |
| 23 | 23 | c.update_keys(identifier, key) |
| 24 | - | |
| 24 | + | |
| 25 | 25 | projects.each do |project| |
| 26 | 26 | c.update_project(project.path, project.gitosis_writers) |
| 27 | 27 | end | ... | ... |
app/models/note.rb
| ... | ... | @@ -7,18 +7,23 @@ class Note < ActiveRecord::Base |
| 7 | 7 | belongs_to :author, |
| 8 | 8 | :class_name => "User" |
| 9 | 9 | |
| 10 | - attr_protected :author, :author_id | |
| 10 | + delegate :name, | |
| 11 | + :email, | |
| 12 | + :to => :author, | |
| 13 | + :prefix => true | |
| 14 | + | |
| 15 | + attr_protected :author, :author_id | |
| 11 | 16 | |
| 12 | 17 | validates_presence_of :project |
| 13 | 18 | |
| 14 | 19 | validates :note, |
| 15 | 20 | :presence => true, |
| 16 | - :length => { :within => 0..255 } | |
| 21 | + :length => { :within => 0..5000 } | |
| 17 | 22 | |
| 18 | - validates :attachment, | |
| 19 | - :file_size => { | |
| 20 | - :maximum => 10.megabytes.to_i | |
| 21 | - } | |
| 23 | + validates :attachment, | |
| 24 | + :file_size => { | |
| 25 | + :maximum => 10.megabytes.to_i | |
| 26 | + } | |
| 22 | 27 | |
| 23 | 28 | scope :common, where(:noteable_id => nil) |
| 24 | 29 | ... | ... |
app/models/project.rb
| ... | ... | @@ -9,6 +9,8 @@ class Project < ActiveRecord::Base |
| 9 | 9 | has_many :notes, :dependent => :destroy |
| 10 | 10 | has_many :snippets, :dependent => :destroy |
| 11 | 11 | |
| 12 | + acts_as_taggable | |
| 13 | + | |
| 12 | 14 | validates :name, |
| 13 | 15 | :uniqueness => true, |
| 14 | 16 | :presence => true, |
| ... | ... | @@ -20,7 +22,7 @@ class Project < ActiveRecord::Base |
| 20 | 22 | :format => { :with => /^[a-zA-Z0-9_\-]*$/, |
| 21 | 23 | :message => "only letters, digits & '_' '-' allowed" }, |
| 22 | 24 | :length => { :within => 0..255 } |
| 23 | - | |
| 25 | + | |
| 24 | 26 | validates :description, |
| 25 | 27 | :length => { :within => 0..2000 } |
| 26 | 28 | |
| ... | ... | @@ -57,13 +59,13 @@ class Project < ActiveRecord::Base |
| 57 | 59 | c.update_project(path, gitosis_writers) |
| 58 | 60 | end |
| 59 | 61 | end |
| 60 | - | |
| 62 | + | |
| 61 | 63 | def destroy_gitosis_project |
| 62 | 64 | Gitosis.new.configure do |c| |
| 63 | 65 | c.destroy_project(self) |
| 64 | 66 | end |
| 65 | 67 | end |
| 66 | - | |
| 68 | + | |
| 67 | 69 | def add_access(user, *access) |
| 68 | 70 | opts = { :user => user } |
| 69 | 71 | access.each { |name| opts.merge!(name => true) } |
| ... | ... | @@ -102,12 +104,12 @@ class Project < ActiveRecord::Base |
| 102 | 104 | def url_to_repo |
| 103 | 105 | "#{GITOSIS["git_user"]}@#{GITOSIS["host"]}:#{path}.git" |
| 104 | 106 | end |
| 105 | - | |
| 107 | + | |
| 106 | 108 | def path_to_repo |
| 107 | 109 | GITOSIS["base_path"] + path + ".git" |
| 108 | 110 | end |
| 109 | 111 | |
| 110 | - def repo | |
| 112 | + def repo | |
| 111 | 113 | @repo ||= Grit::Repo.new(path_to_repo) |
| 112 | 114 | end |
| 113 | 115 | |
| ... | ... | @@ -119,32 +121,52 @@ class Project < ActiveRecord::Base |
| 119 | 121 | repo rescue false |
| 120 | 122 | end |
| 121 | 123 | |
| 124 | + def last_activity | |
| 125 | + updates(1).first | |
| 126 | + rescue | |
| 127 | + nil | |
| 128 | + end | |
| 129 | + | |
| 130 | + def last_activity_date | |
| 131 | + last_activity.try(:created_at) | |
| 132 | + end | |
| 133 | + | |
| 134 | + def updates(n = 3) | |
| 135 | + [ | |
| 136 | + fresh_commits(n), | |
| 137 | + issues.last(n), | |
| 138 | + notes.fresh.limit(n) | |
| 139 | + ].compact.flatten.sort do |x, y| | |
| 140 | + y.created_at <=> x.created_at | |
| 141 | + end[0...n] | |
| 142 | + end | |
| 143 | + | |
| 122 | 144 | def commit(commit_id = nil) |
| 123 | 145 | if commit_id |
| 124 | 146 | repo.commits(commit_id).first |
| 125 | - else | |
| 147 | + else | |
| 126 | 148 | repo.commits.first |
| 127 | 149 | end |
| 128 | 150 | end |
| 129 | 151 | |
| 130 | - def heads | |
| 152 | + def heads | |
| 131 | 153 | @heads ||= repo.heads |
| 132 | 154 | end |
| 133 | 155 | |
| 134 | - def fresh_commits | |
| 135 | - commits = heads.map do |h| | |
| 136 | - repo.commits(h.name, 10) | |
| 156 | + def fresh_commits(n = 10) | |
| 157 | + commits = heads.map do |h| | |
| 158 | + repo.commits(h.name, n) | |
| 137 | 159 | end.flatten.uniq { |c| c.id } |
| 138 | 160 | |
| 139 | 161 | commits.sort! do |x, y| |
| 140 | 162 | y.committed_date <=> x.committed_date |
| 141 | 163 | end |
| 142 | 164 | |
| 143 | - commits[0..10] | |
| 165 | + commits[0...n] | |
| 144 | 166 | end |
| 145 | 167 | |
| 146 | 168 | def commits_since(date) |
| 147 | - commits = heads.map do |h| | |
| 169 | + commits = heads.map do |h| | |
| 148 | 170 | repo.log(h.name, nil, :since => date) |
| 149 | 171 | end.flatten.uniq { |c| c.id } |
| 150 | 172 | |
| ... | ... | @@ -165,7 +187,7 @@ class Project < ActiveRecord::Base |
| 165 | 187 | unless owner.can_create_project? |
| 166 | 188 | errors[:base] << ("Your own projects limit is #{owner.projects_limit}! Please contact administrator to increase it") |
| 167 | 189 | end |
| 168 | - rescue | |
| 190 | + rescue | |
| 169 | 191 | errors[:base] << ("Cant check your ability to create project") |
| 170 | 192 | end |
| 171 | 193 | ... | ... |
app/models/snippet.rb
| ... | ... | @@ -13,7 +13,7 @@ class Snippet < ActiveRecord::Base |
| 13 | 13 | validates :title, |
| 14 | 14 | :presence => true, |
| 15 | 15 | :length => { :within => 0..255 } |
| 16 | - | |
| 16 | + | |
| 17 | 17 | validates :file_name, |
| 18 | 18 | :presence => true, |
| 19 | 19 | :length => { :within => 0..255 } |
| ... | ... | @@ -22,9 +22,11 @@ class Snippet < ActiveRecord::Base |
| 22 | 22 | :presence => true, |
| 23 | 23 | :length => { :within => 0..10000 } |
| 24 | 24 | |
| 25 | + scope :fresh, order("created_at DESC") | |
| 26 | + scope :non_expired, where(["expires_at IS NULL OR expires_at > ?", Time.current]) | |
| 25 | 27 | |
| 26 | 28 | def self.content_types |
| 27 | - [ | |
| 29 | + [ | |
| 28 | 30 | ".rb", ".py", ".pl", ".scala", ".c", ".cpp", ".java", |
| 29 | 31 | ".haml", ".html", ".sass", ".scss", ".xml", ".php", ".erb", |
| 30 | 32 | ".js", ".sh", ".coffee", ".yml", ".md" |
| ... | ... | @@ -34,6 +36,10 @@ class Snippet < ActiveRecord::Base |
| 34 | 36 | def colorize |
| 35 | 37 | system_colorize(content, file_name) |
| 36 | 38 | end |
| 39 | + | |
| 40 | + def expired? | |
| 41 | + expires_at && expires_at < Time.current | |
| 42 | + end | |
| 37 | 43 | end |
| 38 | 44 | # == Schema Information |
| 39 | 45 | # |
| ... | ... | @@ -47,5 +53,6 @@ end |
| 47 | 53 | # created_at :datetime |
| 48 | 54 | # updated_at :datetime |
| 49 | 55 | # file_name :string(255) |
| 56 | +# expires_at :datetime | |
| 50 | 57 | # |
| 51 | 58 | ... | ... |
app/models/user.rb
| ... | ... | @@ -5,7 +5,7 @@ class User < ActiveRecord::Base |
| 5 | 5 | :recoverable, :rememberable, :trackable, :validatable |
| 6 | 6 | |
| 7 | 7 | # Setup accessible (or protected) attributes for your model |
| 8 | - attr_accessible :email, :password, :password_confirmation, :remember_me, | |
| 8 | + attr_accessible :email, :password, :password_confirmation, :remember_me, | |
| 9 | 9 | :name, :projects_limit, :skype, :linkedin, :twitter |
| 10 | 10 | |
| 11 | 11 | has_many :users_projects, :dependent => :destroy | ... | ... |
app/views/admin/mailer/preview.html.haml
| 1 | 1 | %p This is page with preview for all system emails that are sent to user |
| 2 | -%p Email previews built based on existing Project/Commit/Issue base - so some preview maybe unavailable unless object appear in system | |
| 2 | +%p Email previews built based on existing Project/Commit/Issue base - so some preview maybe unavailable unless object appear in system | |
| 3 | 3 | |
| 4 | 4 | #accordion |
| 5 | 5 | %h3 |
| 6 | 6 | %a New user |
| 7 | - %div | |
| 7 | + %div | |
| 8 | 8 | %iframe{ :src=> admin_mailer_preview_user_new_path, :width=>"100%", :height=>"350"} |
| 9 | 9 | %h3 |
| 10 | 10 | %a New issue |
| 11 | - %div | |
| 11 | + %div | |
| 12 | 12 | %iframe{ :src=> admin_mailer_preview_issue_new_path, :width=>"100%", :height=>"350"} |
| 13 | - %h3 | |
| 13 | + %h3 | |
| 14 | 14 | %a Commit note |
| 15 | 15 | %div |
| 16 | 16 | %iframe{ :src=> admin_mailer_preview_note_path(:type => "Commit"), :width=>"100%", :height=>"350"} |
| 17 | 17 | %h3 |
| 18 | 18 | %a Issue note |
| 19 | - %div | |
| 19 | + %div | |
| 20 | 20 | %iframe{ :src=> admin_mailer_preview_note_path(:type => "Issue"), :width=>"100%", :height=>"350"} |
| 21 | 21 | %h3 |
| 22 | 22 | %a Wall note |
| 23 | - %div | |
| 23 | + %div | |
| 24 | 24 | %iframe{ :src=> admin_mailer_preview_note_path(:type => "Wall"), :width=>"100%", :height=>"350"} |
| 25 | 25 | |
| 26 | - | |
| 27 | -:javascript | |
| 26 | +:javascript | |
| 28 | 27 | $(function() { |
| 29 | 28 | $( "#accordion" ).accordion(); }); | ... | ... |
app/views/admin/projects/index.html.haml
app/views/admin/projects/show.html.haml
| 1 | 1 | %p#notice= notice |
| 2 | 2 | |
| 3 | 3 | .span-8.colborder |
| 4 | - %h2= @admin_project.name | |
| 4 | + %h2= @admin_project.name | |
| 5 | 5 | |
| 6 | 6 | %p |
| 7 | 7 | %b Name: |
| ... | ... | @@ -22,16 +22,16 @@ |
| 22 | 22 | |
| 23 | 23 | .span-14 |
| 24 | 24 | |
| 25 | - %h2 Team | |
| 25 | + %h2 Team | |
| 26 | 26 | |
| 27 | 27 | %table.round-borders |
| 28 | 28 | %tr |
| 29 | 29 | %th Name |
| 30 | - %th Added | |
| 30 | + %th Added | |
| 31 | 31 | %th Web |
| 32 | 32 | %th Git |
| 33 | 33 | %th Admin |
| 34 | - %th | |
| 34 | + %th | |
| 35 | 35 | |
| 36 | 36 | - @admin_project.users_projects.each do |tm| |
| 37 | 37 | %tr | ... | ... |
app/views/admin/team_members/index.html.haml
| 1 | 1 | - @admin_team_members.group_by(&:project).sort.each do |project, members| |
| 2 | 2 | %h3= link_to project.name, [:admin, project] |
| 3 | 3 | %table |
| 4 | - %tr | |
| 4 | + %thead | |
| 5 | 5 | %th Name |
| 6 | 6 | %th Email |
| 7 | 7 | %th Read |
| 8 | 8 | %th Git |
| 9 | 9 | %th Manage |
| 10 | - %th Added | |
| 11 | - %th | |
| 10 | + %th Added | |
| 11 | + %th | |
| 12 | 12 | %th |
| 13 | 13 | %th |
| 14 | 14 | - members.each do |tm| | ... | ... |
app/views/admin/team_members/show.html.haml
app/views/admin/users/_form.html.haml
app/views/admin/users/index.html.haml
app/views/admin/users/new.html.haml
app/views/admin/users/show.html.haml
| ... | ... | @@ -19,28 +19,27 @@ |
| 19 | 19 | = @admin_user.skype |
| 20 | 20 | %p |
| 21 | 21 | %b LinkedIn: |
| 22 | - = @admin_user.linkedin | |
| 22 | + = @admin_user.linkedin | |
| 23 | 23 | %p |
| 24 | 24 | %b Twitter: |
| 25 | 25 | = @admin_user.twitter |
| 26 | 26 | |
| 27 | - | |
| 28 | 27 | .clear |
| 29 | 28 | = link_to 'Edit', edit_admin_user_path(@admin_user) |
| 30 | 29 | \| |
| 31 | 30 | = link_to 'Back', admin_users_path |
| 32 | 31 | |
| 33 | 32 | .span-14 |
| 34 | - %h2 Projects | |
| 33 | + %h2 Projects | |
| 35 | 34 | |
| 36 | 35 | %table.round-borders |
| 37 | 36 | %tr |
| 38 | 37 | %th Name |
| 39 | - %th Added | |
| 38 | + %th Added | |
| 40 | 39 | %th Web |
| 41 | 40 | %th Git |
| 42 | 41 | %th Admin |
| 43 | - %th | |
| 42 | + %th | |
| 44 | 43 | |
| 45 | 44 | - @admin_user.users_projects.each do |tm| |
| 46 | 45 | - project = tm.project | ... | ... |
app/views/commits/_commits.html.haml
| 1 | 1 | - @commits.group_by { |c| c.committed_date.to_date }.each do |day, commits| |
| 2 | - .day-commits-table | |
| 3 | - .day-header | |
| 2 | + %div{ :class => "commits-date ui-box ui-box-small ui-box-big" } | |
| 3 | + .day-commits-table | |
| 4 | 4 | %h3= day.stamp("28 Aug, 2010") |
| 5 | - %ul | |
| 6 | - - commits.each do |commit| | |
| 7 | - %li{ :class => "commit", :url => project_commit_path(@project, :id => commit.id) } | |
| 8 | - - if commit.author.email | |
| 9 | - = image_tag gravatar_icon(commit.author.email), :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 10 | - - else | |
| 11 | - = image_tag "no_avatar.png", :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 12 | - %p | |
| 13 | - %strong | |
| 14 | - = truncate(commit.safe_message, :length => 60) | |
| 15 | - = link_to "Browse Code", tree_project_path(@project, :commit_id => commit.id), :class => "lite_button", :style => "float:right" | |
| 16 | - = link_to truncate(commit.id.to_s, :length => 16), project_commit_path(@project, :id => commit.id), :class => "lite_button", :style => "width:120px;float:right" | |
| 17 | - %span | |
| 18 | - %span.author | |
| 19 | - = commit.author | |
| 20 | - = time_ago_in_words(commit.committed_date) | |
| 21 | - ago | |
| 22 | -= more_commits_link if @commits.size > 99 | |
| 5 | + .data | |
| 6 | + - commits.each do |commit| | |
| 7 | + %a{ :class => "commit", :href => project_commit_path(@project, :id => commit.id) } | |
| 8 | + %span.commit-info | |
| 9 | + %data.commit-button | |
| 10 | + = truncate(commit.id.to_s, :length => 16) | |
| 11 | + %i | |
| 12 | + %data.commit-browse{ :onclick => "location.href='#{tree_project_path(@project, :commit_id => commit.id)}';return false;"} | |
| 13 | + Browse Code | |
| 14 | + - if commit.author_email | |
| 15 | + = image_tag gravatar_icon(commit.author_email), :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 16 | + - else | |
| 17 | + = image_tag "no_avatar.png", :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 18 | + %span.commit-title | |
| 19 | + %strong | |
| 20 | + = truncate(commit.safe_message, :length => 60) | |
| 21 | + %span.commit-author | |
| 22 | + %strong= commit.author_name | |
| 23 | + = time_ago_in_words(commit.committed_date) | |
| 24 | + ago | ... | ... |
app/views/commits/_diff.html.haml
| ... | ... | @@ -8,7 +8,7 @@ |
| 8 | 8 | .diff_file_header |
| 9 | 9 | - if diff.deleted_file |
| 10 | 10 | %strong{:id => "#{diff.b_path}"}= diff.a_path |
| 11 | - - else | |
| 11 | + - else | |
| 12 | 12 | = link_to tree_file_project_path(@project, @commit.id, diff.b_path) do |
| 13 | 13 | %strong{:id => "#{diff.b_path}"}= diff.b_path |
| 14 | 14 | %br/ |
| ... | ... | @@ -19,5 +19,5 @@ |
| 19 | 19 | .diff_file_content_image |
| 20 | 20 | %img{:src => "data:#{file.mime_type};base64,#{Base64.encode64(file.data)}"} |
| 21 | 21 | - else |
| 22 | - %p | |
| 22 | + %p | |
| 23 | 23 | %center No preview for this file type | ... | ... |
app/views/commits/_index.html.haml
app/views/commits/_text_file.html.haml
| ... | ... | @@ -2,6 +2,7 @@ |
| 2 | 2 | - line_new = 0 |
| 3 | 3 | - lines_arr = diff.diff.lines.to_a |
| 4 | 4 | - lines_arr.each do |line| |
| 5 | + - next if line.match(/^--- \/dev\/null/) | |
| 5 | 6 | - next if line.match(/^--- a/) |
| 6 | 7 | - next if line.match(/^\+\+\+ b/) |
| 7 | 8 | - if line.match(/^@@ -/) |
| ... | ... | @@ -12,10 +13,10 @@ |
| 12 | 13 | = diff_line(line, line_new, line_old) |
| 13 | 14 | - if line[0] == "+" |
| 14 | 15 | - line_new += 1 |
| 15 | - - elsif | |
| 16 | + - elsif | |
| 16 | 17 | - line[0] == "-" |
| 17 | 18 | - line_old += 1 |
| 18 | - - else | |
| 19 | + - else | |
| 19 | 20 | - line_new += 1 |
| 20 | 21 | - line_old += 1 |
| 21 | 22 | ... | ... |
app/views/commits/index.html.haml
| 1 | -%div | |
| 2 | - %h3 | |
| 3 | - .left | |
| 4 | - = form_tag project_commits_path(@project), :method => :get do | |
| 5 | - = select_tag "branch", options_for_select(@repo.heads.map(&:name), @branch), :onchange => "this.form.submit();", :class => "", :prompt => "Branches" | |
| 6 | - | |
| 7 | - .left.prepend-1 | |
| 8 | - = form_tag project_commits_path(@project), :method => :get do | |
| 9 | - = select_tag "tag", options_for_select(@project.tags, @tag), :onchange => "this.form.submit();", :class => "", :prompt => "Tags" | |
| 10 | - = text_field_tag "ssh", @project.url_to_repo, :class => ["ssh_project_url", "one_click_select"] | |
| 11 | - .clear | |
| 12 | - - if params[:path] | |
| 13 | - %h3{:style => "color:#555"} /#{params[:path]} | |
| 14 | - %div{:id => dom_id(@project)} | |
| 15 | - = render "commits" | |
| 1 | +- content_for(:body_class, "project-page commits-page") | |
| 2 | + | |
| 3 | +-#%a.right.button{:href => "#"} Download | |
| 4 | +-#-if can? current_user, :admin_project, @project | |
| 5 | + %a.right.button.blue{:href => "#"} EDIT | |
| 6 | +%h2.icon | |
| 7 | + %span | |
| 8 | + %d | |
| 9 | + = link_to project_commits_path(@project) do | |
| 10 | + = @project.name | |
| 11 | + - if params[:path] | |
| 12 | + \/ | |
| 13 | + %a{:href => "#"}= params[:path].split("/").join(" / ") | |
| 14 | + | |
| 15 | +.right= render :partial => "projects/refs", :locals => { :destination => project_commits_path(@project) } | |
| 16 | + | |
| 17 | +%div{:id => dom_id(@project)} | |
| 18 | + #commits_list= render "commits" | |
| 19 | +.clear | |
| 20 | +.loading{ :style => "display:none;"} | |
| 21 | + %center= image_tag "ajax-loader.gif" | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | +:javascript | |
| 26 | + $(function(){ | |
| 27 | + CommitsList.init("#{@ref}", 20); | |
| 28 | + }); | ... | ... |
app/views/commits/show.html.haml
| 1 | 1 | %h3 |
| 2 | - = "[ #{@commit.committer} ] #{truncate(@commit.safe_message)}" | |
| 2 | + = "[ #{@commit.author_name} ] #{truncate(@commit.safe_message, :length => 70)}" | |
| 3 | 3 | -#= link_to 'Back', project_commits_path(@project), :class => "button" |
| 4 | 4 | %table.round-borders |
| 5 | 5 | %tr |
| ... | ... | @@ -7,33 +7,21 @@ |
| 7 | 7 | %td= @commit.id |
| 8 | 8 | %tr |
| 9 | 9 | %td Author |
| 10 | - %td= @commit.author | |
| 11 | - %tr | |
| 12 | - %td Commiter | |
| 13 | - %td= @commit.committer | |
| 10 | + %td= @commit.author_name | |
| 14 | 11 | %tr |
| 15 | 12 | %td Commited Date |
| 16 | - %td= @commit.committed_date | |
| 13 | + %td= @commit.committed_date.stamp("21 Aug 2011, 11:15pm") | |
| 17 | 14 | %tr |
| 18 | 15 | %td Message |
| 19 | - %td= @commit.safe_message | |
| 16 | + %td | |
| 17 | + %pre.commit_message | |
| 18 | + = preserve @commit.safe_message | |
| 20 | 19 | %tr |
| 21 | 20 | %td Tree |
| 22 | 21 | %td= link_to 'Browse Code', tree_project_path(@project, :commit_id => @commit.id) |
| 23 | 22 | .clear |
| 24 | 23 | |
| 25 | -#tabs | |
| 26 | - %ul | |
| 27 | - %li | |
| 28 | - %a{ :href => "#tabs-1" } Diff | |
| 29 | - %li | |
| 30 | - %a{ :href => "#tabs-2" } Comments | |
| 31 | - %span{ :class => "notes_count" }= @notes.count | |
| 32 | - %hr | |
| 33 | - #tabs-1 | |
| 34 | - = render "commits/diff" | |
| 35 | - #tabs-2 | |
| 36 | - = render "notes/notes" | |
| 24 | +%br | |
| 37 | 25 | |
| 38 | -:javascript | |
| 39 | - $(function() { $( "#tabs" ).tabs(); }); | |
| 26 | += render "commits/diff" | |
| 27 | += render "notes/notes" | ... | ... |
app/views/commits/show.js.haml
| 1 | --#:plain | |
| 2 | - $("#side-commit-preview").remove(); | |
| 3 | - var side = $("<div id='side-commit-preview'></div>"); | |
| 4 | - side.html("#{escape_javascript(render "commits/show")}"); | |
| 5 | - $("##{dom_id(@project)}").parent().append(side); | |
| 6 | - $("##{dom_id(@project)}").addClass("span-14"); | |
| 7 | -:plain | |
| 8 | - $("#notes-list").html("#{escape_javascript(render(:partial => 'notes/notes_list'))}"); | |
| 1 | += render "notes/load" | ... | ... |
app/views/dashboard/index.html.haml
| 1 | -timeline | |
| 1 | +- content_for(:body_class, "dashboard-page") | |
| 2 | + | |
| 3 | +#dashboard-content.dashboard-content.content | |
| 4 | + %aside | |
| 5 | + %h4 | |
| 6 | + - if current_user.can_create_project? | |
| 7 | + %a.button-small.button-green{:href => new_project_path} New Repository | |
| 8 | + Your Repositories | |
| 9 | + %ol.project-list | |
| 10 | + - @projects.each do |project| | |
| 11 | + %li | |
| 12 | + %a{:href => project_path(project)} | |
| 13 | + %span.arrow → | |
| 14 | + %span.project-name= project.name | |
| 15 | + %span.time | |
| 16 | + %strong Last activity: | |
| 17 | + = project.last_activity_date ? time_ago_in_words(project.last_activity_date) + " ago" : "Never" | |
| 18 | + #news-feed.news-feed | |
| 19 | + %h2.icon | |
| 20 | + %span> | |
| 21 | + Dashboard | |
| 22 | + - @active_projects.first(3).each do |project| | |
| 23 | + .project-box.project-updates.ui-box.ui-box-small.ui-box-big | |
| 24 | + %h3= project.name | |
| 25 | + .data | |
| 26 | + - project.updates.each do |update| | |
| 27 | + %a.project-update{:href => dashboard_feed_path(project, update)} | |
| 28 | + = image_tag gravatar_icon(update.author_email), :class => "left", :width => 40 | |
| 29 | + %span.update-title | |
| 30 | + = dashboard_feed_title(update) | |
| 31 | + %span.update-author | |
| 32 | + %strong= update.author_name | |
| 33 | + authored | |
| 34 | + = time_ago_in_words(update.created_at) | |
| 35 | + ago | |
| 36 | + %br | |
| 37 | + / .project-update | |
| 38 | + / .project-updates | |
| 39 | + / #news-feed | |
| 40 | +/ #dashboard-content | ... | ... |
app/views/devise/confirmations/new.html.erb
app/views/devise/passwords/edit.html.erb
app/views/devise/passwords/new.html.erb
| 1 | -<h2>Forgot your password?</h2> | |
| 2 | - | |
| 3 | -<div class="span-12 colborder"> | |
| 4 | - <%= form_for(resource, :as => resource_name, :url => password_path(resource_name), :html => { :method => :post }) do |f| %> | |
| 5 | - <%= devise_error_messages! %> | |
| 6 | - | |
| 7 | - <div><%= f.label :email %><br /> | |
| 8 | - <%= f.email_field :email %></div> | |
| 9 | - | |
| 10 | - <div><%= f.submit "Send me reset password instructions", :class => "lbutton vm" %></div> | |
| 11 | - <% end %> | |
| 12 | -</div> | |
| 13 | -<div> | |
| 14 | - <%= render :partial => "devise/shared/links" %> | |
| 15 | -</div> | |
| 1 | +<%= form_for(resource, :as => resource_name, :url => password_path(resource_name), :html => { :class => "login-box", :method => :post }) do |f| %> | |
| 2 | + <%= image_tag "login-logo.png", :width => "304", :height => "66", :class => "login-logo", :alt => "Login Logo" %> | |
| 3 | + <%= devise_error_messages! %> | |
| 4 | + <%= f.email_field :email, :placeholder => "Email", :class => "text top" %> | |
| 5 | + <br/> | |
| 6 | + <%= f.submit "Reset password", :class => "grey-button" %> | |
| 7 | + <div class="right"> <%= render :partial => "devise/shared/links" %></div> | |
| 8 | +<% end %> | ... | ... |
app/views/devise/sessions/new.html.erb
| 1 | -<h2>Sign in</h2> | |
| 1 | +<%= form_for(resource, :as => resource_name, :url => session_path(resource_name), :html => { :class => "login-box" }) do |f| %> | |
| 2 | + <%= image_tag "login-logo.png", :width => "304", :height => "66", :class => "login-logo", :alt => "Login Logo" %> | |
| 3 | + <%= f.text_field :email, :class => "text top", :placeholder => "Email" %> | |
| 4 | + <%= f.password_field :password, :class => "text bottom", :placeholder => "Password" %> | |
| 2 | 5 | |
| 3 | -<div class="span-12 colborder"> | |
| 4 | - <%= form_for(resource, :as => resource_name, :url => session_path(resource_name)) do |f| %> | |
| 5 | - <div><%= f.label :email %><br /> | |
| 6 | - <%= f.text_field :email %></div> | |
| 7 | - | |
| 8 | - <div><%= f.label :password %><br /> | |
| 9 | - <%= f.password_field :password %></div> | |
| 10 | - | |
| 11 | - <% if devise_mapping.rememberable? -%> | |
| 12 | - <div><%= f.check_box :remember_me %> <%= f.label :remember_me %></div> | |
| 13 | - <% end -%> | |
| 14 | - <br/> | |
| 15 | - <div><%= f.submit "Sign in", :class => "lbutton vm" %></div> | |
| 16 | - <% end %> | |
| 17 | -</div> | |
| 18 | -<div> | |
| 19 | - <%= render :partial => "devise/shared/links" %> | |
| 20 | -</div> | |
| 6 | + <% if devise_mapping.rememberable? -%> | |
| 7 | + <div><%= f.check_box :remember_me %> <%= f.label :remember_me %></div> | |
| 8 | + <% end -%> | |
| 9 | + <br/> | |
| 10 | + <%= f.submit "Sign in", :class => "grey-button" %> | |
| 11 | + <div class="right"> <%= render :partial => "devise/shared/links" %></div> | |
| 12 | +<% end %> | ... | ... |
app/views/devise/shared/_links.erb
app/views/devise/unlocks/new.html.erb
app/views/issues/_form.html.haml
| ... | ... | @@ -7,10 +7,10 @@ |
| 7 | 7 | |
| 8 | 8 | .span-8 |
| 9 | 9 | = f.label :title |
| 10 | - = f.text_field :title, :style => "width:450px" | |
| 11 | - .span-8 | |
| 12 | - = f.label :content | |
| 13 | - = f.text_area :content, :style => "width:450px; height:130px" | |
| 10 | + = f.text_area :title, :style => "width:450px; height:100px", :maxlength => 255 | |
| 11 | + -#.span-8 | |
| 12 | + -#= f.label :content | |
| 13 | + -#= f.text_area :content, :style => "width:450px; height:130px" | |
| 14 | 14 | .span-8.append-bottom |
| 15 | 15 | = f.label :assignee_id |
| 16 | 16 | = f.select(:assignee_id, @project.users.all.collect {|p| [ p.name, p.id ] }, { :include_blank => "Select user" }) | ... | ... |
app/views/issues/_issues.html.haml
| 1 | 1 | %table.round-borders#issues-table |
| 2 | - %tr | |
| 2 | + %thead | |
| 3 | 3 | - if can?(current_user, :admin_issue, @project) && !params[:f] || params[:f] == "0" |
| 4 | - %th | |
| 4 | + %th | |
| 5 | 5 | %th Assignee |
| 6 | 6 | %th ID |
| 7 | 7 | %th Title |
| 8 | 8 | %th Closed? |
| 9 | - %th | |
| 10 | 9 | |
| 11 | 10 | - @issues.critical.each do |issue| |
| 12 | 11 | = render(:partial => 'show', :locals => {:issue => issue}) | ... | ... |
app/views/issues/_show.html.haml
| 1 | 1 | %tr{ :id => dom_id(issue), :class => "issue #{issue.critical ? "critical" : ""}", :url => project_issue_path(@project, issue) } |
| 2 | - - if can?(current_user, :admin_issue, @project) && !params[:f] || params[:f] == "0" | |
| 2 | + - if can?(current_user, :admin_issue, @project) && (!params[:f] || params[:f] == "0") | |
| 3 | 3 | %td |
| 4 | 4 | = image_tag "move.png" , :class => [:handle, :left] |
| 5 | 5 | %td |
| 6 | 6 | = image_tag gravatar_icon(issue.assignee.email), :class => "left", :width => 40, :style => "padding:0 5px;" |
| 7 | - = truncate issue.assignee.name, :lenght => 20 | |
| 7 | + = issue.assignee.name | |
| 8 | 8 | %td ##{issue.id} |
| 9 | 9 | %td |
| 10 | - = html_escape issue.title | |
| 10 | + = truncate(html_escape(issue.title), :length => 200) | |
| 11 | + %br | |
| 11 | 12 | %br |
| 12 | 13 | - if issue.critical |
| 13 | 14 | %span.tag.high critical |
| 14 | 15 | - if issue.today? |
| 15 | 16 | %span.tag.today today |
| 17 | + | |
| 18 | + .right | |
| 19 | + - if can?(current_user, :admin_issue, @project) || issue.author == current_user | |
| 20 | + = link_to 'Edit', edit_project_issue_path(@project, issue), :class => "cgray", :remote => true | |
| 21 | + - if can?(current_user, :admin_issue, @project) || issue.author == current_user | |
| 22 | + | |
| 23 | + = link_to 'Destroy', [@project, issue], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "cred delete-issue negative", :id => "destroy_issue_#{issue.id}" | |
| 24 | + | |
| 16 | 25 | -#- if issue.author == current_user |
| 17 | 26 | -#%span.tag.yours yours |
| 18 | 27 | -#- if issue.notes.count > 0 |
| ... | ... | @@ -21,13 +30,8 @@ |
| 21 | 30 | -#notes |
| 22 | 31 | %td |
| 23 | 32 | - if can? current_user, :write_issue, @project |
| 24 | - = form_for([@project, issue], :remote => true) do |f| | |
| 33 | + = form_for([@project, issue], :remote => true) do |f| | |
| 25 | 34 | = f.check_box :closed, :onclick => "$(this).parent().submit();" |
| 26 | 35 | = hidden_field_tag :status_only, true |
| 27 | - - else | |
| 36 | + - else | |
| 28 | 37 | = check_box_tag "closed", 1, issue.closed, :disabled => true |
| 29 | - %td | |
| 30 | - - if can?(current_user, :admin_issue, @project) || issue.author == current_user | |
| 31 | - = link_to 'Edit', edit_project_issue_path(@project, issue), :class => "lbutton positive", :remote => true | |
| 32 | - - if can?(current_user, :admin_issue, @project) || issue.author == current_user | |
| 33 | - = link_to 'Destroy', [@project, issue], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "lbutton delete-issue negative", :id => "destroy_issue_#{issue.id}" | ... | ... |
app/views/issues/index.html.haml
| 1 | 1 | %div |
| 2 | - - if can? current_user, :write_issue, @project | |
| 3 | - .left= link_to 'New Issue', new_project_issue_path(@project), :remote => true, :class => "lbutton vm" | |
| 4 | - .right | |
| 5 | - = form_tag project_issues_path(@project), :method => :get do | |
| 6 | - .span-2 | |
| 7 | - = radio_button_tag :f, 0, (params[:f] || "0") == "0", :onclick => "this.form.submit()", :id => "open_issues" | |
| 8 | - = label_tag "open_issues","Open" | |
| 9 | - .span-2 | |
| 10 | - = radio_button_tag :f, 2, params[:f] == "2", :onclick => "this.form.submit()", :id => "closed_issues" | |
| 11 | - = label_tag "closed_issues","Closed" | |
| 12 | - .span-2 | |
| 13 | - = radio_button_tag :f, 3, params[:f] == "3", :onclick => "this.form.submit()", :id => "my_issues" | |
| 14 | - = label_tag "my_issues","To Me" | |
| 15 | - | |
| 16 | - .span-2 | |
| 17 | - = radio_button_tag :f, 1, params[:f] == "1", :onclick => "this.form.submit()", :id => "all_issues" | |
| 18 | - = label_tag "all_issues","All" | |
| 2 | + .top_panel_issues | |
| 3 | + - if can? current_user, :write_issue, @project | |
| 4 | + %div{:class => "left", :style => "margin-right: 10px;" } | |
| 5 | + = link_to 'New Issue', new_project_issue_path(@project), :remote => true, :class => "lbutton vm" | |
| 6 | + = form_tag search_project_issues_path(@project), :method => :get, :remote => true, :class => :left, :id => "issue_search_form" do | |
| 7 | + = hidden_field_tag :project_id, @project.id, { :id => 'project_id' } | |
| 8 | + = search_field_tag :issue_search, nil, { :placeholder => 'Search', :class => 'issue_search' } | |
| 9 | + | |
| 10 | + .right.issues_filter | |
| 11 | + = form_tag project_issues_path(@project), :method => :get do | |
| 12 | + .left | |
| 13 | + = radio_button_tag :f, 0, (params[:f] || "0") == "0", :onclick => "this.form.submit()", :id => "open_issues", :class => "status" | |
| 14 | + = label_tag "open_issues","Open" | |
| 15 | + .left | |
| 16 | + = radio_button_tag :f, 2, params[:f] == "2", :onclick => "this.form.submit()", :id => "closed_issues", :class => "status" | |
| 17 | + = label_tag "closed_issues","Closed" | |
| 18 | + .left | |
| 19 | + = radio_button_tag :f, 3, params[:f] == "3", :onclick => "this.form.submit()", :id => "my_issues", :class => "status" | |
| 20 | + = label_tag "my_issues","To Me" | |
| 21 | + .left | |
| 22 | + = radio_button_tag :f, 1, params[:f] == "1", :onclick => "this.form.submit()", :id => "all_issues", :class => "status" | |
| 23 | + = label_tag "all_issues","All" | |
| 19 | 24 | |
| 20 | 25 | #issues-table-holder= render "issues" |
| 21 | 26 | %br |
| 22 | 27 | :javascript |
| 23 | - $('.delete-issue').live('ajax:success', function() { | |
| 24 | - $(this).closest('tr').fadeOut(); }); | |
| 25 | - | |
| 28 | + var href = $('.issue_search').parent().attr('action'); | |
| 29 | + var last_terms = ''; | |
| 30 | + | |
| 31 | + $('.issue_search').keyup(function() { | |
| 32 | + var terms = $(this).val(); | |
| 33 | + var project_id = $('#project_id').val(); | |
| 34 | + var status = $('.status:checked').val(); | |
| 35 | + if (terms != last_terms) { | |
| 36 | + last_terms = terms; | |
| 37 | + | |
| 38 | + if (terms.length >= 2 || terms.length == 0) { | |
| 39 | + $.get(href, { 'status': status, 'terms': terms, project: project_id }, function(response) { | |
| 40 | + $('#issues-table').html(response); | |
| 41 | + setSortable(); | |
| 42 | + }); | |
| 43 | + } | |
| 44 | + } | |
| 45 | + }); | |
| 46 | + | |
| 47 | + $('.delete-issue').live('ajax:success', function() { | |
| 48 | + $(this).closest('tr').fadeOut(); updatePage();}); | |
| 49 | + | |
| 26 | 50 | function setSortable(){ |
| 27 | 51 | $('#issues-table>tbody').sortable({ |
| 28 | 52 | axis: 'y', | ... | ... |
app/views/issues/show.html.haml
| 1 | 1 | %h2 |
| 2 | - = "Issue ##{@issue.id} - #{@issue.title}" | |
| 3 | - | |
| 4 | -.span-15 | |
| 5 | - = simple_format html_escape(@issue.content) | |
| 2 | + %strong | |
| 3 | + Issue | |
| 4 | + = "##{@issue.id}" | |
| 5 | + – | |
| 6 | + = html_escape(@issue.title) | |
| 7 | +.left.width-65p | |
| 6 | 8 | .issue_notes= render "notes/notes" |
| 7 | -.span-8.right | |
| 9 | + | |
| 10 | + .loading{ :style => "display:none;"} | |
| 11 | + %center= image_tag "ajax-loader.gif" | |
| 12 | +.right.width-30p | |
| 8 | 13 | .span-8 |
| 9 | - - if @issue.closed | |
| 10 | - %center.success Closed | |
| 11 | - - else | |
| 12 | - %center.error Open | |
| 13 | 14 | %table.round-borders |
| 14 | 15 | %tr |
| 15 | - %td Title: | |
| 16 | - %td | |
| 17 | - = truncate html_escape(@issue.title) | |
| 18 | - %tr | |
| 19 | - %td Project | |
| 20 | - %td | |
| 21 | - %strong= @issue.project.name | |
| 22 | - %tr | |
| 23 | - %td Author: | |
| 16 | + %td Author: | |
| 24 | 17 | %td |
| 25 | 18 | = image_tag gravatar_icon(@issue.author.email), :class => "left", :width => 40, :style => "padding:0 5px;" |
| 26 | 19 | = @issue.author.name |
| 27 | 20 | %tr |
| 28 | - %td Assignee: | |
| 21 | + %td Assignee: | |
| 29 | 22 | %td |
| 30 | 23 | = image_tag gravatar_icon(@issue.assignee.email), :class => "left", :width => 40, :style => "padding:0 5px;" |
| 31 | 24 | = @issue.assignee.name |
| 25 | + %tr | |
| 26 | + %td Tags | |
| 27 | + %td | |
| 28 | + - if @issue.critical | |
| 29 | + %span.tag.high critical | |
| 30 | + - else | |
| 31 | + %span.tag.normal normal | |
| 32 | + | |
| 33 | + - if @issue.today? | |
| 34 | + %span.tag.today today | |
| 32 | 35 | %tr |
| 33 | 36 | %td Closed? |
| 34 | 37 | %td |
| 35 | - - if can? current_user, :write_issue, @project | |
| 36 | - = form_for([@project, @issue]) do |f| | |
| 38 | + - if can? current_user, :write_issue, @issue | |
| 39 | + = form_for([@project, @issue]) do |f| | |
| 37 | 40 | = f.check_box :closed, :onclick => "$(this).parent().submit();" |
| 38 | 41 | = hidden_field_tag :status_only, true |
| 39 | - - else | |
| 42 | + - else | |
| 40 | 43 | = check_box_tag "closed", 1, @issue.closed, :disabled => true |
| 41 | 44 | |
| 42 | 45 | |
| 46 | + - if can?(current_user, :write_issue, @issue) | |
| 47 | + .clear | |
| 48 | + %br | |
| 49 | + = link_to 'Edit', edit_project_issue_path(@project, @issue), :class => "lbutton positive", :remote => true | |
| 50 | + .right= link_to 'Destroy', [@project, @issue], :confirm => 'Are you sure?', :method => :delete, :class => "lbutton delete-issue negative", :id => "destroy_issue_#{@issue.id}" | |
| 43 | 51 | .clear |
| 44 | - | ... | ... |
app/views/issues/show.js.haml
app/views/issues/update.js.haml
| ... | ... | @@ -2,11 +2,11 @@ |
| 2 | 2 | - if @issue.valid? |
| 3 | 3 | :plain |
| 4 | 4 | $("##{dom_id(@issue)}").fadeOut(); |
| 5 | -- else | |
| 5 | +- else | |
| 6 | 6 | - if @issue.valid? |
| 7 | 7 | :plain |
| 8 | 8 | $("#edit_issue_dialog").dialog("close"); |
| 9 | - $.ajax({type: "GET", url: location.href, dataType: "script"}); | |
| 9 | + updatePage(); | |
| 10 | 10 | - else |
| 11 | 11 | :plain |
| 12 | 12 | $("#edit_issue_dialog").empty(); | ... | ... |
app/views/keys/index.html.haml
| ... | ... | @@ -10,6 +10,6 @@ |
| 10 | 10 | = render(:partial => 'show', :locals => {:key => key}) |
| 11 | 11 | |
| 12 | 12 | :javascript |
| 13 | - $('.delete-key').live('ajax:success', function() { | |
| 14 | - $(this).closest('tr').fadeOut(); }); | |
| 13 | + $('.delete-key').live('ajax:success', function() { | |
| 14 | + $(this).closest('tr').fadeOut(); }); | |
| 15 | 15 | ... | ... |
app/views/layouts/_flash.html.haml
| ... | ... | @@ -6,9 +6,9 @@ |
| 6 | 6 | %h4= text |
| 7 | 7 | :javascript |
| 8 | 8 | $(function(){ |
| 9 | - $("#flash_container").slideDown("slow"); | |
| 10 | - $("#flash_container").click(function(){ | |
| 11 | - $(this).slideUp("slow"); | |
| 9 | + $("#flash_container").slideDown("slow"); | |
| 10 | + $("#flash_container").click(function(){ | |
| 11 | + $(this).slideUp("slow"); | |
| 12 | 12 | }); |
| 13 | 13 | setTimeout("hideFlash()",2000); |
| 14 | 14 | }); | ... | ... |
app/views/layouts/_head_panel.html.erb
| 1 | -<div id="header-panel"> | |
| 2 | - <div class="container"> | |
| 3 | - <div class="span-24"> | |
| 4 | - <div class="span-10"> | |
| 5 | - <%#= image_tag "git.png", :height => 40, :class => "left" %> | |
| 6 | - <%#= link_to "gitlab", root_path, :id => "logo" %> | |
| 7 | - <span class="search-holder"> | |
| 8 | - <%= text_field_tag "search", nil, :placeholder => "Search" %> | |
| 9 | - </span> | |
| 10 | - </div> | |
| 11 | - <div class="right"> | |
| 12 | - <%= link_to truncate(@project.name, :length => 20), project_path(@project), :class => "current button" if @project && !@project.new_record? %> | |
| 13 | - <%= link_to 'Projects', projects_path, :class => current_page?(projects_path) ? "current button" : "button" %> | |
| 14 | - <%= link_to('Admin', admin_root_path, :class => admin_namespace? ? "current button" : "button" ) if current_user.is_admin? %> | |
| 15 | - <%= link_to profile_path, :class => ((controller.controller_name == "keys" || controller.controller_name == "profile") ? "current button" : "button") do %> | |
| 16 | - <%= image_tag gravatar_icon(current_user.email) %> | |
| 17 | - <%= current_user.name.split(" ").first %> | |
| 18 | - <% end %> | |
| 19 | - <%= link_to 'Logout', destroy_user_session_path, :style => "border-left: 1px solid #666;", :class => "button", :method => :delete %> | |
| 20 | - </div> | |
| 1 | +<!-- Page Header --> | |
| 2 | +<header> | |
| 3 | + <h1 class="logo"> | |
| 4 | + <a href="/">GITLAB</a> | |
| 5 | + </h1> | |
| 6 | + <div class="account-box"> | |
| 7 | + <%= link_to profile_path, :class => "pic" do %> | |
| 8 | + <%= image_tag gravatar_icon(current_user.email) %> | |
| 9 | + <% end %> | |
| 10 | + | |
| 11 | + <a href="#" class="arrow-up"></a> | |
| 12 | + | |
| 13 | + <div class="account-links"> | |
| 14 | + <%= link_to profile_path, :class => "username" do %> | |
| 15 | + <%#= current_user.name %> | |
| 16 | + Your profile | |
| 17 | + <% end %> | |
| 18 | + <%= link_to "Fluid layout", url_for( :view_style => 'fluid' ) if cookies[:view_style] == "collapsed"%> | |
| 19 | + <%= link_to "Fixed layout", url_for( :view_style => 'collapsed' ) unless cookies[:view_style] == "collapsed"%> | |
| 20 | + <%= link_to 'Logout', destroy_user_session_path, :class => "logout", :method => :delete %> | |
| 21 | 21 | </div> |
| 22 | + </div><!-- .account-box --> | |
| 23 | + | |
| 24 | + <div class="search"> | |
| 25 | + <%= text_field_tag "search", nil, :placeholder => "Search", :class => "search-input" %> | |
| 22 | 26 | </div> |
| 23 | -</div> | |
| 27 | + <!-- .login-top --> | |
| 28 | + <nav> | |
| 29 | + <%= link_to dashboard_path, :class => current_page?(root_path) ? "current dashboard" : "dashboard" do %> | |
| 30 | + <span></span>Dashboard | |
| 31 | + <% end %> | |
| 32 | + <%= link_to projects_path, :class => current_page?(projects_path) ? "current project" : "project" do %> | |
| 33 | + <span></span>Projects | |
| 34 | + <% end %> | |
| 35 | + <%= link_to((current_user.is_admin? ? admin_root_path : "#"), :class => (admin_namespace? ? "current admin" : "admin")) do %> | |
| 36 | + <span></span>Admin | |
| 37 | + <% end %> | |
| 38 | + </nav> | |
| 24 | 39 | |
| 40 | +</header> | |
| 41 | +<!-- eo Page Header --> | |
| 25 | 42 | |
| 26 | 43 | <% if current_user %> |
| 27 | 44 | <%= javascript_tag do %> | ... | ... |
| ... | ... | @@ -0,0 +1,26 @@ |
| 1 | +!!! | |
| 2 | +%html | |
| 3 | + %head | |
| 4 | + %title | |
| 5 | + GitLab #{" - #{@project.name}" if @project && !@project.new_record?} | |
| 6 | + = stylesheet_link_tag "application" | |
| 7 | + = javascript_include_tag "application" | |
| 8 | + = csrf_meta_tags | |
| 9 | + = javascript_tag do | |
| 10 | + REQ_URI = "#{request.env["REQUEST_URI"]}"; | |
| 11 | + REQ_REFFER = "#{request.env["HTTP_REFERER"]}"; | |
| 12 | + %body{ :class => body_class('project-page'), :id => yield(:boyd_id)} | |
| 13 | + #container | |
| 14 | + = render :partial => "layouts/flash" | |
| 15 | + = render :partial => "layouts/head_panel" | |
| 16 | + .project-container | |
| 17 | + .project-sidebar | |
| 18 | + .fixed | |
| 19 | + %aside | |
| 20 | + = link_to "Users", admin_users_path, :class => controller.controller_name == "users" ? "current" : nil | |
| 21 | + = link_to "Projects", admin_projects_path, :class => controller.controller_name == "projects" ? "current" : nil | |
| 22 | + = link_to "Teams", admin_team_members_path, :class => controller.controller_name == "team_members" ? "current" : nil | |
| 23 | + = link_to "Emails", admin_emails_path, :class => controller.controller_name == "mailer" ? "current" : nil | |
| 24 | + | |
| 25 | + .project-content | |
| 26 | + = yield | ... | ... |
app/views/layouts/application.html.haml
| ... | ... | @@ -2,28 +2,16 @@ |
| 2 | 2 | %html |
| 3 | 3 | %head |
| 4 | 4 | %title |
| 5 | - GitLab #{" - #{@project.name}" if @project && !@project.new_record?} | |
| 6 | - = stylesheet_link_tag 'blueprint/screen', :media => "screen, projection" | |
| 7 | - = stylesheet_link_tag 'blueprint/print', :media => "print" | |
| 8 | - = stylesheet_link_tag 'blueprint/plugins/buttons/screen', :media => "screen, projection" | |
| 9 | - = stylesheet_link_tag 'blueprint/plugins/link-icons/screen', :media => "screen, projection" | |
| 10 | - = stylesheet_link_tag 'jquery_ui/jquery-ui-1.8.16.custom', :media => "screen, projection" | |
| 5 | + GitLab | |
| 11 | 6 | = stylesheet_link_tag "application" |
| 12 | 7 | = javascript_include_tag "application" |
| 13 | 8 | = csrf_meta_tags |
| 14 | - %link{:href => "/assets/favicon.png", :rel => "icon", :type => "image/png"}/ | |
| 15 | 9 | = javascript_tag do |
| 16 | 10 | REQ_URI = "#{request.env["REQUEST_URI"]}"; |
| 17 | 11 | REQ_REFFER = "#{request.env["HTTP_REFERER"]}"; |
| 18 | - %body#thebody | |
| 19 | - = render :partial => "layouts/flash" | |
| 20 | - - if user_signed_in? | |
| 12 | + %body{ :class => body_class, :id => yield(:boyd_id)} | |
| 13 | + #container | |
| 14 | + = render :partial => "layouts/flash" | |
| 21 | 15 | = render :partial => "layouts/head_panel" |
| 22 | - .top_bar.container | |
| 23 | - = render :partial => "projects/top_menu" if @project && !@project.new_record? | |
| 24 | - = render :partial => "projects/projects_top_menu" if (controller.controller_name == "projects" && ["index", "new", "create"].include?(controller.action_name)) && !admin_namespace? | |
| 25 | - = render :partial => "profile/top_menu" if ["keys", "profile"].include?(controller.controller_name) | |
| 26 | - = render :partial => "admin/top_menu" if admin_namespace? | |
| 27 | - #content-container.container | |
| 28 | - .span-24 | |
| 29 | - = yield | |
| 16 | + = render :partial => "layouts/page_title" | |
| 17 | + = yield | ... | ... |
| ... | ... | @@ -0,0 +1,14 @@ |
| 1 | +!!! | |
| 2 | +%html | |
| 3 | + %head | |
| 4 | + %title | |
| 5 | + GitLab #{" - #{@project.name}" if @project && !@project.new_record?} | |
| 6 | + = stylesheet_link_tag "application" | |
| 7 | + = javascript_include_tag "application" | |
| 8 | + = csrf_meta_tags | |
| 9 | + = javascript_tag do | |
| 10 | + REQ_URI = "#{request.env["REQUEST_URI"]}"; | |
| 11 | + REQ_REFFER = "#{request.env["HTTP_REFERER"]}"; | |
| 12 | + %body.login-page | |
| 13 | + = render :partial => "layouts/flash" | |
| 14 | + = yield | ... | ... |
| ... | ... | @@ -0,0 +1,28 @@ |
| 1 | +!!! | |
| 2 | +%html | |
| 3 | + %head | |
| 4 | + %title | |
| 5 | + GitLab #{" - #{@project.name}" if @project && !@project.new_record?} | |
| 6 | + = stylesheet_link_tag "application" | |
| 7 | + = javascript_include_tag "application" | |
| 8 | + = csrf_meta_tags | |
| 9 | + = javascript_tag do | |
| 10 | + REQ_URI = "#{request.env["REQUEST_URI"]}"; | |
| 11 | + REQ_REFFER = "#{request.env["HTTP_REFERER"]}"; | |
| 12 | + %body{ :class => body_class('project-page'), :id => yield(:boyd_id)} | |
| 13 | + #container | |
| 14 | + = render :partial => "layouts/flash" | |
| 15 | + = render :partial => "layouts/head_panel" | |
| 16 | + .project-container | |
| 17 | + .project-sidebar | |
| 18 | + .fixed | |
| 19 | + %aside | |
| 20 | + = link_to "Profile", profile_path, :class => current_page?(:controller => "profile", :action => :show) ? "current" : nil | |
| 21 | + = link_to "Password", profile_password_path, :class => current_page?(:controller => "profile", :action => :password) ? "current" : nil | |
| 22 | + = link_to keys_path, :class => controller.controller_name == "keys" ? "current" : nil do | |
| 23 | + Keys | |
| 24 | + - unless current_user.keys.empty? | |
| 25 | + %span{ :class => "number" }= current_user.keys.count | |
| 26 | + | |
| 27 | + .project-content | |
| 28 | + = yield | ... | ... |
| ... | ... | @@ -0,0 +1,44 @@ |
| 1 | +!!! | |
| 2 | +%html | |
| 3 | + %head | |
| 4 | + %title | |
| 5 | + GitLab #{" - #{@project.name}" if @project && !@project.new_record?} | |
| 6 | + = stylesheet_link_tag "application" | |
| 7 | + = javascript_include_tag "application" | |
| 8 | + = csrf_meta_tags | |
| 9 | + = javascript_tag do | |
| 10 | + REQ_URI = "#{request.env["REQUEST_URI"]}"; | |
| 11 | + REQ_REFFER = "#{request.env["HTTP_REFERER"]}"; | |
| 12 | + %body{ :class => body_class('project-page'), :id => yield(:boyd_id)} | |
| 13 | + #container | |
| 14 | + = render :partial => "layouts/flash" | |
| 15 | + = render :partial => "layouts/head_panel" | |
| 16 | + .project-container | |
| 17 | + .project-sidebar | |
| 18 | + .fixed | |
| 19 | + %input.git-url.text{:id => "", :name => "", :readonly => "", :type => "text", :value => @project.url_to_repo} | |
| 20 | + %aside | |
| 21 | + = link_to "History", project_path(@project), :class => current_page?(:controller => "projects", :action => "show", :id => @project) ? "current" : nil | |
| 22 | + = link_to "Tree", tree_project_path(@project), :class => current_page?(:controller => "projects", :action => "tree", :id => @project) ? "current" : nil | |
| 23 | + = link_to "Commits", project_commits_path(@project), :class => current_page?(:controller => "commits", :action => "index", :project_id => @project) ? "current" : nil | |
| 24 | + = link_to team_project_path(@project), :class => (current_page?(:controller => "projects", :action => "team", :id => @project) || controller.controller_name == "team_members") ? "current" : nil do | |
| 25 | + Team | |
| 26 | + - if @project.users_projects.count > 0 | |
| 27 | + %span{ :class => "number" }= @project.users_projects.count | |
| 28 | + = link_to project_issues_path(@project), :class => (controller.controller_name == "issues") ? "current" : nil do | |
| 29 | + Issues | |
| 30 | + - if @project.issues.opened.count > 0 | |
| 31 | + %span{ :class => "number" }= @project.issues.opened.count | |
| 32 | + = link_to wall_project_path(@project), :class => current_page?(:controller => "projects", :action => "wall", :id => @project) ? "current" : nil do | |
| 33 | + Wall | |
| 34 | + - if @project.common_notes.count > 0 | |
| 35 | + %span{ :class => "number" }= @project.common_notes.count | |
| 36 | + = link_to project_snippets_path(@project), :class => (controller.controller_name == "snippets") ? "current" : nil do | |
| 37 | + Snippets | |
| 38 | + - if @project.snippets.count > 0 | |
| 39 | + %span{ :class => "number" }= @project.snippets.non_expired.count | |
| 40 | + - if @commit | |
| 41 | + = link_to truncate(commit_name(@project,@commit), :length => 15), project_commit_path(@project, :id => @commit.id), :class => current_page?(:controller => "commits", :action => "show", :project_id => @project, :id => @commit.id) ? "current" : nil | |
| 42 | + | |
| 43 | + .project-content | |
| 44 | + = yield | ... | ... |
app/views/notes/_form.html.haml
| ... | ... | @@ -10,7 +10,7 @@ |
| 10 | 10 | |
| 11 | 11 | %div |
| 12 | 12 | = f.label :note |
| 13 | - %cite (255 symbols only) | |
| 13 | + %cite | |
| 14 | 14 | %br |
| 15 | 15 | = f.text_area :note, :size => 255 |
| 16 | 16 | |
| ... | ... | @@ -22,7 +22,7 @@ |
| 22 | 22 | |
| 23 | 23 | = check_box_tag :notify, 1, true |
| 24 | 24 | = label_tag :notify, "Notify project team about your note" |
| 25 | - | |
| 25 | + | |
| 26 | 26 | .clear |
| 27 | 27 | %br |
| 28 | 28 | = f.submit 'Add note', :class => "lbutton vm", :id => "submit_note" | ... | ... |
| ... | ... | @@ -0,0 +1,17 @@ |
| 1 | +- unless @notes.blank? | |
| 2 | + | |
| 3 | + - if params[:last_id] && params[:first_id] | |
| 4 | + :plain | |
| 5 | + NoteList.replace(#{@notes.last.id}, #{@notes.first.id}, "#{escape_javascript(render(:partial => 'notes/notes_list'))}"); | |
| 6 | + | |
| 7 | + | |
| 8 | + - elsif params[:last_id] | |
| 9 | + :plain | |
| 10 | + NoteList.prepend(#{@notes.first.id}, "#{escape_javascript(render(:partial => 'notes/notes_list'))}"); | |
| 11 | + | |
| 12 | + - elsif params[:first_id] | |
| 13 | + :plain | |
| 14 | + NoteList.append(#{@notes.last.id}, "#{escape_javascript(render(:partial => 'notes/notes_list'))}"); | |
| 15 | + | |
| 16 | + - else | |
| 17 | + :plain | ... | ... |
app/views/notes/_notes.html.haml
| 1 | -- if controller.action_name == "wall" | |
| 2 | - %ul#notes-list= render "notes/notes_list" | |
| 3 | - | |
| 4 | -- else | |
| 5 | - %ul#notes-list= render "notes/notes_list" | |
| 6 | - %br | |
| 7 | - %br | |
| 8 | - - if can? current_user, :write_note, @project | |
| 9 | - = render "notes/form" | |
| 1 | +- if can? current_user, :write_note, @project | |
| 2 | + = render "notes/form" | |
| 3 | +.clear | |
| 4 | +%hr | |
| 5 | +%ul#notes-list= render "notes/notes_list" | |
| 10 | 6 | |
| 11 | 7 | :javascript |
| 12 | - $('.delete-note').live('ajax:success', function() { | |
| 13 | - $(this).closest('li').fadeOut(); }); | |
| 8 | + $('.delete-note').live('ajax:success', function() { | |
| 9 | + $(this).closest('li').fadeOut(); }); | |
| 14 | 10 | |
| 15 | 11 | $("#new_note").live("ajax:before", function(){ |
| 16 | - $("#submit_note").attr("disabled", "disabled"); | |
| 12 | + $("#submit_note").attr("disabled", "disabled"); | |
| 17 | 13 | }) |
| 18 | 14 | |
| 19 | 15 | $("#new_note").live("ajax:complete", function(){ |
| 20 | - $("#submit_note").removeAttr("disabled"); | |
| 16 | + $("#submit_note").removeAttr("disabled"); | |
| 21 | 17 | }) |
| 22 | - | |
| 23 | 18 | |
| 24 | -- if ["issues", "projects"].include?(controller.controller_name) | |
| 25 | - :javascript | |
| 26 | - $(function(){ | |
| 27 | - var int =self.setInterval("updatePage()", 20000); | |
| 19 | + $(function(){ | |
| 20 | + $("#note_note").live("click", function(){ | |
| 21 | + $(this).css("height", "100px"); | |
| 22 | + $('.attach_holder').show(); | |
| 28 | 23 | }); |
| 24 | + | |
| 25 | + NoteList.init("wall", #{@notes.last.try(:id) || 0}, #{@notes.first.try(:id) || 0}); | |
| 26 | + }); | ... | ... |
app/views/notes/_show.html.haml
| 1 | -%li{:id => dom_id(note)} | |
| 2 | - %div.note_author | |
| 3 | - = image_tag gravatar_icon(note.author.email), :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 4 | - %div.note_content.left | |
| 5 | - = simple_format(html_escape(note.note)) | |
| 6 | - - if note.attachment.url | |
| 7 | - Attachment: | |
| 8 | - = link_to note.attachment_identifier, note.attachment.url, :target => "_blank" | |
| 9 | - %br | |
| 10 | - %span.author= note.author.name | |
| 11 | - %cite.ago | |
| 1 | +%li{:id => dom_id(note), :class => "note"} | |
| 2 | + = image_tag gravatar_icon(note.author.email), :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 3 | + %div.note-author | |
| 4 | + %strong= note.author_name | |
| 5 | + %cite.cgray | |
| 12 | 6 | = time_ago_in_words(note.updated_at) |
| 13 | 7 | ago |
| 14 | - %br | |
| 15 | - - if(note.author_id == current_user.id) || can?(current_user, :admin_note, @project) | |
| 16 | - = link_to 'Remove', [@project, note], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "lbutton delete-note right negative" | |
| 8 | + - if(note.author_id == current_user.id) || can?(current_user, :admin_note, @project) | |
| 9 | + = link_to "Remove", [@project, note], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "cred delete-note right" | |
| 10 | + | |
| 11 | + %div.note-title | |
| 12 | + = markdown(note.note) | |
| 13 | + - if note.attachment.url | |
| 14 | + .right | |
| 15 | + %span.file | |
| 16 | + = link_to note.attachment_identifier, note.attachment.url, :target => "_blank" | |
| 17 | 17 | .clear | ... | ... |
app/views/notes/create.js.haml
| 1 | 1 | - if @note.valid? |
| 2 | 2 | :plain |
| 3 | 3 | $("#new_note .errors").remove(); |
| 4 | - updatePage(); | |
| 5 | 4 | $('#note_note').val(""); |
| 5 | + NoteList.prepend(#{@note.id}, "#{escape_javascript(render :partial => "notes/show", :locals => {:note => @note})}"); | |
| 6 | 6 | - else |
| 7 | 7 | :plain |
| 8 | 8 | $("#new_note").replaceWith("#{escape_javascript(render('form'))}"); |
| 9 | 9 | |
| 10 | -:plain | |
| 10 | +:plain | |
| 11 | 11 | $("#submit_note").removeAttr("disabled"); | ... | ... |
app/views/notify/new_issue_email.html.haml
| ... | ... | @@ -10,9 +10,9 @@ |
| 10 | 10 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 11 | 11 | %td{:align => "left", :style => "padding: 20px 0 0;"} |
| 12 | 12 | %h2{:style => "color:#646464 !important; font-weight: bold; margin: 0; padding: 0; line-height: 26px; font-size: 18px; font-family: Helvetica, Arial, sans-serif; "} |
| 13 | - = link_to project_issue_url(@project, @issue) do | |
| 13 | + = link_to project_issue_url(@project, @issue) do | |
| 14 | 14 | = "Issue ##{@issue.id.to_s}" |
| 15 | - = truncate(@issue.title, :length => 45) | |
| 15 | + = truncate(@issue.title, :length => 45) | |
| 16 | 16 | %br |
| 17 | 17 | %cite{:style => "color:#767676; font-weight: normal; margin: 0; padding: 0; line-height: 20px; font-size: 12px;font-family: Helvetica, Arial, sans-serif; "} |
| 18 | 18 | = @issue.content | ... | ... |
app/views/notify/new_user_email.html.haml
| ... | ... | @@ -4,7 +4,7 @@ |
| 4 | 4 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 5 | 5 | %td{:align => "left", :style => "padding: 20px 0 0;"} |
| 6 | 6 | %h2{:style => "color:#646464; font-weight: bold; margin: 0; padding: 0; line-height: 26px; font-size: 18px; font-family: Helvetica, Arial, sans-serif; "} |
| 7 | - Hi #{@user.name}! | |
| 7 | + Hi #{@user.name}! | |
| 8 | 8 | %p{:style => "color:#767676; font-weight: normal; margin: 0; padding: 0; line-height: 20px; font-size: 12px;font-family: Helvetica, Arial, sans-serif; "} |
| 9 | 9 | Administrator created account for you. Now you are a member of company gitlab application. |
| 10 | 10 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} | ... | ... |
app/views/notify/note_issue_email.html.haml
| ... | ... | @@ -4,10 +4,10 @@ |
| 4 | 4 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 5 | 5 | %td{:align => "left", :style => "padding: 20px 0 0;"} |
| 6 | 6 | %h2{:style => "color:#646464 !important; font-weight: bold; margin: 0; padding: 0; line-height: 26px; font-size: 18px; font-family: Helvetica, Arial, sans-serif; "} |
| 7 | - New comment - | |
| 8 | - = link_to project_issue_url(@project, @issue, :anchor => "note_#{@note.id}") do | |
| 7 | + New comment - | |
| 8 | + = link_to project_issue_url(@project, @issue, :anchor => "note_#{@note.id}") do | |
| 9 | 9 | = "Issue ##{@issue.id.to_s}" |
| 10 | - = truncate(@issue.title, :length => 35) | |
| 10 | + = truncate(@issue.title, :length => 35) | |
| 11 | 11 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 12 | 12 | %tr |
| 13 | 13 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} | ... | ... |
app/views/notify/note_wall_email.html.haml
| ... | ... | @@ -4,7 +4,7 @@ |
| 4 | 4 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 5 | 5 | %td{:align => "left", :style => "padding: 20px 0 0;"} |
| 6 | 6 | %h2{:style => "color:#646464; font-weight: bold; margin: 0; padding: 0; line-height: 26px; font-size: 18px; font-family: Helvetica, Arial, sans-serif; "} |
| 7 | - New message on | |
| 7 | + New message on | |
| 8 | 8 | = link_to "Project Wall", wall_project_url(@project, :anchor => "note_#{@note.id}") |
| 9 | 9 | %td{:style => "font-size: 1px; line-height: 1px;", :width => "21"} |
| 10 | 10 | %tr | ... | ... |
app/views/projects/_form.html.haml
| ... | ... | @@ -21,10 +21,15 @@ |
| 21 | 21 | %td |
| 22 | 22 | = f.text_field :path, :placeholder => "example_project", :disabled => !@project.new_record? |
| 23 | 23 | %tr |
| 24 | - %td | |
| 24 | + %td | |
| 25 | 25 | .left= f.label :code |
| 26 | 26 | %cite.right http://yourserver/ |
| 27 | 27 | %td= f.text_field :code, :placeholder => "example" |
| 28 | + | |
| 29 | + %tr | |
| 30 | + %td= f.label :tag_list | |
| 31 | + %td= f.text_area :tag_list, :placeholder => "project tags", :style => "height:50px", :id => :tag_field | |
| 32 | + | |
| 28 | 33 | .field |
| 29 | 34 | = f.label :description |
| 30 | 35 | %br/ |
| ... | ... | @@ -39,10 +44,27 @@ |
| 39 | 44 | = image_tag "ajax-loader.gif", :class => "append-bottom" |
| 40 | 45 | - if @project.new_record? |
| 41 | 46 | %h3.prepend-top Creating project & repository. Please wait for few minutes |
| 42 | - - else | |
| 47 | + - else | |
| 43 | 48 | %h3.prepend-top Updating project & repository. Please wait for few minutes |
| 49 | + | |
| 44 | 50 | :javascript |
| 45 | - $('.new_project, .edit_project').bind('ajax:before', function() { | |
| 46 | - $(this).find(".form_content").hide(); | |
| 51 | + $('.new_project, .edit_project').bind('ajax:before', function() { | |
| 52 | + $(this).find(".form_content").hide(); | |
| 47 | 53 | $('.ajax_loader').show(); |
| 48 | - }); | |
| 54 | + }); | |
| 55 | + | |
| 56 | +:javascript | |
| 57 | + $(function(){ | |
| 58 | + var tag_field = $('#tag_field').tagify(); | |
| 59 | + | |
| 60 | + tag_field.tagify('inputField').autocomplete({ | |
| 61 | + source: '/tags.json' | |
| 62 | + }); | |
| 63 | + | |
| 64 | + | |
| 65 | + $('form').submit( function() { | |
| 66 | + var tag_field = $('#tag_field') | |
| 67 | + tag_field.val( tag_field.tagify('serialize') ); | |
| 68 | + return true; | |
| 69 | + }); | |
| 70 | + }) | ... | ... |
app/views/projects/_list.html.haml
| ... | ... | @@ -10,13 +10,18 @@ |
| 10 | 10 | |
| 11 | 11 | - @projects.each do |project| |
| 12 | 12 | %tr{ :class => "project", :url => project_path(project) } |
| 13 | - %td= project.name | |
| 13 | + %td | |
| 14 | + = project.name | |
| 15 | + .small-tags | |
| 16 | + - project.tag_list.each do |tag| | |
| 17 | + = link_to tag, "/tags/#{tag}" | |
| 18 | + | |
| 14 | 19 | %td= truncate project.url_to_repo |
| 15 | 20 | %td= project.code |
| 16 | 21 | %td= check_box_tag "read", 1, project.readers.include?(current_user), :disabled => :disabled |
| 17 | 22 | %td= check_box_tag "commit", 1, project.writers.include?(current_user), :disabled => :disabled |
| 18 | 23 | %td= check_box_tag "admin", 1, project.admins.include?(current_user), :disabled => :disabled |
| 19 | - %td | |
| 24 | + %td | |
| 20 | 25 | -if can? current_user, :admin_project, project |
| 21 | 26 | = link_to 'Edit', edit_project_path(project), :class => "lbutton positive" |
| 22 | 27 | %br | ... | ... |
app/views/projects/_projects_top_menu.html.haml
app/views/projects/_recent_commits.html.haml
| ... | ... | @@ -6,8 +6,8 @@ |
| 6 | 6 | = image_tag "no_avatar.png", :class => "left", :width => 40, :style => "padding-right:5px;" |
| 7 | 7 | %p{:style => "margin-bottom: 3px;"} |
| 8 | 8 | %strong |
| 9 | - = link_to truncate(commit.safe_message, :length => 60), project_commit_path(@project, :id => commit.id) | |
| 10 | - | |
| 9 | + = link_to truncate(commit.safe_message, :length => 60), project_commit_path(@project, :id => commit.id) | |
| 10 | + | |
| 11 | 11 | %span |
| 12 | 12 | %span.author |
| 13 | 13 | = commit.author.name.force_encoding("UTF-8") | ... | ... |
app/views/projects/_recent_messages.html.haml
| ... | ... | @@ -40,7 +40,7 @@ |
| 40 | 40 | %p{:style => "margin-bottom: 3px;"} |
| 41 | 41 | %span.author |
| 42 | 42 | = note.author.name |
| 43 | - = link_to truncate(note.note, :length => 200), link_to_item + "#note_#{note.id}" | |
| 43 | + = link_to markdown(truncate(note.note, :length => 200)), link_to_item + "#note_#{note.id}" | |
| 44 | 44 | - if note.attachment.url |
| 45 | 45 | %br |
| 46 | 46 | Attachment: | ... | ... |
| ... | ... | @@ -0,0 +1,8 @@ |
| 1 | += form_tag destination, :method => :get, :class => "project-refs-form" do | |
| 2 | + = select_tag "ref", grouped_options_refs, :onchange => "this.form.submit();", :class => "project-refs-select" | |
| 3 | + | |
| 4 | + | |
| 5 | +:javascript | |
| 6 | + $(function(){ | |
| 7 | + $('.project-refs-select').chosen(); | |
| 8 | + }) | ... | ... |
app/views/projects/_team.html.haml
| ... | ... | @@ -2,7 +2,7 @@ |
| 2 | 2 | %div#new-member-holder |
| 3 | 3 | = link_to "Add new", new_project_team_member_path(@project), :remote => true, :class => "lbutton vm" |
| 4 | 4 | %table.round-borders#team-table |
| 5 | - %tr | |
| 5 | + %thead | |
| 6 | 6 | %th Name |
| 7 | 7 | %th Email |
| 8 | 8 | %th Web |
| ... | ... | @@ -14,5 +14,5 @@ |
| 14 | 14 | = render(:partial => 'team_members/show', :locals => {:member => up}) |
| 15 | 15 | |
| 16 | 16 | :javascript |
| 17 | - $('.delete-team-member').live('ajax:success', function() { | |
| 18 | - $(this).closest('tr').fadeOut(); }); | |
| 17 | + $('.delete-team-member').live('ajax:success', function() { | |
| 18 | + $(this).closest('tr').fadeOut(); }); | ... | ... |
app/views/projects/_tile.html.haml
| 1 | 1 | - @projects.in_groups_of(3, false) do |projects| |
| 2 | 2 | - projects.each_with_index do |project, i| |
| 3 | - %div{ :class => "project_thumb round-borders", :style => i == 2 ? "" : "margin-right:30px;" } | |
| 4 | - %div{ :class => "project", :url => project_path(project) } | |
| 5 | - %h2 | |
| 6 | - = image_tag gravatar_icon(project.name), :class => "left", :width => 40, :style => "padding-right:5px;" | |
| 7 | - = link_to ("/" + project.code), project_path(project), :style => "text-decoration:none" | |
| 8 | - %p= project.name | |
| 9 | - %p= project.url_to_repo | |
| 10 | - -#%p | |
| 11 | - Commit – | |
| 12 | - = last_commit(project) | |
| 13 | - %hr | |
| 14 | - = link_to "Browse Code", tree_project_path(project), :class => "lbutton" | |
| 15 | - = link_to "Commits", project_commits_path(project), :class => "lbutton", :style => "float:right;width:80px;" | |
| 16 | - .clear | |
| 3 | + %div.grid_1 | |
| 4 | + %div{ :class => "project-box ui-box ui-box-big" } | |
| 5 | + = link_to project_path(project) do | |
| 6 | + %h3= project.name | |
| 7 | + .data | |
| 8 | + %p.title.repository | |
| 9 | + %span Repository: | |
| 10 | + = project.url_to_repo | |
| 11 | + %p.title.activity | |
| 12 | + %span Last Activity: | |
| 13 | + - last_note = project.notes.last | |
| 14 | + = last_note ? last_note.created_at.stamp("24 Aug, 2011") : "Never" | |
| 15 | + | |
| 16 | + %p.small-tags | |
| 17 | + - project.tag_list.each do |tag| | |
| 18 | + = link_to tag, "/tags/#{tag}" | |
| 19 | + | |
| 20 | + .buttons | |
| 21 | + %a.browse-code.button.yellow{:href => tree_project_path(project)} Browse code | |
| 22 | + %a.commits.button.green{:href => project_commits_path(project)} Commits | ... | ... |
app/views/projects/_top_menu.html.haml
| 1 | 1 | %div.top_project_menu |
| 2 | - -#%span= link_to @project.code.capitalize, @project, :class => current_page?(:controller => "projects", :action => "show", :id => @project) ? "current" : nil | |
| 3 | 2 | - if @project.repo_exists? |
| 4 | 3 | %span= link_to image_tag("home.png", :width => 20), project_path(@project), :class => current_page?(:controller => "projects", :action => "show", :id => @project) ? "current" : nil |
| 5 | 4 | %span= link_to "Tree", tree_project_path(@project), :class => current_page?(:controller => "projects", :action => "tree", :id => @project) ? "current" : nil |
| ... | ... | @@ -23,7 +22,7 @@ |
| 23 | 22 | = link_to project_snippets_path(@project), :class => (controller.controller_name == "snippets") ? "current" : nil do |
| 24 | 23 | Snippets |
| 25 | 24 | - if @project.snippets.count > 0 |
| 26 | - %span{ :class => "top_menu_count" }= @project.snippets.count | |
| 25 | + %span{ :class => "top_menu_count" }= @project.snippets.non_expired.count | |
| 27 | 26 | |
| 28 | 27 | - if @commit |
| 29 | 28 | %span= link_to truncate(commit_name(@project,@commit), :length => 15), project_commit_path(@project, :id => @commit.id), :class => current_page?(:controller => "commits", :action => "show", :project_id => @project, :id => @commit.id) ? "current" : nil | ... | ... |
app/views/projects/_tree.html.haml
| 1 | -%h3 | |
| 2 | - .left | |
| 3 | - = form_tag tree_project_path(@project), :method => :get do | |
| 4 | - = select_tag "branch", options_for_select(@repo.heads.map(&:name), @branch), :onchange => "this.form.submit();", :class => "", :prompt => "Branches" | |
| 5 | - | |
| 6 | - .left.prepend-1 | |
| 7 | - = form_tag tree_project_path(@project), :method => :get do | |
| 8 | - = select_tag "tag", options_for_select(@project.tags, @tag), :onchange => "this.form.submit();", :class => "", :prompt => "Tags" | |
| 9 | - = text_field_tag "ssh", @project.url_to_repo, :class => ["ssh_project_url","one_click_select"] | |
| 10 | - .clear | |
| 11 | 1 | |
| 12 | -%h3#tree-breadcrumbs | |
| 13 | - = link_to @project.name, tree_project_path(@project, :path => nil, :commit_id => @commit.try(:id)), :remote => true | |
| 14 | - - if params[:path] | |
| 15 | - - part_path = "" | |
| 16 | - - params[:path].split("\/").each do |part| | |
| 17 | - - part_path = File.join(part_path, part) unless part_path.empty? | |
| 18 | - - if part_path.empty? | |
| 19 | - - part_path = part | |
| 20 | - \/ | |
| 21 | - = link_to truncate(part, :length => 40), tree_file_project_path(@project, :path => part_path, :commit_id => @commit.try(:id), :branch => @branch, :tag => @tag), :remote => :true | |
| 2 | +-#%a.right.button{:href => "#"} Download | |
| 3 | +-#-if can? current_user, :admin_project, @project | |
| 4 | + %a.right.button.blue{:href => "#"} EDIT | |
| 5 | +#tree-breadcrumbs | |
| 6 | + %h2.icon | |
| 7 | + %span | |
| 8 | + %d | |
| 9 | + = link_to tree_project_path(@project, :path => nil, :commit_id => @commit.try(:id)), :remote => true do | |
| 10 | + = @project.name | |
| 11 | + - if params[:path] | |
| 12 | + - part_path = "" | |
| 13 | + - params[:path].split("\/").each do |part| | |
| 14 | + - part_path = File.join(part_path, part) unless part_path.empty? | |
| 15 | + - if part_path.empty? | |
| 16 | + - part_path = part | |
| 17 | + \/ | |
| 18 | + = link_to truncate(part, :length => 40), tree_file_project_path(@project, :path => part_path, :commit_id => @commit.try(:id), :branch => @branch, :tag => @tag), :remote => :true | |
| 19 | + | |
| 20 | + .right= render :partial => "projects/refs", :locals => { :destination => tree_project_path(@project) } | |
| 21 | +.clear | |
| 22 | + | |
| 22 | 23 | #tree-content-holder |
| 23 | 24 | - if tree.is_a?(Grit::Blob) |
| 24 | 25 | = render :partial => "projects/tree_file", :locals => { :name => tree.name, :content => tree.data, :file => tree } |
| 25 | 26 | - else |
| 26 | 27 | - contents = tree.contents |
| 27 | 28 | %table#tree-slider.round-borders |
| 28 | - %tr | |
| 29 | + %thead | |
| 29 | 30 | %th Name |
| 30 | 31 | %th Last Update |
| 31 | 32 | %th | ... | ... |
app/views/projects/empty.html.erb
| ... | ... | @@ -40,7 +40,7 @@ eos |
| 40 | 40 | <p> |
| 41 | 41 | Be careful! <br/> |
| 42 | 42 | Project cant be recovered after destroy.</p> |
| 43 | - <%= link_to 'Destroy', @project, | |
| 43 | + <%= link_to 'Destroy', @project, | |
| 44 | 44 | :confirm => 'Are you sure?', :method => :delete, |
| 45 | 45 | :class => "left button negative span-6", :style => "text-align:center" %> |
| 46 | 46 | <div class="clear"></div> | ... | ... |
app/views/projects/index.html.haml
| 1 | -- unless @projects.empty? | |
| 2 | - %div{:class => "tile", :style => view_mode_style("tile")} | |
| 3 | - = render "tile" | |
| 4 | - %div{:class => "list", :style => view_mode_style("list")} | |
| 5 | - = render "list" | |
| 6 | -- else | |
| 7 | - %center.prepend-top | |
| 8 | - %h2 | |
| 9 | - %cite Nothing here | |
| 1 | +- content_for(:body_class, "projects-page") | |
| 2 | +- content_for(:page_title) do | |
| 3 | + .container_4 | |
| 4 | + .grid_4 | |
| 5 | + - if current_user.can_create_project? | |
| 6 | + %a.grey-button.right{:href => new_project_path} Create new project | |
| 7 | + %h2.icon | |
| 8 | + %span | |
| 9 | + Projects | |
| 10 | + | |
| 11 | + %div.clear | |
| 12 | + - unless @projects.empty? | |
| 13 | + %div{:class => "tile", :style => view_mode_style("tile")} | |
| 14 | + = render "tile" | |
| 15 | + %div{:class => "list", :style => view_mode_style("list")} | |
| 16 | + = render "list" | |
| 17 | + - else | |
| 18 | + %center.prepend-top | |
| 19 | + %h2 | |
| 20 | + %cite Nothing here | ... | ... |
app/views/projects/show.html.haml
| ... | ... | @@ -13,11 +13,16 @@ |
| 13 | 13 | = label_tag "week_view","Week" |
| 14 | 14 | .clear |
| 15 | 15 | %hr |
| 16 | -.span-11 | |
| 16 | +.left.width-49p | |
| 17 | 17 | %h3 Commits |
| 18 | 18 | =render "projects/recent_commits" |
| 19 | 19 | |
| 20 | -.span-11.right | |
| 20 | +.right.width-49p | |
| 21 | 21 | %h3 Talk |
| 22 | 22 | =render "projects/recent_messages" |
| 23 | 23 | |
| 24 | +:javascript | |
| 25 | + function updateDashboard(){ | |
| 26 | + $('#content-container').load("#{escape_javascript(project_path(@project))} #content-container>*"); | |
| 27 | + } | |
| 28 | + setInterval("updateDashboard()", 300000); | ... | ... |
app/views/projects/tree.js.haml
| 1 | 1 | :plain |
| 2 | - $("#tree-holder table").hide("slide", { direction: "left" }, 150, function(){ | |
| 2 | + $("#tree-holder table").hide("slide", { direction: "left" }, 150, function(){ | |
| 3 | 3 | $("#tree-holder").html("#{escape_javascript(render(:partial => "tree", :locals => {:repo => @repo, :commit => @commit, :tree => @tree}))}"); |
| 4 | 4 | $("#tree-holder table").show("slide", { direction: "right" }, 150); |
| 5 | 5 | }); | ... | ... |
app/views/projects/wall.html.haml
| 1 | 1 | %div.wall_page |
| 2 | - - if can? current_user, :write_note, @project | |
| 3 | - = render "notes/form" | |
| 4 | - .right | |
| 5 | - = form_tag wall_project_path(@project), :method => :get do | |
| 6 | - .span-2 | |
| 7 | - = radio_button_tag :view, "recent", (params[:view] || "recent") == "recent", :onclick => "this.form.submit()", :id => "recent_view" | |
| 8 | - = label_tag "recent_view","Recent" | |
| 9 | - .span-2 | |
| 10 | - = radio_button_tag :view, "day", params[:view] == "day", :onclick => "this.form.submit()", :id => "day_view" | |
| 11 | - = label_tag "day_view","Today" | |
| 12 | - .span-2 | |
| 13 | - = radio_button_tag :view, "week", params[:view] == "week", :onclick => "this.form.submit()", :id => "week_view" | |
| 14 | - = label_tag "week_view","Week" | |
| 15 | - .span-2 | |
| 16 | - = radio_button_tag :view, "all", params[:view] == "all", :onclick => "this.form.submit()", :id => "all_view" | |
| 17 | - = label_tag "all_view","All" | |
| 18 | - .clear | |
| 19 | - %br | |
| 20 | - %hr | |
| 21 | -= render "notes/notes" | |
| 2 | + = render "notes/notes" | |
| 3 | + | |
| 4 | +.loading{ :style => "display:none;"} | |
| 5 | + %center= image_tag "ajax-loader.gif" | |
| 22 | 6 | |
| 23 | -:javascript | |
| 24 | - $(function(){ | |
| 25 | - $("#note_note").live("click", function(){ | |
| 26 | - $(this).css("height", "100px"); | |
| 27 | - $('.attach_holder').show(); | |
| 28 | - }); | |
| 29 | - }); | ... | ... |
app/views/projects/wall.js.haml
app/views/snippets/_form.html.haml
| ... | ... | @@ -13,10 +13,13 @@ |
| 13 | 13 | %td= f.label :file_name |
| 14 | 14 | %td= f.text_field :file_name, :placeholder => "example.rb" |
| 15 | 15 | %tr |
| 16 | + %td= f.label "Lifetime" | |
| 17 | + %td= f.select :expires_at, lifetime_select_options | |
| 18 | + %tr | |
| 16 | 19 | %td{:colspan => 2} |
| 17 | 20 | = f.label :content, "Code" |
| 18 | 21 | %br |
| 19 | 22 | = f.text_area :content, :style => "height:240px;width:932px;" |
| 20 | - | |
| 23 | + | |
| 21 | 24 | .actions.prepend-top |
| 22 | 25 | = f.submit 'Save', :class => "lbutton vm" | ... | ... |
app/views/snippets/_snippet.html.haml
| 1 | -%tr{ :id => dom_id(snippet), :class => "snippet", :url => project_snippet_path(@project, snippet) } | |
| 2 | - %td | |
| 3 | - = image_tag gravatar_icon(snippet.author.email), :class => "left", :width => 40, :style => "padding:0 5px;" | |
| 4 | - = truncate snippet.author.name, :lenght => 20 | |
| 5 | - %td= html_escape snippet.title | |
| 6 | - %td= html_escape snippet.file_name | |
| 7 | - %td | |
| 8 | - - if can?(current_user, :admin_snippet, @project) || snippet.author == current_user | |
| 9 | - = link_to 'Edit', edit_project_snippet_path(@project, snippet), :class => "lbutton positive" | |
| 10 | - - if can?(current_user, :admin_snippet, @project) || snippet.author == current_user | |
| 11 | - = link_to 'Destroy', [@project, snippet], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "lbutton delete-snippet negative", :id => "destroy_snippet_#{snippet.id}" | |
| 1 | +- unless snippet.expired? | |
| 2 | + %tr{ :id => dom_id(snippet), :class => "snippet", :url => project_snippet_path(@project, snippet) } | |
| 3 | + %td | |
| 4 | + = image_tag gravatar_icon(snippet.author.email), :class => "left", :width => 40, :style => "padding:0 5px;" | |
| 5 | + = truncate snippet.author.name, :lenght => 20 | |
| 6 | + %td= html_escape snippet.title | |
| 7 | + %td= html_escape snippet.file_name | |
| 8 | + %td | |
| 9 | + - if can?(current_user, :admin_snippet, @project) || snippet.author == current_user | |
| 10 | + = link_to 'Edit', edit_project_snippet_path(@project, snippet), :class => "lbutton positive" | |
| 11 | + - if can?(current_user, :admin_snippet, @project) || snippet.author == current_user | |
| 12 | + = link_to 'Destroy', [@project, snippet], :confirm => 'Are you sure?', :method => :delete, :remote => true, :class => "lbutton delete-snippet negative", :id => "destroy_snippet_#{snippet.id}" | ... | ... |
app/views/snippets/index.html.haml
| ... | ... | @@ -8,7 +8,7 @@ |
| 8 | 8 | %th Title |
| 9 | 9 | %th File name |
| 10 | 10 | %th |
| 11 | - = render @snippets | |
| 11 | + = render @snippets.fresh | |
| 12 | 12 | :javascript |
| 13 | - $('.delete-snippet').live('ajax:success', function() { | |
| 14 | - $(this).closest('tr').fadeOut(); }); | |
| 13 | + $('.delete-snippet').live('ajax:success', function() { | |
| 14 | + $(this).closest('tr').fadeOut(); }); | ... | ... |
app/views/snippets/show.html.haml
| 1 | -%h2 | |
| 2 | - = "Snippet ##{@snippet.id} - #{@snippet.title}" | |
| 1 | +- if !@snippet.expired? | |
| 2 | + %h2 | |
| 3 | + = "Snippet ##{@snippet.id} - #{@snippet.title}" | |
| 3 | 4 | |
| 4 | -.view_file | |
| 5 | - .view_file_header | |
| 6 | - %strong | |
| 7 | - = @snippet.file_name | |
| 8 | - %br/ | |
| 9 | - .view_file_content | |
| 10 | - :erb | |
| 11 | - <%= raw @snippet.colorize %> | |
| 5 | + .view_file | |
| 6 | + .view_file_header | |
| 7 | + %strong | |
| 8 | + = @snippet.file_name | |
| 9 | + %br/ | |
| 10 | + .view_file_content | |
| 11 | + :erb | |
| 12 | + <%= raw @snippet.colorize %> | |
| 12 | 13 | |
| 13 | -- if can?(current_user, :admin_snippet, @project) || @snippet.author == current_user | |
| 14 | - = link_to 'Edit', edit_project_snippet_path(@project, @snippet), :class => "lbutton positive" | |
| 15 | -- if can?(current_user, :admin_snippet, @project) || @snippet.author == current_user | |
| 16 | - = link_to 'Destroy', [@project, @snippet], :confirm => 'Are you sure?', :method => :delete, :class => "lbutton delete-snippet negative", :id => "destroy_snippet_#{@snippet.id}" | |
| 17 | -.clear | |
| 18 | -%br | |
| 19 | -.snippet_notes= render "notes/notes" | |
| 14 | + - if can?(current_user, :admin_snippet, @project) || @snippet.author == current_user | |
| 15 | + = link_to 'Edit', edit_project_snippet_path(@project, @snippet), :class => "lbutton positive" | |
| 16 | + - if can?(current_user, :admin_snippet, @project) || @snippet.author == current_user | |
| 17 | + = link_to 'Destroy', [@project, @snippet], :confirm => 'Are you sure?', :method => :delete, :class => "lbutton delete-snippet negative", :id => "destroy_snippet_#{@snippet.id}" | |
| 18 | + .clear | |
| 19 | + %br | |
| 20 | + .snippet_notes= render "notes/notes" | |
| 20 | 21 | |
| 21 | -.clear | |
| 22 | + .clear | |
| 22 | 23 | |
| 24 | +- else | |
| 25 | + %h2 | |
| 26 | + Sorry, this snippet is no longer exists | ... | ... |
app/views/team_members/_show.html.haml
| ... | ... | @@ -7,11 +7,11 @@ |
| 7 | 7 | |
| 8 | 8 | %td= truncate user.email, :lenght => 16 |
| 9 | 9 | - if can? current_user, :admin_project, @project |
| 10 | - = form_for(member, :as => :team_member, :url => project_team_member_path(@project, member)) do |f| | |
| 10 | + = form_for(member, :as => :team_member, :url => project_team_member_path(@project, member)) do |f| | |
| 11 | 11 | %td= f.check_box :read, :onclick => "$(this.form).submit();" |
| 12 | 12 | %td= f.check_box :write, :onclick => "$(this.form).submit();" |
| 13 | 13 | %td= f.check_box :admin, :onclick => "$(this.form).submit();" |
| 14 | - - else | |
| 14 | + - else | |
| 15 | 15 | %td= check_box_tag "read", 1, member.read, :disabled => :disabled |
| 16 | 16 | %td= check_box_tag "commit", 1, member.write, :disabled => :disabled |
| 17 | 17 | %td= check_box_tag "admin", 1, member.admin, :disabled => :disabled | ... | ... |
app/views/team_members/show.html.haml
config/application.rb
| ... | ... | @@ -44,5 +44,8 @@ module Gitlab |
| 44 | 44 | |
| 45 | 45 | # Version of your assets, change this if you want to expire all your assets |
| 46 | 46 | config.assets.version = '1.0' |
| 47 | + | |
| 48 | + # Extend assets path | |
| 49 | + config.assets.paths << Rails.root.join('vendor', 'assets', 'images', 'jquery-ui') | |
| 47 | 50 | end |
| 48 | 51 | end | ... | ... |
config/environments/development.rb
config/environments/production.rb
| ... | ... | @@ -58,7 +58,6 @@ Gitlab::Application.configure do |
| 58 | 58 | # Send deprecation notices to registered listeners |
| 59 | 59 | config.active_support.deprecation = :notify |
| 60 | 60 | |
| 61 | - | |
| 62 | 61 | config.action_mailer.delivery_method = :sendmail |
| 63 | 62 | # Defaults to: |
| 64 | 63 | # # config.action_mailer.sendmail_settings = { | ... | ... |
config/initializers/grit_ext.rb
config/routes.rb
| 1 | 1 | Gitlab::Application.routes.draw do |
| 2 | - namespace :admin do | |
| 2 | + | |
| 3 | + get 'tags'=> 'tags#index' | |
| 4 | + get 'tags/:tag' => 'projects#index' | |
| 5 | + | |
| 6 | + | |
| 7 | + namespace :admin do | |
| 3 | 8 | resources :users |
| 4 | 9 | resources :projects |
| 5 | 10 | resources :team_members |
| ... | ... | @@ -10,19 +15,21 @@ Gitlab::Application.routes.draw do |
| 10 | 15 | root :to => "users#index" |
| 11 | 16 | end |
| 12 | 17 | |
| 13 | - get "errors/gitosis" | |
| 18 | + get "errors/gitosis" | |
| 14 | 19 | get "profile/password", :to => "profile#password" |
| 15 | 20 | put "profile/password", :to => "profile#password_update" |
| 16 | 21 | put "profile/edit", :to => "profile#social_update" |
| 17 | 22 | get "profile", :to => "profile#show" |
| 23 | + get "dashboard", :to => "dashboard#index" | |
| 18 | 24 | #get "profile/:id", :to => "profile#show" |
| 19 | 25 | |
| 20 | 26 | resources :projects, :only => [:new, :create, :index] |
| 21 | 27 | resources :keys |
| 28 | + | |
| 22 | 29 | devise_for :users |
| 23 | 30 | |
| 24 | - resources :projects, :except => [:new, :create, :index], :path => "/" do | |
| 25 | - member do | |
| 31 | + resources :projects, :except => [:new, :create, :index], :path => "/" do | |
| 32 | + member do | |
| 26 | 33 | get "tree" |
| 27 | 34 | get "blob" |
| 28 | 35 | get "team" |
| ... | ... | @@ -32,7 +39,7 @@ Gitlab::Application.routes.draw do |
| 32 | 39 | get "tree/:commit_id" => "projects#tree" |
| 33 | 40 | get "tree/:commit_id/:path" => "projects#tree", |
| 34 | 41 | :as => :tree_file, |
| 35 | - :constraints => { | |
| 42 | + :constraints => { | |
| 36 | 43 | :id => /[a-zA-Z0-9_\-]+/, |
| 37 | 44 | :commit_id => /[a-zA-Z0-9]+/, |
| 38 | 45 | :path => /.*/ |
| ... | ... | @@ -47,8 +54,11 @@ Gitlab::Application.routes.draw do |
| 47 | 54 | collection do |
| 48 | 55 | post :sort |
| 49 | 56 | end |
| 57 | + collection do | |
| 58 | + get :search | |
| 59 | + end | |
| 50 | 60 | end |
| 51 | 61 | resources :notes, :only => [:create, :destroy] |
| 52 | 62 | end |
| 53 | - root :to => "projects#index" | |
| 63 | + root :to => "dashboard#index" | |
| 54 | 64 | end | ... | ... |
db/migrate/20110913200833_devise_create_users.rb
| ... | ... | @@ -0,0 +1,34 @@ |
| 1 | +class IssueContenToNote < ActiveRecord::Migration | |
| 2 | + def up | |
| 3 | + puts "Issue content is deprecated -> move to notes" | |
| 4 | + Issue.find_each(:batch_size => 100) do |issue| | |
| 5 | + next if issue.content.blank? | |
| 6 | + note = Note.new( | |
| 7 | + :note => issue.content, | |
| 8 | + :project_id => issue.project_id, | |
| 9 | + :noteable => issue, | |
| 10 | + :created_at => issue.created_at, | |
| 11 | + :updated_at => issue.created_at | |
| 12 | + ) | |
| 13 | + note.author_id = issue.author_id | |
| 14 | + | |
| 15 | + if note.save | |
| 16 | + issue.update_attributes(:content => nil) | |
| 17 | + print "." | |
| 18 | + else | |
| 19 | + print "F" | |
| 20 | + end | |
| 21 | + end | |
| 22 | + | |
| 23 | + total = Issue.where("content is not null").count | |
| 24 | + | |
| 25 | + if total > 0 | |
| 26 | + puts "content of #{total} issues were not migrated" | |
| 27 | + else | |
| 28 | + puts "Done" | |
| 29 | + end | |
| 30 | + end | |
| 31 | + | |
| 32 | + def down | |
| 33 | + end | |
| 34 | +end | ... | ... |
db/migrate/20111101222453_acts_as_taggable_on_migration.rb
0 → 100644
| ... | ... | @@ -0,0 +1,28 @@ |
| 1 | +class ActsAsTaggableOnMigration < ActiveRecord::Migration | |
| 2 | + def self.up | |
| 3 | + create_table :tags do |t| | |
| 4 | + t.string :name | |
| 5 | + end | |
| 6 | + | |
| 7 | + create_table :taggings do |t| | |
| 8 | + t.references :tag | |
| 9 | + | |
| 10 | + # You should make sure that the column created is | |
| 11 | + # long enough to store the required class names. | |
| 12 | + t.references :taggable, :polymorphic => true | |
| 13 | + t.references :tagger, :polymorphic => true | |
| 14 | + | |
| 15 | + t.string :context | |
| 16 | + | |
| 17 | + t.datetime :created_at | |
| 18 | + end | |
| 19 | + | |
| 20 | + add_index :taggings, :tag_id | |
| 21 | + add_index :taggings, [:taggable_id, :taggable_type, :context] | |
| 22 | + end | |
| 23 | + | |
| 24 | + def self.down | |
| 25 | + drop_table :taggings | |
| 26 | + drop_table :tags | |
| 27 | + end | |
| 28 | +end | ... | ... |
db/schema.rb
| ... | ... | @@ -11,7 +11,7 @@ |
| 11 | 11 | # |
| 12 | 12 | # It's strongly recommended to check this file into your version control system. |
| 13 | 13 | |
| 14 | -ActiveRecord::Schema.define(:version => 20111025134235) do | |
| 14 | +ActiveRecord::Schema.define(:version => 20111101222453) do | |
| 15 | 15 | |
| 16 | 16 | create_table "issues", :force => true do |t| |
| 17 | 17 | t.string "title" |
| ... | ... | @@ -36,7 +36,7 @@ ActiveRecord::Schema.define(:version => 20111025134235) do |
| 36 | 36 | end |
| 37 | 37 | |
| 38 | 38 | create_table "notes", :force => true do |t| |
| 39 | - t.string "note" | |
| 39 | + t.text "note" | |
| 40 | 40 | t.string "noteable_id" |
| 41 | 41 | t.string "noteable_type" |
| 42 | 42 | t.integer "author_id" |
| ... | ... | @@ -65,6 +65,24 @@ ActiveRecord::Schema.define(:version => 20111025134235) do |
| 65 | 65 | t.datetime "created_at" |
| 66 | 66 | t.datetime "updated_at" |
| 67 | 67 | t.string "file_name" |
| 68 | + t.datetime "expires_at" | |
| 69 | + end | |
| 70 | + | |
| 71 | + create_table "taggings", :force => true do |t| | |
| 72 | + t.integer "tag_id" | |
| 73 | + t.integer "taggable_id" | |
| 74 | + t.string "taggable_type" | |
| 75 | + t.integer "tagger_id" | |
| 76 | + t.string "tagger_type" | |
| 77 | + t.string "context" | |
| 78 | + t.datetime "created_at" | |
| 79 | + end | |
| 80 | + | |
| 81 | + add_index "taggings", ["tag_id"], :name => "index_taggings_on_tag_id" | |
| 82 | + add_index "taggings", ["taggable_id", "taggable_type", "context"], :name => "index_taggings_on_taggable_id_and_taggable_type_and_context" | |
| 83 | + | |
| 84 | + create_table "tags", :force => true do |t| | |
| 85 | + t.string "name" | |
| 68 | 86 | end |
| 69 | 87 | |
| 70 | 88 | create_table "users", :force => true do |t| | ... | ... |
lib/color.rb
lib/commit_ext.rb
| 1 | 1 | module CommitExt |
| 2 | 2 | def safe_message |
| 3 | - message.encode("UTF-8", | |
| 4 | - :invalid => :replace, | |
| 5 | - :undef => :replace, | |
| 3 | + message.encode("UTF-8", | |
| 4 | + :invalid => :replace, | |
| 5 | + :undef => :replace, | |
| 6 | 6 | :universal_newline => true, |
| 7 | 7 | :replace => "") |
| 8 | - rescue | |
| 8 | + rescue | |
| 9 | 9 | "-- invalid encoding for commit message" |
| 10 | 10 | end |
| 11 | + | |
| 12 | + def created_at | |
| 13 | + committed_date | |
| 14 | + end | |
| 15 | + | |
| 16 | + def author_email | |
| 17 | + author.email.force_encoding(Encoding::UTF_8) | |
| 18 | + end | |
| 19 | + | |
| 20 | + def author_name | |
| 21 | + author.name.force_encoding(Encoding::UTF_8) | |
| 22 | + end | |
| 11 | 23 | end | ... | ... |
lib/file_size_validator.rb
| ... | ... | @@ -33,7 +33,7 @@ class FileSizeValidator < ActiveModel::EachValidator |
| 33 | 33 | |
| 34 | 34 | def validate_each(record, attribute, value) |
| 35 | 35 | raise(ArgumentError, "A CarrierWave::Uploader::Base object was expected") unless value.kind_of? CarrierWave::Uploader::Base |
| 36 | - | |
| 36 | + | |
| 37 | 37 | value = (options[:tokenizer] || DEFAULT_TOKENIZER).call(value) if value.kind_of?(String) |
| 38 | 38 | |
| 39 | 39 | CHECKS.each do |key, validity_check| |
| ... | ... | @@ -53,7 +53,7 @@ class FileSizeValidator < ActiveModel::EachValidator |
| 53 | 53 | record.errors.add(attribute, MESSAGES[key], errors_options) |
| 54 | 54 | end |
| 55 | 55 | end |
| 56 | - | |
| 56 | + | |
| 57 | 57 | def help |
| 58 | 58 | Helper.instance |
| 59 | 59 | end | ... | ... |
lib/utils.rb
1.01 KB
640 Bytes
747 Bytes
640 Bytes
640 Bytes
public/index.html.example
| ... | ... | @@ -25,7 +25,6 @@ |
| 25 | 25 | text-decoration: none; |
| 26 | 26 | } |
| 27 | 27 | |
| 28 | - | |
| 29 | 28 | #page { |
| 30 | 29 | background-color: #f0f0f0; |
| 31 | 30 | width: 750px; |
| ... | ... | @@ -57,7 +56,6 @@ |
| 57 | 56 | padding-right: 30px; |
| 58 | 57 | } |
| 59 | 58 | |
| 60 | - | |
| 61 | 59 | #header { |
| 62 | 60 | background-image: url("/assets/rails.png"); |
| 63 | 61 | background-repeat: no-repeat; |
| ... | ... | @@ -71,7 +69,6 @@ |
| 71 | 69 | font-size: 16px; |
| 72 | 70 | } |
| 73 | 71 | |
| 74 | - | |
| 75 | 72 | #about h3 { |
| 76 | 73 | margin: 0; |
| 77 | 74 | margin-bottom: 10px; |
| ... | ... | @@ -112,7 +109,6 @@ |
| 112 | 109 | padding: 10px; |
| 113 | 110 | } |
| 114 | 111 | |
| 115 | - | |
| 116 | 112 | #getting-started { |
| 117 | 113 | border-top: 1px solid #ccc; |
| 118 | 114 | margin-top: 25px; |
| ... | ... | @@ -149,7 +145,6 @@ |
| 149 | 145 | font-size: 13px; |
| 150 | 146 | } |
| 151 | 147 | |
| 152 | - | |
| 153 | 148 | #sidebar ul { |
| 154 | 149 | margin-left: 0; |
| 155 | 150 | padding-left: 0; | ... | ... |
spec/factories.rb
spec/factory.rb
| 1 | 1 | class Factory |
| 2 | 2 | @factories = {} |
| 3 | 3 | |
| 4 | - class << self | |
| 4 | + class << self | |
| 5 | 5 | def add(name, klass, &block) |
| 6 | 6 | @factories[name] = [klass, block] |
| 7 | 7 | end |
| ... | ... | @@ -13,10 +13,10 @@ class Factory |
| 13 | 13 | def new(name, opts) |
| 14 | 14 | factory = @factories[name] |
| 15 | 15 | factory[0].new.tap do |obj| |
| 16 | - factory[1].call(obj) | |
| 16 | + factory[1].call(obj) | |
| 17 | 17 | end.tap do |obj| |
| 18 | 18 | opts.each do |k, opt| |
| 19 | - obj.send("#{k}=", opt) | |
| 19 | + obj.send("#{k}=", opt) | |
| 20 | 20 | end |
| 21 | 21 | end |
| 22 | 22 | end | ... | ... |
spec/models/issue_spec.rb
spec/models/key_spec.rb
spec/models/note_spec.rb
| ... | ... | @@ -13,8 +13,8 @@ describe Note do |
| 13 | 13 | it { Factory.create(:note, |
| 14 | 14 | :project => Factory.create(:project)).should be_valid } |
| 15 | 15 | |
| 16 | - describe :authorization do | |
| 17 | - before do | |
| 16 | + describe :authorization do | |
| 17 | + before do | |
| 18 | 18 | @p1 = Factory :project |
| 19 | 19 | @p2 = Factory :project, :code => "alien", :path => "legit_1" |
| 20 | 20 | @u1 = Factory :user |
| ... | ... | @@ -24,10 +24,10 @@ describe Note do |
| 24 | 24 | @abilities << Ability |
| 25 | 25 | end |
| 26 | 26 | |
| 27 | - describe :read do | |
| 28 | - before do | |
| 29 | - @p1.users_projects.create(:user => @u1, :read => false) | |
| 30 | - @p1.users_projects.create(:user => @u2, :read => true) | |
| 27 | + describe :read do | |
| 28 | + before do | |
| 29 | + @p1.users_projects.create(:user => @u1, :read => false) | |
| 30 | + @p1.users_projects.create(:user => @u2, :read => true) | |
| 31 | 31 | @p2.users_projects.create(:user => @u3, :read => true) |
| 32 | 32 | end |
| 33 | 33 | |
| ... | ... | @@ -36,11 +36,11 @@ describe Note do |
| 36 | 36 | it { @abilities.allowed?(@u3, :read_note, @p1).should be_false } |
| 37 | 37 | end |
| 38 | 38 | |
| 39 | - describe :write do | |
| 40 | - before do | |
| 41 | - @p1.users_projects.create(:user => @u1, :write => false) | |
| 42 | - @p1.users_projects.create(:user => @u2, :write => true) | |
| 43 | - @p2.users_projects.create(:user => @u3, :write => true) | |
| 39 | + describe :write do | |
| 40 | + before do | |
| 41 | + @p1.users_projects.create(:user => @u1, :write => false) | |
| 42 | + @p1.users_projects.create(:user => @u2, :write => true) | |
| 43 | + @p2.users_projects.create(:user => @u3, :write => true) | |
| 44 | 44 | end |
| 45 | 45 | |
| 46 | 46 | it { @abilities.allowed?(@u1, :write_note, @p1).should be_false } |
| ... | ... | @@ -48,11 +48,11 @@ describe Note do |
| 48 | 48 | it { @abilities.allowed?(@u3, :write_note, @p1).should be_false } |
| 49 | 49 | end |
| 50 | 50 | |
| 51 | - describe :admin do | |
| 52 | - before do | |
| 53 | - @p1.users_projects.create(:user => @u1, :admin => false) | |
| 54 | - @p1.users_projects.create(:user => @u2, :admin => true) | |
| 55 | - @p2.users_projects.create(:user => @u3, :admin => true) | |
| 51 | + describe :admin do | |
| 52 | + before do | |
| 53 | + @p1.users_projects.create(:user => @u1, :admin => false) | |
| 54 | + @p1.users_projects.create(:user => @u2, :admin => true) | |
| 55 | + @p2.users_projects.create(:user => @u3, :admin => true) | |
| 56 | 56 | end |
| 57 | 57 | |
| 58 | 58 | it { @abilities.allowed?(@u1, :admin_note, @p1).should be_false } | ... | ... |
spec/models/project_security_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe Project do |
| 4 | - describe :authorization do | |
| 5 | - before do | |
| 4 | + describe :authorization do | |
| 5 | + before do | |
| 6 | 6 | @p1 = Factory :project |
| 7 | 7 | @u1 = Factory :user |
| 8 | 8 | @u2 = Factory :user |
| ... | ... | @@ -10,30 +10,30 @@ describe Project do |
| 10 | 10 | @abilities << Ability |
| 11 | 11 | end |
| 12 | 12 | |
| 13 | - describe :read do | |
| 14 | - before do | |
| 15 | - @p1.users_projects.create(:project => @p1, :user => @u1, :read => false) | |
| 16 | - @p1.users_projects.create(:project => @p1, :user => @u2, :read => true) | |
| 13 | + describe :read do | |
| 14 | + before do | |
| 15 | + @p1.users_projects.create(:project => @p1, :user => @u1, :read => false) | |
| 16 | + @p1.users_projects.create(:project => @p1, :user => @u2, :read => true) | |
| 17 | 17 | end |
| 18 | 18 | |
| 19 | 19 | it { @abilities.allowed?(@u1, :read_project, @p1).should be_false } |
| 20 | 20 | it { @abilities.allowed?(@u2, :read_project, @p1).should be_true } |
| 21 | 21 | end |
| 22 | 22 | |
| 23 | - describe :write do | |
| 24 | - before do | |
| 25 | - @p1.users_projects.create(:project => @p1, :user => @u1, :write => false) | |
| 26 | - @p1.users_projects.create(:project => @p1, :user => @u2, :write => true) | |
| 23 | + describe :write do | |
| 24 | + before do | |
| 25 | + @p1.users_projects.create(:project => @p1, :user => @u1, :write => false) | |
| 26 | + @p1.users_projects.create(:project => @p1, :user => @u2, :write => true) | |
| 27 | 27 | end |
| 28 | 28 | |
| 29 | 29 | it { @abilities.allowed?(@u1, :write_project, @p1).should be_false } |
| 30 | 30 | it { @abilities.allowed?(@u2, :write_project, @p1).should be_true } |
| 31 | 31 | end |
| 32 | 32 | |
| 33 | - describe :admin do | |
| 34 | - before do | |
| 35 | - @p1.users_projects.create(:project => @p1, :user => @u1, :admin => false) | |
| 36 | - @p1.users_projects.create(:project => @p1, :user => @u2, :admin => true) | |
| 33 | + describe :admin do | |
| 34 | + before do | |
| 35 | + @p1.users_projects.create(:project => @p1, :user => @u1, :admin => false) | |
| 36 | + @p1.users_projects.create(:project => @p1, :user => @u2, :admin => true) | |
| 37 | 37 | end |
| 38 | 38 | |
| 39 | 39 | it { @abilities.allowed?(@u1, :admin_project, @p1).should be_false } | ... | ... |
spec/models/project_spec.rb
| ... | ... | @@ -40,20 +40,20 @@ describe Project do |
| 40 | 40 | should_not allow_value("gitosis-admin").for(:path) |
| 41 | 41 | end |
| 42 | 42 | |
| 43 | - it "should return valid url to repo" do | |
| 43 | + it "should return valid url to repo" do | |
| 44 | 44 | project = Project.new(:path => "somewhere") |
| 45 | 45 | project.url_to_repo.should == "git@localhost:somewhere.git" |
| 46 | 46 | end |
| 47 | 47 | |
| 48 | - it "should return path to repo" do | |
| 48 | + it "should return path to repo" do | |
| 49 | 49 | project = Project.new(:path => "somewhere") |
| 50 | 50 | project.path_to_repo.should == File.join(Rails.root, "tmp", "tests", "somewhere") |
| 51 | 51 | end |
| 52 | 52 | |
| 53 | - describe :valid_repo? do | |
| 54 | - it "should be valid repo" do | |
| 53 | + describe :valid_repo? do | |
| 54 | + it "should be valid repo" do | |
| 55 | 55 | project = Factory :project |
| 56 | - project.valid_repo?.should be_true | |
| 56 | + project.valid_repo?.should be_true | |
| 57 | 57 | end |
| 58 | 58 | |
| 59 | 59 | it "should be invalid repo" do |
| ... | ... | @@ -62,43 +62,88 @@ describe Project do |
| 62 | 62 | end |
| 63 | 63 | end |
| 64 | 64 | |
| 65 | - describe "Git methods" do | |
| 65 | + describe "updates" do | |
| 66 | 66 | let(:project) { Factory :project } |
| 67 | 67 | |
| 68 | - describe :repo do | |
| 69 | - it "should return valid repo" do | |
| 68 | + before do | |
| 69 | + @issue = Factory :issue, | |
| 70 | + :project => project, | |
| 71 | + :author => Factory(:user), | |
| 72 | + :assignee => Factory(:user) | |
| 73 | + | |
| 74 | + @note = Factory :note, | |
| 75 | + :project => project, | |
| 76 | + :author => Factory(:user) | |
| 77 | + | |
| 78 | + @commit = project.fresh_commits(1).first | |
| 79 | + end | |
| 80 | + | |
| 81 | + describe "return commit, note & issue" do | |
| 82 | + it { project.updates(3).count.should == 3 } | |
| 83 | + it { project.updates(3).last.id.should == @commit.id } | |
| 84 | + it { project.updates(3).include?(@issue).should be_true } | |
| 85 | + it { project.updates(3).include?(@note).should be_true } | |
| 86 | + end | |
| 87 | + end | |
| 88 | + | |
| 89 | + describe "last_activity" do | |
| 90 | + let(:project) { Factory :project } | |
| 91 | + | |
| 92 | + before do | |
| 93 | + @note = Factory :note, | |
| 94 | + :project => project, | |
| 95 | + :author => Factory(:user) | |
| 96 | + end | |
| 97 | + | |
| 98 | + it { project.last_activity.should == @note } | |
| 99 | + it { project.last_activity_date.to_s.should == @note.created_at.to_s } | |
| 100 | + end | |
| 101 | + | |
| 102 | + describe "fresh commits" do | |
| 103 | + let(:project) { Factory :project } | |
| 104 | + | |
| 105 | + it { project.fresh_commits(3).count.should == 3 } | |
| 106 | + it { project.fresh_commits.first.id.should == "2fb376f61875b58bceee0492e270e9c805294b1a" } | |
| 107 | + it { project.fresh_commits.last.id.should == "0dac878dbfe0b9c6104a87d65fe999149a8d862c" } | |
| 108 | + end | |
| 109 | + | |
| 110 | + describe "Git methods" do | |
| 111 | + let(:project) { Factory :project } | |
| 112 | + | |
| 113 | + describe :repo do | |
| 114 | + it "should return valid repo" do | |
| 70 | 115 | project.repo.should be_kind_of(Grit::Repo) |
| 71 | 116 | end |
| 72 | 117 | |
| 73 | - it "should return nil" do | |
| 118 | + it "should return nil" do | |
| 74 | 119 | lambda { Project.new(:path => "invalid").repo }.should raise_error(Grit::NoSuchPathError) |
| 75 | 120 | end |
| 76 | 121 | |
| 77 | - it "should return nil" do | |
| 122 | + it "should return nil" do | |
| 78 | 123 | lambda { Project.new.repo }.should raise_error(TypeError) |
| 79 | 124 | end |
| 80 | 125 | end |
| 81 | 126 | |
| 82 | - describe :commit do | |
| 83 | - it "should return first head commit if without params" do | |
| 127 | + describe :commit do | |
| 128 | + it "should return first head commit if without params" do | |
| 84 | 129 | project.commit.id.should == project.repo.commits.first.id |
| 85 | 130 | end |
| 86 | 131 | |
| 87 | - it "should return valid commit" do | |
| 132 | + it "should return valid commit" do | |
| 88 | 133 | project.commit(ValidCommit::ID).should be_valid_commit |
| 89 | 134 | end |
| 90 | 135 | |
| 91 | - it "should return nil" do | |
| 136 | + it "should return nil" do | |
| 92 | 137 | project.commit("+123_4532530XYZ").should be_nil |
| 93 | 138 | end |
| 94 | 139 | end |
| 95 | 140 | |
| 96 | - describe :tree do | |
| 97 | - before do | |
| 141 | + describe :tree do | |
| 142 | + before do | |
| 98 | 143 | @commit = project.commit(ValidCommit::ID) |
| 99 | 144 | end |
| 100 | 145 | |
| 101 | - it "should raise error w/o arguments" do | |
| 146 | + it "should raise error w/o arguments" do | |
| 102 | 147 | lambda { project.tree }.should raise_error |
| 103 | 148 | end |
| 104 | 149 | ... | ... |
spec/models/snippet_spec.rb
spec/models/user_spec.rb
spec/models/users_project_spec.rb
spec/monkeypatch.rb
| 1 | 1 | # Stubbing Project <-> gitosis path |
| 2 | 2 | # create project using Factory only |
| 3 | -class Project | |
| 3 | +class Project | |
| 4 | 4 | def update_gitosis_project |
| 5 | 5 | true |
| 6 | 6 | end |
| ... | ... | @@ -9,12 +9,12 @@ class Project |
| 9 | 9 | true |
| 10 | 10 | end |
| 11 | 11 | |
| 12 | - def path_to_repo | |
| 12 | + def path_to_repo | |
| 13 | 13 | File.join(Rails.root, "tmp", "tests", path) |
| 14 | 14 | end |
| 15 | 15 | end |
| 16 | 16 | |
| 17 | -class Key | |
| 17 | +class Key | |
| 18 | 18 | def update_gitosis |
| 19 | 19 | true |
| 20 | 20 | end | ... | ... |
spec/requests/admin/admin_projects_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Admin::Projects" do |
| 4 | - before do | |
| 4 | + before do | |
| 5 | 5 | @project = Factory :project, |
| 6 | 6 | :name => "LeGiT", |
| 7 | 7 | :code => "LGT" |
| ... | ... | @@ -9,7 +9,7 @@ describe "Admin::Projects" do |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | describe "GET /admin/projects" do |
| 12 | - before do | |
| 12 | + before do | |
| 13 | 13 | visit admin_projects_path |
| 14 | 14 | end |
| 15 | 15 | |
| ... | ... | @@ -17,49 +17,49 @@ describe "Admin::Projects" do |
| 17 | 17 | current_path.should == admin_projects_path |
| 18 | 18 | end |
| 19 | 19 | |
| 20 | - it "should have projects list" do | |
| 20 | + it "should have projects list" do | |
| 21 | 21 | page.should have_content(@project.code) |
| 22 | 22 | page.should have_content(@project.name) |
| 23 | 23 | end |
| 24 | 24 | end |
| 25 | 25 | |
| 26 | - describe "GET /admin/projects/:id" do | |
| 27 | - before do | |
| 26 | + describe "GET /admin/projects/:id" do | |
| 27 | + before do | |
| 28 | 28 | visit admin_projects_path |
| 29 | 29 | click_link "Show" |
| 30 | 30 | end |
| 31 | 31 | |
| 32 | - it "should have project info" do | |
| 32 | + it "should have project info" do | |
| 33 | 33 | page.should have_content(@project.code) |
| 34 | 34 | page.should have_content(@project.name) |
| 35 | 35 | end |
| 36 | 36 | end |
| 37 | 37 | |
| 38 | - describe "GET /admin/projects/:id/edit" do | |
| 39 | - before do | |
| 38 | + describe "GET /admin/projects/:id/edit" do | |
| 39 | + before do | |
| 40 | 40 | visit admin_projects_path |
| 41 | 41 | click_link "edit_project_#{@project.id}" |
| 42 | 42 | end |
| 43 | 43 | |
| 44 | - it "should have project edit page" do | |
| 44 | + it "should have project edit page" do | |
| 45 | 45 | page.should have_content("Name") |
| 46 | 46 | page.should have_content("Code") |
| 47 | 47 | end |
| 48 | 48 | |
| 49 | 49 | describe "Update project" do |
| 50 | - before do | |
| 50 | + before do | |
| 51 | 51 | fill_in "project_name", :with => "Big Bang" |
| 52 | 52 | fill_in "project_code", :with => "BB1" |
| 53 | 53 | click_button "Save" |
| 54 | 54 | @project.reload |
| 55 | 55 | end |
| 56 | 56 | |
| 57 | - it "should show page with new data" do | |
| 57 | + it "should show page with new data" do | |
| 58 | 58 | page.should have_content("BB1") |
| 59 | 59 | page.should have_content("Big Bang") |
| 60 | 60 | end |
| 61 | 61 | |
| 62 | - it "should change project entry" do | |
| 62 | + it "should change project entry" do | |
| 63 | 63 | @project.name.should == "Big Bang" |
| 64 | 64 | @project.code.should == "BB1" |
| 65 | 65 | end |
| ... | ... | @@ -67,24 +67,24 @@ describe "Admin::Projects" do |
| 67 | 67 | end |
| 68 | 68 | |
| 69 | 69 | describe "GET /admin/projects/new" do |
| 70 | - before do | |
| 70 | + before do | |
| 71 | 71 | visit admin_projects_path |
| 72 | 72 | click_link "New Project" |
| 73 | 73 | end |
| 74 | 74 | |
| 75 | 75 | it "should be correct path" do |
| 76 | - current_path.should == new_admin_project_path | |
| 76 | + current_path.should == new_admin_project_path | |
| 77 | 77 | end |
| 78 | 78 | |
| 79 | 79 | it "should have labels for new project" do |
| 80 | - page.should have_content("Name") | |
| 81 | - page.should have_content("Path") | |
| 82 | - page.should have_content("Description") | |
| 80 | + page.should have_content("Name") | |
| 81 | + page.should have_content("Path") | |
| 82 | + page.should have_content("Description") | |
| 83 | 83 | end |
| 84 | 84 | end |
| 85 | 85 | |
| 86 | 86 | describe "POST /admin/projects" do |
| 87 | - before do | |
| 87 | + before do | |
| 88 | 88 | visit new_admin_project_path |
| 89 | 89 | fill_in 'Name', :with => 'NewProject' |
| 90 | 90 | fill_in 'Code', :with => 'NPR' | ... | ... |
spec/requests/admin/admin_users_spec.rb
| ... | ... | @@ -4,7 +4,7 @@ describe "Admin::Users" do |
| 4 | 4 | before { login_as :admin } |
| 5 | 5 | |
| 6 | 6 | describe "GET /admin/users" do |
| 7 | - before do | |
| 7 | + before do | |
| 8 | 8 | visit admin_users_path |
| 9 | 9 | end |
| 10 | 10 | |
| ... | ... | @@ -12,14 +12,14 @@ describe "Admin::Users" do |
| 12 | 12 | current_path.should == admin_users_path |
| 13 | 13 | end |
| 14 | 14 | |
| 15 | - it "should have users list" do | |
| 15 | + it "should have users list" do | |
| 16 | 16 | page.should have_content(@user.email) |
| 17 | 17 | page.should have_content(@user.name) |
| 18 | 18 | end |
| 19 | 19 | end |
| 20 | 20 | |
| 21 | - describe "GET /admin/users/new" do | |
| 22 | - before do | |
| 21 | + describe "GET /admin/users/new" do | |
| 22 | + before do | |
| 23 | 23 | @password = "123ABC" |
| 24 | 24 | visit new_admin_user_path |
| 25 | 25 | fill_in "user_name", :with => "Big Bang" |
| ... | ... | @@ -28,23 +28,23 @@ describe "Admin::Users" do |
| 28 | 28 | fill_in "user_password_confirmation", :with => @password |
| 29 | 29 | end |
| 30 | 30 | |
| 31 | - it "should create new user" do | |
| 31 | + it "should create new user" do | |
| 32 | 32 | expect { click_button "Save" }.to change {User.count}.by(1) |
| 33 | 33 | end |
| 34 | 34 | |
| 35 | - it "should create user with valid data" do | |
| 35 | + it "should create user with valid data" do | |
| 36 | 36 | click_button "Save" |
| 37 | 37 | user = User.last |
| 38 | 38 | user.name.should == "Big Bang" |
| 39 | 39 | user.email.should == "bigbang@mail.com" |
| 40 | 40 | end |
| 41 | 41 | |
| 42 | - it "should call send mail" do | |
| 42 | + it "should call send mail" do | |
| 43 | 43 | Notify.should_receive(:new_user_email).and_return(stub(:deliver => true)) |
| 44 | 44 | click_button "Save" |
| 45 | 45 | end |
| 46 | 46 | |
| 47 | - it "should send valid email to user with email & password" do | |
| 47 | + it "should send valid email to user with email & password" do | |
| 48 | 48 | click_button "Save" |
| 49 | 49 | user = User.last |
| 50 | 50 | email = ActionMailer::Base.deliveries.last |
| ... | ... | @@ -54,45 +54,45 @@ describe "Admin::Users" do |
| 54 | 54 | end |
| 55 | 55 | end |
| 56 | 56 | |
| 57 | - describe "GET /admin/users/:id" do | |
| 58 | - before do | |
| 57 | + describe "GET /admin/users/:id" do | |
| 58 | + before do | |
| 59 | 59 | visit admin_users_path |
| 60 | 60 | click_link "Show" |
| 61 | 61 | end |
| 62 | 62 | |
| 63 | - it "should have user info" do | |
| 63 | + it "should have user info" do | |
| 64 | 64 | page.should have_content(@user.email) |
| 65 | 65 | page.should have_content(@user.name) |
| 66 | 66 | page.should have_content(@user.is_admin?) |
| 67 | 67 | end |
| 68 | 68 | end |
| 69 | 69 | |
| 70 | - describe "GET /admin/users/:id/edit" do | |
| 71 | - before do | |
| 70 | + describe "GET /admin/users/:id/edit" do | |
| 71 | + before do | |
| 72 | 72 | @simple_user = Factory :user |
| 73 | 73 | visit admin_users_path |
| 74 | 74 | click_link "edit_user_#{@simple_user.id}" |
| 75 | 75 | end |
| 76 | 76 | |
| 77 | - it "should have user edit page" do | |
| 77 | + it "should have user edit page" do | |
| 78 | 78 | page.should have_content("Name") |
| 79 | 79 | page.should have_content("Password") |
| 80 | 80 | end |
| 81 | 81 | |
| 82 | 82 | describe "Update user" do |
| 83 | - before do | |
| 83 | + before do | |
| 84 | 84 | fill_in "user_name", :with => "Big Bang" |
| 85 | 85 | fill_in "user_email", :with => "bigbang@mail.com" |
| 86 | 86 | check "user_admin" |
| 87 | 87 | click_button "Save" |
| 88 | 88 | end |
| 89 | 89 | |
| 90 | - it "should show page with new data" do | |
| 90 | + it "should show page with new data" do | |
| 91 | 91 | page.should have_content("bigbang@mail.com") |
| 92 | 92 | page.should have_content("Big Bang") |
| 93 | 93 | end |
| 94 | 94 | |
| 95 | - it "should change user entry" do | |
| 95 | + it "should change user entry" do | |
| 96 | 96 | @simple_user.reload |
| 97 | 97 | @simple_user.name.should == "Big Bang" |
| 98 | 98 | @simple_user.is_admin?.should be_true | ... | ... |
spec/requests/admin/security_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Admin::Projects" do |
| 4 | - describe "GET /admin/projects" do | |
| 4 | + describe "GET /admin/projects" do | |
| 5 | 5 | it { admin_projects_path.should be_allowed_for :admin } |
| 6 | 6 | it { admin_projects_path.should be_denied_for :user } |
| 7 | 7 | it { admin_projects_path.should be_denied_for :visitor } |
| 8 | 8 | end |
| 9 | 9 | |
| 10 | - describe "GET /admin/users" do | |
| 10 | + describe "GET /admin/users" do | |
| 11 | 11 | it { admin_users_path.should be_allowed_for :admin } |
| 12 | 12 | it { admin_users_path.should be_denied_for :user } |
| 13 | 13 | it { admin_users_path.should be_denied_for :visitor } |
| 14 | 14 | end |
| 15 | 15 | |
| 16 | - describe "GET /admin/team_members" do | |
| 16 | + describe "GET /admin/team_members" do | |
| 17 | 17 | it { admin_team_members_path.should be_allowed_for :admin } |
| 18 | 18 | it { admin_team_members_path.should be_denied_for :user } |
| 19 | 19 | it { admin_team_members_path.should be_denied_for :visitor } |
| 20 | 20 | end |
| 21 | 21 | |
| 22 | - describe "GET /admin/emails" do | |
| 22 | + describe "GET /admin/emails" do | |
| 23 | 23 | it { admin_emails_path.should be_allowed_for :admin } |
| 24 | 24 | it { admin_emails_path.should be_denied_for :user } |
| 25 | 25 | it { admin_emails_path.should be_denied_for :visitor } | ... | ... |
spec/requests/commits_notes_spec.rb
| ... | ... | @@ -4,15 +4,14 @@ describe "Issues" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | let!(:commit) { project.repo.commits.first } |
| 6 | 6 | |
| 7 | - before do | |
| 7 | + before do | |
| 8 | 8 | login_as :user |
| 9 | 9 | project.add_access(@user, :read, :write) |
| 10 | 10 | end |
| 11 | 11 | |
| 12 | - describe "add new note", :js => true do | |
| 13 | - before do | |
| 12 | + describe "add new note", :js => true do | |
| 13 | + before do | |
| 14 | 14 | visit project_commit_path(project, commit) |
| 15 | - click_link "Comments" # notes tab | |
| 16 | 15 | fill_in "note_note", :with => "I commented this commit" |
| 17 | 16 | click_button "Add note" |
| 18 | 17 | end | ... | ... |
spec/requests/commits_spec.rb
| ... | ... | @@ -3,13 +3,13 @@ require 'spec_helper' |
| 3 | 3 | describe "Commits" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | let!(:commit) { project.repo.commits.first } |
| 6 | - before do | |
| 6 | + before do | |
| 7 | 7 | login_as :user |
| 8 | 8 | project.add_access(@user, :read) |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | describe "GET /commits" do |
| 12 | - before do | |
| 12 | + before do | |
| 13 | 13 | visit project_commits_path(project) |
| 14 | 14 | end |
| 15 | 15 | |
| ... | ... | @@ -17,22 +17,22 @@ describe "Commits" do |
| 17 | 17 | current_path.should == project_commits_path(project) |
| 18 | 18 | end |
| 19 | 19 | |
| 20 | - it "should have project name" do | |
| 20 | + it "should have project name" do | |
| 21 | 21 | page.should have_content(project.name) |
| 22 | 22 | end |
| 23 | 23 | |
| 24 | - it "should list commits" do | |
| 24 | + it "should list commits" do | |
| 25 | 25 | page.should have_content(commit.author) |
| 26 | 26 | page.should have_content(commit.message) |
| 27 | 27 | end |
| 28 | 28 | end |
| 29 | 29 | |
| 30 | - describe "GET /commits/:id" do | |
| 31 | - before do | |
| 30 | + describe "GET /commits/:id" do | |
| 31 | + before do | |
| 32 | 32 | visit project_commit_path(project, commit) |
| 33 | 33 | end |
| 34 | 34 | |
| 35 | - it "should have valid path" do | |
| 35 | + it "should have valid path" do | |
| 36 | 36 | current_path.should == project_commit_path(project, commit) |
| 37 | 37 | end |
| 38 | 38 | end | ... | ... |
| ... | ... | @@ -0,0 +1,30 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe "Dashboard" do | |
| 4 | + before { login_as :user } | |
| 5 | + | |
| 6 | + describe "GET /dashboard" do | |
| 7 | + before do | |
| 8 | + @project = Factory :project | |
| 9 | + @project.add_access(@user, :read, :write) | |
| 10 | + visit dashboard_path | |
| 11 | + end | |
| 12 | + | |
| 13 | + it "should be on dashboard page" do | |
| 14 | + current_path.should == dashboard_path | |
| 15 | + end | |
| 16 | + | |
| 17 | + it "should have projects panel" do | |
| 18 | + within ".project-list" do | |
| 19 | + page.should have_content(@project.name) | |
| 20 | + end | |
| 21 | + end | |
| 22 | + | |
| 23 | + it "should have news feed" do | |
| 24 | + within "#news-feed" do | |
| 25 | + page.should have_content(@project.commit.author.name) | |
| 26 | + page.should have_content(@project.commit.safe_message) | |
| 27 | + end | |
| 28 | + end | |
| 29 | + end | |
| 30 | +end | ... | ... |
spec/requests/issues_notes_spec.rb
| ... | ... | @@ -3,7 +3,7 @@ require 'spec_helper' |
| 3 | 3 | describe "Issues" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | |
| 6 | - before do | |
| 6 | + before do | |
| 7 | 7 | login_as :user |
| 8 | 8 | project.add_access(@user, :read, :write) |
| 9 | 9 | |
| ... | ... | @@ -13,8 +13,8 @@ describe "Issues" do |
| 13 | 13 | :project => project |
| 14 | 14 | end |
| 15 | 15 | |
| 16 | - describe "add new note", :js => true do | |
| 17 | - before do | |
| 16 | + describe "add new note", :js => true do | |
| 17 | + before do | |
| 18 | 18 | visit project_issue_path(project, @issue) |
| 19 | 19 | fill_in "note_note", :with => "I commented this issue" |
| 20 | 20 | click_button "Add note" | ... | ... |
spec/requests/issues_spec.rb
| ... | ... | @@ -3,13 +3,16 @@ require 'spec_helper' |
| 3 | 3 | describe "Issues" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | |
| 6 | - before do | |
| 6 | + before do | |
| 7 | 7 | login_as :user |
| 8 | + @user2 = Factory :user | |
| 9 | + | |
| 8 | 10 | project.add_access(@user, :read, :write) |
| 11 | + project.add_access(@user2, :read, :write) | |
| 9 | 12 | end |
| 10 | 13 | |
| 11 | 14 | describe "GET /issues" do |
| 12 | - before do | |
| 15 | + before do | |
| 13 | 16 | @issue = Factory :issue, |
| 14 | 17 | :author => @user, |
| 15 | 18 | :assignee => @user, |
| ... | ... | @@ -24,23 +27,23 @@ describe "Issues" do |
| 24 | 27 | it { should have_content(@issue.project.name) } |
| 25 | 28 | it { should have_content(@issue.assignee.name) } |
| 26 | 29 | |
| 27 | - describe "Destroy" do | |
| 28 | - before do | |
| 30 | + describe "Destroy" do | |
| 31 | + before do | |
| 29 | 32 | # admin access to remove issue |
| 30 | 33 | @user.users_projects.destroy_all |
| 31 | 34 | project.add_access(@user, :read, :write, :admin) |
| 32 | 35 | visit project_issues_path(project) |
| 33 | 36 | end |
| 34 | 37 | |
| 35 | - it "should remove entry" do | |
| 38 | + it "should remove entry" do | |
| 36 | 39 | expect { |
| 37 | 40 | click_link "destroy_issue_#{@issue.id}" |
| 38 | 41 | }.to change { Issue.count }.by(-1) |
| 39 | 42 | end |
| 40 | 43 | end |
| 41 | 44 | |
| 42 | - describe "statuses", :js => true do | |
| 43 | - before do | |
| 45 | + describe "statuses", :js => true do | |
| 46 | + before do | |
| 44 | 47 | @closed_issue = Factory :issue, |
| 45 | 48 | :author => @user, |
| 46 | 49 | :assignee => @user, |
| ... | ... | @@ -48,72 +51,119 @@ describe "Issues" do |
| 48 | 51 | :closed => true |
| 49 | 52 | end |
| 50 | 53 | |
| 51 | - it "should show only open" do | |
| 52 | - should have_content(@issue.title) | |
| 54 | + it "should show only open" do | |
| 55 | + should have_content(@issue.title[0..25]) | |
| 53 | 56 | should have_no_content(@closed_issue.title) |
| 54 | 57 | end |
| 55 | 58 | |
| 56 | - it "should show only closed" do | |
| 59 | + it "should show only closed" do | |
| 57 | 60 | choose "closed_issues" |
| 58 | 61 | should have_no_content(@issue.title) |
| 59 | - should have_content(@closed_issue.title) | |
| 62 | + should have_content(@closed_issue.title[0..25]) | |
| 60 | 63 | end |
| 61 | 64 | |
| 62 | - it "should show all" do | |
| 65 | + it "should show all" do | |
| 63 | 66 | choose "all_issues" |
| 64 | - should have_content(@issue.title) | |
| 65 | - should have_content(@closed_issue.title) | |
| 67 | + should have_content(@issue.title[0..25]) | |
| 68 | + should have_content(@closed_issue.title[0..25]) | |
| 66 | 69 | end |
| 67 | 70 | end |
| 68 | 71 | end |
| 69 | 72 | |
| 70 | - describe "New issue", :js => true do | |
| 71 | - before do | |
| 73 | + describe "New issue", :js => true do | |
| 74 | + before do | |
| 72 | 75 | visit project_issues_path(project) |
| 73 | 76 | click_link "New Issue" |
| 74 | 77 | end |
| 75 | 78 | |
| 76 | - it "should open new issue popup" do | |
| 79 | + it "should open new issue popup" do | |
| 77 | 80 | page.should have_content("Add new issue") |
| 78 | 81 | end |
| 79 | 82 | |
| 80 | - describe "fill in" do | |
| 81 | - before do | |
| 82 | - fill_in "issue_title", :with => "bug 345" | |
| 83 | - fill_in "issue_content", :with => "app bug 345" | |
| 84 | - click_link "Select user" | |
| 85 | - click_link @user.name | |
| 83 | + describe "fill in" do | |
| 84 | + describe 'assign to me' do | |
| 85 | + before do | |
| 86 | + fill_in "issue_title", :with => "bug 345" | |
| 87 | + click_link "Select user" | |
| 88 | + within "#issue_assignee_id-menu" do | |
| 89 | + click_link @user.name | |
| 90 | + end | |
| 91 | + end | |
| 92 | + | |
| 93 | + it { expect { click_button "Save" }.to change {Issue.count}.by(1) } | |
| 94 | + | |
| 95 | + it "should add new issue to table" do | |
| 96 | + click_button "Save" | |
| 97 | + | |
| 98 | + page.should_not have_content("Add new issue") | |
| 99 | + page.should have_content @user.name | |
| 100 | + page.should have_content "bug 345" | |
| 101 | + page.should have_content project.name | |
| 102 | + end | |
| 103 | + | |
| 104 | + it "should call send mail" do | |
| 105 | + Notify.should_not_receive(:new_issue_email) | |
| 106 | + click_button "Save" | |
| 107 | + end | |
| 86 | 108 | end |
| 87 | 109 | |
| 88 | - it { expect { click_button "Save" }.to change {Issue.count}.by(1) } | |
| 110 | + describe 'assign to other' do | |
| 111 | + before do | |
| 112 | + fill_in "issue_title", :with => "bug 345" | |
| 113 | + click_link "Select user" | |
| 114 | + within "#issue_assignee_id-menu" do | |
| 115 | + click_link @user2.name | |
| 116 | + end | |
| 117 | + end | |
| 118 | + | |
| 119 | + it { expect { click_button "Save" }.to change {Issue.count}.by(1) } | |
| 120 | + | |
| 121 | + it "should add new issue to table" do | |
| 122 | + click_button "Save" | |
| 123 | + | |
| 124 | + page.should_not have_content("Add new issue") | |
| 125 | + page.should have_content @user2.name | |
| 126 | + page.should have_content "bug 345" | |
| 127 | + page.should have_content project.name | |
| 128 | + end | |
| 129 | + | |
| 130 | + it "should call send mail" do | |
| 131 | + Notify.should_receive(:new_issue_email).and_return(stub(:deliver => true)) | |
| 132 | + click_button "Save" | |
| 133 | + end | |
| 134 | + | |
| 135 | + it "should send valid email to user with email & password" do | |
| 136 | + click_button "Save" | |
| 137 | + issue = Issue.last | |
| 138 | + email = ActionMailer::Base.deliveries.last | |
| 139 | + email.subject.should have_content("New Issue was created") | |
| 140 | + email.body.should have_content(issue.title) | |
| 141 | + email.body.should have_content(issue.assignee.name) | |
| 142 | + end | |
| 89 | 143 | |
| 90 | - it "should add new issue to table" do | |
| 91 | - click_button "Save" | |
| 92 | - | |
| 93 | - page.should_not have_content("Add new issue") | |
| 94 | - page.should have_content @user.name | |
| 95 | - page.should have_content "bug 345" | |
| 96 | - page.should have_content project.name | |
| 97 | 144 | end |
| 145 | + end | |
| 146 | + end | |
| 98 | 147 | |
| 99 | - it "should call send mail" do | |
| 100 | - Notify.should_receive(:new_issue_email).and_return(stub(:deliver => true)) | |
| 101 | - click_button "Save" | |
| 102 | - end | |
| 148 | + describe "Show issue" do | |
| 149 | + before do | |
| 150 | + @issue = Factory :issue, | |
| 151 | + :author => @user, | |
| 152 | + :assignee => @user, | |
| 153 | + :project => project | |
| 103 | 154 | |
| 104 | - it "should send valid email to user with email & password" do | |
| 105 | - click_button "Save" | |
| 106 | - issue = Issue.last | |
| 107 | - email = ActionMailer::Base.deliveries.last | |
| 108 | - email.subject.should have_content("New Issue was created") | |
| 109 | - email.body.should have_content(issue.title) | |
| 110 | - email.body.should have_content(issue.assignee.name) | |
| 111 | - end | |
| 155 | + visit project_issue_path(project, @issue) | |
| 156 | + end | |
| 157 | + | |
| 158 | + it "should have valid show page for issue" do | |
| 159 | + page.should have_content @issue.title | |
| 160 | + page.should have_content @user.name | |
| 161 | + page.should have_content "today" | |
| 112 | 162 | end |
| 113 | 163 | end |
| 114 | 164 | |
| 115 | - describe "Edit issue", :js => true do | |
| 116 | - before do | |
| 165 | + describe "Edit issue", :js => true do | |
| 166 | + before do | |
| 117 | 167 | @issue = Factory :issue, |
| 118 | 168 | :author => @user, |
| 119 | 169 | :assignee => @user, |
| ... | ... | @@ -122,19 +172,18 @@ describe "Issues" do |
| 122 | 172 | click_link "Edit" |
| 123 | 173 | end |
| 124 | 174 | |
| 125 | - it "should open new issue popup" do | |
| 175 | + it "should open new issue popup" do | |
| 126 | 176 | page.should have_content("Issue ##{@issue.id}") |
| 127 | 177 | end |
| 128 | 178 | |
| 129 | - describe "fill in" do | |
| 179 | + describe "fill in" do | |
| 130 | 180 | before do |
| 131 | 181 | fill_in "issue_title", :with => "bug 345" |
| 132 | - fill_in "issue_content", :with => "app bug 345" | |
| 133 | 182 | end |
| 134 | 183 | |
| 135 | 184 | it { expect { click_button "Save" }.to_not change {Issue.count} } |
| 136 | 185 | |
| 137 | - it "should update issue fields" do | |
| 186 | + it "should update issue fields" do | |
| 138 | 187 | click_button "Save" |
| 139 | 188 | |
| 140 | 189 | page.should_not have_content("Issue ##{@issue.id}") |
| ... | ... | @@ -144,4 +193,51 @@ describe "Issues" do |
| 144 | 193 | end |
| 145 | 194 | end |
| 146 | 195 | end |
| 196 | + | |
| 197 | + describe "Search issue", :js => true do | |
| 198 | + before do | |
| 199 | + ['foobar', 'foobar2', 'gitlab'].each do |title| | |
| 200 | + @issue = Factory :issue, | |
| 201 | + :author => @user, | |
| 202 | + :assignee => @user, | |
| 203 | + :project => project, | |
| 204 | + :title => title | |
| 205 | + @issue.save | |
| 206 | + end | |
| 207 | + end | |
| 208 | + | |
| 209 | + it "should be able to search on different statuses" do | |
| 210 | + @issue = Issue.first | |
| 211 | + @issue.closed = true | |
| 212 | + @issue.save | |
| 213 | + | |
| 214 | + visit project_issues_path(project) | |
| 215 | + choose 'closed_issues' | |
| 216 | + fill_in 'issue_search', :with => 'foobar' | |
| 217 | + | |
| 218 | + page.should have_content 'foobar' | |
| 219 | + page.should_not have_content 'foobar2' | |
| 220 | + page.should_not have_content 'gitlab' | |
| 221 | + end | |
| 222 | + | |
| 223 | + it "should search for term and return the correct results" do | |
| 224 | + visit project_issues_path(project) | |
| 225 | + fill_in 'issue_search', :with => 'foobar' | |
| 226 | + | |
| 227 | + page.should have_content 'foobar' | |
| 228 | + page.should have_content 'foobar2' | |
| 229 | + page.should_not have_content 'gitlab' | |
| 230 | + end | |
| 231 | + | |
| 232 | + it "should return all results if term has been cleared" do | |
| 233 | + visit project_issues_path(project) | |
| 234 | + fill_in "issue_search", :with => "foobar" | |
| 235 | + # Because fill_in, :with => "" triggers nothing we need to trigger a keyup event | |
| 236 | + page.execute_script("$('.issue_search').val('').keyup();"); | |
| 237 | + | |
| 238 | + page.should have_content 'foobar' | |
| 239 | + page.should have_content 'foobar2' | |
| 240 | + page.should have_content 'gitlab' | |
| 241 | + end | |
| 242 | + end | |
| 147 | 243 | end | ... | ... |
spec/requests/keys_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Issues" do |
| 4 | - before do | |
| 4 | + before do | |
| 5 | 5 | login_as :user |
| 6 | 6 | end |
| 7 | 7 | |
| 8 | 8 | describe "GET /keys" do |
| 9 | - before do | |
| 9 | + before do | |
| 10 | 10 | @key = Factory :key, :user => @user |
| 11 | 11 | visit keys_path |
| 12 | 12 | end |
| ... | ... | @@ -15,8 +15,8 @@ describe "Issues" do |
| 15 | 15 | |
| 16 | 16 | it { should have_content(@key.title) } |
| 17 | 17 | |
| 18 | - describe "Destroy" do | |
| 19 | - it "should remove entry" do | |
| 18 | + describe "Destroy" do | |
| 19 | + it "should remove entry" do | |
| 20 | 20 | expect { |
| 21 | 21 | click_link "destroy_key_#{@key.id}" |
| 22 | 22 | }.to change { @user.keys.count }.by(-1) |
| ... | ... | @@ -24,17 +24,17 @@ describe "Issues" do |
| 24 | 24 | end |
| 25 | 25 | end |
| 26 | 26 | |
| 27 | - describe "New key", :js => true do | |
| 28 | - before do | |
| 27 | + describe "New key", :js => true do | |
| 28 | + before do | |
| 29 | 29 | visit keys_path |
| 30 | 30 | click_link "Add new" |
| 31 | 31 | end |
| 32 | 32 | |
| 33 | - it "should open new key popup" do | |
| 33 | + it "should open new key popup" do | |
| 34 | 34 | page.should have_content("Add new public key") |
| 35 | 35 | end |
| 36 | 36 | |
| 37 | - describe "fill in" do | |
| 37 | + describe "fill in" do | |
| 38 | 38 | before do |
| 39 | 39 | fill_in "key_title", :with => "laptop" |
| 40 | 40 | fill_in "key_key", :with => "publickey234=" |
| ... | ... | @@ -42,7 +42,7 @@ describe "Issues" do |
| 42 | 42 | |
| 43 | 43 | it { expect { click_button "Save" }.to change {Key.count}.by(1) } |
| 44 | 44 | |
| 45 | - it "should add new key to table" do | |
| 45 | + it "should add new key to table" do | |
| 46 | 46 | click_button "Save" |
| 47 | 47 | |
| 48 | 48 | page.should_not have_content("Add new public key") | ... | ... |
spec/requests/profile_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Profile" do |
| 4 | - before do | |
| 4 | + before do | |
| 5 | 5 | login_as :user |
| 6 | 6 | end |
| 7 | 7 | |
| 8 | 8 | describe "Show profile" do |
| 9 | - before do | |
| 9 | + before do | |
| 10 | 10 | visit profile_path |
| 11 | 11 | end |
| 12 | 12 | |
| ... | ... | @@ -15,13 +15,13 @@ describe "Profile" do |
| 15 | 15 | end |
| 16 | 16 | |
| 17 | 17 | describe "Profile update" do |
| 18 | - before do | |
| 18 | + before do | |
| 19 | 19 | visit profile_path |
| 20 | 20 | fill_in "user_skype", :with => "testskype" |
| 21 | - fill_in "user_linkedin", :with => "testlinkedin" | |
| 21 | + fill_in "user_linkedin", :with => "testlinkedin" | |
| 22 | 22 | fill_in "user_twitter", :with => "testtwitter" |
| 23 | 23 | click_button "Save" |
| 24 | - @user.reload | |
| 24 | + @user.reload | |
| 25 | 25 | end |
| 26 | 26 | |
| 27 | 27 | it { @user.skype.should == 'testskype' } |
| ... | ... | @@ -29,18 +29,17 @@ describe "Profile" do |
| 29 | 29 | it { @user.twitter.should == 'testtwitter' } |
| 30 | 30 | end |
| 31 | 31 | |
| 32 | - | |
| 33 | 32 | describe "Password update" do |
| 34 | - before do | |
| 33 | + before do | |
| 35 | 34 | visit profile_password_path |
| 36 | 35 | end |
| 37 | 36 | |
| 38 | 37 | it { page.should have_content("Password") } |
| 39 | 38 | it { page.should have_content("Password confirmation") } |
| 40 | 39 | |
| 41 | - describe "change password" do | |
| 42 | - before do | |
| 43 | - @old_pwd = @user.encrypted_password | |
| 40 | + describe "change password" do | |
| 41 | + before do | |
| 42 | + @old_pwd = @user.encrypted_password | |
| 44 | 43 | fill_in "user_password", :with => "777777" |
| 45 | 44 | fill_in "user_password_confirmation", :with => "777777" |
| 46 | 45 | click_button "Save" |
| ... | ... | @@ -51,18 +50,18 @@ describe "Profile" do |
| 51 | 50 | current_path.should == new_user_session_path |
| 52 | 51 | end |
| 53 | 52 | |
| 54 | - it "should change password" do | |
| 53 | + it "should change password" do | |
| 55 | 54 | @user.encrypted_password.should_not == @old_pwd |
| 56 | 55 | end |
| 57 | 56 | |
| 58 | - describe "login with new password" do | |
| 57 | + describe "login with new password" do | |
| 59 | 58 | before do |
| 60 | 59 | fill_in "user_email", :with => @user.email |
| 61 | 60 | fill_in "user_password", :with => "777777" |
| 62 | 61 | click_button "Sign in" |
| 63 | 62 | end |
| 64 | - | |
| 65 | - it "should login user" do | |
| 63 | + | |
| 64 | + it "should login user" do | |
| 66 | 65 | current_path.should == root_path |
| 67 | 66 | end |
| 68 | 67 | end | ... | ... |
spec/requests/projects_security_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Projects" do |
| 4 | - describe "GET /projects" do | |
| 4 | + describe "GET /projects" do | |
| 5 | 5 | it { projects_path.should be_allowed_for :admin } |
| 6 | 6 | it { projects_path.should be_allowed_for :user } |
| 7 | 7 | it { projects_path.should be_denied_for :visitor } |
| 8 | 8 | end |
| 9 | 9 | |
| 10 | - describe "GET /projects/new" do | |
| 10 | + describe "GET /projects/new" do | |
| 11 | 11 | it { projects_path.should be_allowed_for :admin } |
| 12 | 12 | it { projects_path.should be_allowed_for :user } |
| 13 | 13 | it { projects_path.should be_denied_for :visitor } |
| 14 | 14 | end |
| 15 | 15 | |
| 16 | 16 | describe "Project" do |
| 17 | - before do | |
| 17 | + before do | |
| 18 | 18 | @project = Factory :project |
| 19 | 19 | @u1 = Factory :user |
| 20 | 20 | @u2 = Factory :user |
| 21 | 21 | @u3 = Factory :user |
| 22 | 22 | # full access |
| 23 | - @project.users_projects.create(:user => @u1, :read => true, :write => true, :admin => true) | |
| 23 | + @project.users_projects.create(:user => @u1, :read => true, :write => true, :admin => true) | |
| 24 | 24 | # no access |
| 25 | - @project.users_projects.create(:user => @u2, :read => false, :write => false, :admin => false) | |
| 25 | + @project.users_projects.create(:user => @u2, :read => false, :write => false, :admin => false) | |
| 26 | 26 | # readonly |
| 27 | - @project.users_projects.create(:user => @u3, :read => true, :write => false, :admin => false) | |
| 27 | + @project.users_projects.create(:user => @u3, :read => true, :write => false, :admin => false) | |
| 28 | 28 | end |
| 29 | 29 | |
| 30 | - describe "GET /project_code" do | |
| 30 | + describe "GET /project_code" do | |
| 31 | 31 | it { project_path(@project).should be_allowed_for @u1 } |
| 32 | 32 | it { project_path(@project).should be_allowed_for @u3 } |
| 33 | 33 | it { project_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -36,7 +36,7 @@ describe "Projects" do |
| 36 | 36 | it { project_path(@project).should be_denied_for :visitor } |
| 37 | 37 | end |
| 38 | 38 | |
| 39 | - describe "GET /project_code/tree" do | |
| 39 | + describe "GET /project_code/tree" do | |
| 40 | 40 | it { tree_project_path(@project).should be_allowed_for @u1 } |
| 41 | 41 | it { tree_project_path(@project).should be_allowed_for @u3 } |
| 42 | 42 | it { tree_project_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -45,7 +45,7 @@ describe "Projects" do |
| 45 | 45 | it { tree_project_path(@project).should be_denied_for :visitor } |
| 46 | 46 | end |
| 47 | 47 | |
| 48 | - describe "GET /project_code/commits" do | |
| 48 | + describe "GET /project_code/commits" do | |
| 49 | 49 | it { project_commits_path(@project).should be_allowed_for @u1 } |
| 50 | 50 | it { project_commits_path(@project).should be_allowed_for @u3 } |
| 51 | 51 | it { project_commits_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -54,7 +54,7 @@ describe "Projects" do |
| 54 | 54 | it { project_commits_path(@project).should be_denied_for :visitor } |
| 55 | 55 | end |
| 56 | 56 | |
| 57 | - describe "GET /project_code/commit" do | |
| 57 | + describe "GET /project_code/commit" do | |
| 58 | 58 | it { project_commit_path(@project, @project.commit).should be_allowed_for @u1 } |
| 59 | 59 | it { project_commit_path(@project, @project.commit).should be_allowed_for @u3 } |
| 60 | 60 | it { project_commit_path(@project, @project.commit).should be_denied_for :admin } |
| ... | ... | @@ -63,7 +63,7 @@ describe "Projects" do |
| 63 | 63 | it { project_commit_path(@project, @project.commit).should be_denied_for :visitor } |
| 64 | 64 | end |
| 65 | 65 | |
| 66 | - describe "GET /project_code/team" do | |
| 66 | + describe "GET /project_code/team" do | |
| 67 | 67 | it { team_project_path(@project).should be_allowed_for @u1 } |
| 68 | 68 | it { team_project_path(@project).should be_allowed_for @u3 } |
| 69 | 69 | it { team_project_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -72,7 +72,7 @@ describe "Projects" do |
| 72 | 72 | it { team_project_path(@project).should be_denied_for :visitor } |
| 73 | 73 | end |
| 74 | 74 | |
| 75 | - describe "GET /project_code/wall" do | |
| 75 | + describe "GET /project_code/wall" do | |
| 76 | 76 | it { wall_project_path(@project).should be_allowed_for @u1 } |
| 77 | 77 | it { wall_project_path(@project).should be_allowed_for @u3 } |
| 78 | 78 | it { wall_project_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -81,8 +81,8 @@ describe "Projects" do |
| 81 | 81 | it { wall_project_path(@project).should be_denied_for :visitor } |
| 82 | 82 | end |
| 83 | 83 | |
| 84 | - describe "GET /project_code/blob" do | |
| 85 | - before do | |
| 84 | + describe "GET /project_code/blob" do | |
| 85 | + before do | |
| 86 | 86 | @commit = @project.commit |
| 87 | 87 | @path = @commit.tree.contents.select { |i| i.is_a?(Grit::Blob)}.first.name |
| 88 | 88 | @blob_path = blob_project_path(@project, :commit_id => @commit.id, :path => @path) |
| ... | ... | @@ -96,7 +96,7 @@ describe "Projects" do |
| 96 | 96 | it { @blob_path.should be_denied_for :visitor } |
| 97 | 97 | end |
| 98 | 98 | |
| 99 | - describe "GET /project_code/edit" do | |
| 99 | + describe "GET /project_code/edit" do | |
| 100 | 100 | it { edit_project_path(@project).should be_allowed_for @u1 } |
| 101 | 101 | it { edit_project_path(@project).should be_denied_for @u3 } |
| 102 | 102 | it { edit_project_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -105,7 +105,7 @@ describe "Projects" do |
| 105 | 105 | it { edit_project_path(@project).should be_denied_for :visitor } |
| 106 | 106 | end |
| 107 | 107 | |
| 108 | - describe "GET /project_code/issues" do | |
| 108 | + describe "GET /project_code/issues" do | |
| 109 | 109 | it { project_issues_path(@project).should be_allowed_for @u1 } |
| 110 | 110 | it { project_issues_path(@project).should be_allowed_for @u3 } |
| 111 | 111 | it { project_issues_path(@project).should be_denied_for :admin } |
| ... | ... | @@ -114,7 +114,7 @@ describe "Projects" do |
| 114 | 114 | it { project_issues_path(@project).should be_denied_for :visitor } |
| 115 | 115 | end |
| 116 | 116 | |
| 117 | - describe "GET /project_code/snippets" do | |
| 117 | + describe "GET /project_code/snippets" do | |
| 118 | 118 | it { project_snippets_path(@project).should be_allowed_for @u1 } |
| 119 | 119 | it { project_snippets_path(@project).should be_allowed_for @u3 } |
| 120 | 120 | it { project_snippets_path(@project).should be_denied_for :admin } | ... | ... |
spec/requests/projects_spec.rb
| ... | ... | @@ -4,38 +4,38 @@ describe "Projects" do |
| 4 | 4 | before { login_as :user } |
| 5 | 5 | |
| 6 | 6 | describe "GET /projects" do |
| 7 | - before do | |
| 7 | + before do | |
| 8 | 8 | visit projects_path |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | it "should be on projects page" do |
| 12 | - current_path.should == projects_path | |
| 12 | + current_path.should == projects_path | |
| 13 | 13 | end |
| 14 | 14 | |
| 15 | 15 | it "should have link to new project" do |
| 16 | - page.should have_content("New Project") | |
| 16 | + page.should have_content("Create new project") | |
| 17 | 17 | end |
| 18 | 18 | end |
| 19 | 19 | |
| 20 | 20 | describe "GET /projects/new" do |
| 21 | - before do | |
| 21 | + before do | |
| 22 | 22 | visit projects_path |
| 23 | - click_link "New Project" | |
| 23 | + click_link "Create new project" | |
| 24 | 24 | end |
| 25 | 25 | |
| 26 | 26 | it "should be correct path" do |
| 27 | - current_path.should == new_project_path | |
| 27 | + current_path.should == new_project_path | |
| 28 | 28 | end |
| 29 | 29 | |
| 30 | 30 | it "should have labels for new project" do |
| 31 | - page.should have_content("Name") | |
| 32 | - page.should have_content("Path") | |
| 33 | - page.should have_content("Description") | |
| 31 | + page.should have_content("Name") | |
| 32 | + page.should have_content("Path") | |
| 33 | + page.should have_content("Description") | |
| 34 | 34 | end |
| 35 | 35 | end |
| 36 | 36 | |
| 37 | 37 | describe "POST /projects" do |
| 38 | - before do | |
| 38 | + before do | |
| 39 | 39 | visit new_project_path |
| 40 | 40 | fill_in 'Name', :with => 'NewProject' |
| 41 | 41 | fill_in 'Code', :with => 'NPR' |
| ... | ... | @@ -61,7 +61,7 @@ describe "Projects" do |
| 61 | 61 | end |
| 62 | 62 | |
| 63 | 63 | describe "GET /projects/show" do |
| 64 | - before do | |
| 64 | + before do | |
| 65 | 65 | @project = Factory :project |
| 66 | 66 | @project.add_access(@user, :read) |
| 67 | 67 | |
| ... | ... | @@ -72,14 +72,14 @@ describe "Projects" do |
| 72 | 72 | current_path.should == project_path(@project) |
| 73 | 73 | end |
| 74 | 74 | |
| 75 | - it "should beahave like dashboard" do | |
| 75 | + it "should beahave like dashboard" do | |
| 76 | 76 | page.should have_content("History") |
| 77 | 77 | end |
| 78 | 78 | |
| 79 | 79 | end |
| 80 | 80 | |
| 81 | 81 | describe "GET /projects/team" do |
| 82 | - before do | |
| 82 | + before do | |
| 83 | 83 | @project = Factory :project |
| 84 | 84 | @project.add_access(@user, :read) |
| 85 | 85 | |
| ... | ... | @@ -92,13 +92,13 @@ describe "Projects" do |
| 92 | 92 | current_path.should == team_project_path(@project) |
| 93 | 93 | end |
| 94 | 94 | |
| 95 | - it "should have as as team member" do | |
| 95 | + it "should have as as team member" do | |
| 96 | 96 | page.should have_content(@user.name) |
| 97 | 97 | end |
| 98 | 98 | end |
| 99 | 99 | |
| 100 | 100 | describe "GET /projects/:id/edit" do |
| 101 | - before do | |
| 101 | + before do | |
| 102 | 102 | @project = Factory :project |
| 103 | 103 | @project.add_access(@user, :admin, :read) |
| 104 | 104 | |
| ... | ... | @@ -110,14 +110,14 @@ describe "Projects" do |
| 110 | 110 | end |
| 111 | 111 | |
| 112 | 112 | it "should have labels for new project" do |
| 113 | - page.should have_content("Name") | |
| 114 | - page.should have_content("Path") | |
| 115 | - page.should have_content("Description") | |
| 113 | + page.should have_content("Name") | |
| 114 | + page.should have_content("Path") | |
| 115 | + page.should have_content("Description") | |
| 116 | 116 | end |
| 117 | 117 | end |
| 118 | 118 | |
| 119 | 119 | describe "PUT /projects/:id" do |
| 120 | - before do | |
| 120 | + before do | |
| 121 | 121 | @project = Factory :project |
| 122 | 122 | @project.add_access(@user, :admin, :read) |
| 123 | 123 | |
| ... | ... | @@ -140,14 +140,14 @@ describe "Projects" do |
| 140 | 140 | end |
| 141 | 141 | |
| 142 | 142 | #describe "DELETE /projects/:id", :js => true do |
| 143 | - #before do | |
| 143 | + #before do | |
| 144 | 144 | #@project = Factory :project |
| 145 | 145 | #@project.add_access(@user, :read, :admin) |
| 146 | 146 | #visit projects_path |
| 147 | 147 | #end |
| 148 | 148 | |
| 149 | 149 | #it "should be correct path" do |
| 150 | - #expect { click_link "Destroy" }.to change {Project.count}.by(1) | |
| 150 | + #expect { click_link "Destroy" }.to change {Project.count}.by(1) | |
| 151 | 151 | #end |
| 152 | 152 | #end |
| 153 | 153 | end | ... | ... |
spec/requests/projects_tree_perfomance_spec.rb
| ... | ... | @@ -6,13 +6,13 @@ describe "Projects" do |
| 6 | 6 | |
| 7 | 7 | describe "GET /projects/tree" do |
| 8 | 8 | describe "head" do |
| 9 | - before do | |
| 9 | + before do | |
| 10 | 10 | @project = Factory :project |
| 11 | 11 | @project.add_access(@user, :read) |
| 12 | 12 | |
| 13 | 13 | end |
| 14 | 14 | |
| 15 | - it "should be fast" do | |
| 15 | + it "should be fast" do | |
| 16 | 16 | time = Benchmark.realtime do |
| 17 | 17 | visit tree_project_path(@project) |
| 18 | 18 | end |
| ... | ... | @@ -21,12 +21,12 @@ describe "Projects" do |
| 21 | 21 | end |
| 22 | 22 | |
| 23 | 23 | describe ValidCommit::ID do |
| 24 | - before do | |
| 24 | + before do | |
| 25 | 25 | @project = Factory :project |
| 26 | 26 | @project.add_access(@user, :read) |
| 27 | 27 | end |
| 28 | 28 | |
| 29 | - it "should be fast" do | |
| 29 | + it "should be fast" do | |
| 30 | 30 | time = Benchmark.realtime do |
| 31 | 31 | visit tree_project_path(@project, :commit_id => ValidCommit::ID) |
| 32 | 32 | end | ... | ... |
spec/requests/projects_tree_spec.rb
| ... | ... | @@ -5,7 +5,7 @@ describe "Projects" do |
| 5 | 5 | |
| 6 | 6 | describe "GET /projects/tree" do |
| 7 | 7 | describe "head" do |
| 8 | - before do | |
| 8 | + before do | |
| 9 | 9 | @project = Factory :project |
| 10 | 10 | @project.add_access(@user, :read) |
| 11 | 11 | |
| ... | ... | @@ -20,7 +20,7 @@ describe "Projects" do |
| 20 | 20 | end |
| 21 | 21 | |
| 22 | 22 | describe ValidCommit::ID do |
| 23 | - before do | |
| 23 | + before do | |
| 24 | 24 | @project = Factory :project |
| 25 | 25 | @project.add_access(@user, :read) |
| 26 | 26 | |
| ... | ... | @@ -36,7 +36,7 @@ describe "Projects" do |
| 36 | 36 | end |
| 37 | 37 | |
| 38 | 38 | describe "branch passed" do |
| 39 | - before do | |
| 39 | + before do | |
| 40 | 40 | @project = Factory :project |
| 41 | 41 | @project.add_access(@user, :read) |
| 42 | 42 | |
| ... | ... | @@ -53,7 +53,7 @@ describe "Projects" do |
| 53 | 53 | |
| 54 | 54 | # TREE FILE PREVIEW |
| 55 | 55 | describe "file preview" do |
| 56 | - before do | |
| 56 | + before do | |
| 57 | 57 | @project = Factory :project |
| 58 | 58 | @project.add_access(@user, :read) |
| 59 | 59 | |
| ... | ... | @@ -70,9 +70,9 @@ describe "Projects" do |
| 70 | 70 | end |
| 71 | 71 | end |
| 72 | 72 | |
| 73 | - # RAW FILE | |
| 73 | + # RAW FILE | |
| 74 | 74 | describe "GET /projects/blob" do |
| 75 | - before do | |
| 75 | + before do | |
| 76 | 76 | @project = Factory :project |
| 77 | 77 | @project.add_access(@user, :read) |
| 78 | 78 | |
| ... | ... | @@ -85,7 +85,7 @@ describe "Projects" do |
| 85 | 85 | current_path.should == blob_project_path(@project) |
| 86 | 86 | end |
| 87 | 87 | |
| 88 | - it "raw file response" do | |
| 88 | + it "raw file response" do | |
| 89 | 89 | page.source.should == ValidCommit::BLOB_FILE |
| 90 | 90 | end |
| 91 | 91 | end | ... | ... |
spec/requests/projects_wall_spec.rb
| ... | ... | @@ -3,13 +3,13 @@ require 'spec_helper' |
| 3 | 3 | describe "Projects", "Wall" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | |
| 6 | - before do | |
| 6 | + before do | |
| 7 | 7 | login_as :user |
| 8 | 8 | project.add_access(@user, :read, :write) |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | describe "View notes on wall" do |
| 12 | - before do | |
| 12 | + before do | |
| 13 | 13 | Factory :note, :project => project, :note => "Project specs", :author => @user |
| 14 | 14 | visit wall_project_path(project) |
| 15 | 15 | end |
| ... | ... | @@ -19,8 +19,8 @@ describe "Projects", "Wall" do |
| 19 | 19 | it { page.should have_content("less than a minute ago") } |
| 20 | 20 | end |
| 21 | 21 | |
| 22 | - describe "add new note", :js => true do | |
| 23 | - before do | |
| 22 | + describe "add new note", :js => true do | |
| 23 | + before do | |
| 24 | 24 | visit wall_project_path(project) |
| 25 | 25 | fill_in "note_note", :with => "my post on wall" |
| 26 | 26 | click_button "Add note" | ... | ... |
spec/requests/snippets_spec.rb
| ... | ... | @@ -3,13 +3,13 @@ require 'spec_helper' |
| 3 | 3 | describe "Snippets" do |
| 4 | 4 | let(:project) { Factory :project } |
| 5 | 5 | |
| 6 | - before do | |
| 6 | + before do | |
| 7 | 7 | login_as :user |
| 8 | 8 | project.add_access(@user, :read, :write) |
| 9 | 9 | end |
| 10 | 10 | |
| 11 | 11 | describe "GET /snippets" do |
| 12 | - before do | |
| 12 | + before do | |
| 13 | 13 | @snippet = Factory :snippet, |
| 14 | 14 | :author => @user, |
| 15 | 15 | :project => project |
| ... | ... | @@ -23,15 +23,23 @@ describe "Snippets" do |
| 23 | 23 | it { should have_content(@snippet.project.name) } |
| 24 | 24 | it { should have_content(@snippet.author.name) } |
| 25 | 25 | |
| 26 | - describe "Destroy" do | |
| 27 | - before do | |
| 26 | + it "doesn't show expired snippets" do | |
| 27 | + @snippet.update_attribute(:expires_at, 1.day.ago.to_time) | |
| 28 | + visit project_snippet_path(project, @snippet) | |
| 29 | + page.should have_content("Sorry, this snippet is no longer exists") | |
| 30 | + page.should_not have_content(@snippet.title) | |
| 31 | + page.should_not have_content(@snippet.content) | |
| 32 | + end | |
| 33 | + | |
| 34 | + describe "Destroy" do | |
| 35 | + before do | |
| 28 | 36 | # admin access to remove snippet |
| 29 | 37 | @user.users_projects.destroy_all |
| 30 | 38 | project.add_access(@user, :read, :write, :admin) |
| 31 | 39 | visit project_snippets_path(project) |
| 32 | 40 | end |
| 33 | 41 | |
| 34 | - it "should remove entry" do | |
| 42 | + it "should remove entry" do | |
| 35 | 43 | expect { |
| 36 | 44 | click_link "destroy_snippet_#{@snippet.id}" |
| 37 | 45 | }.to change { Snippet.count }.by(-1) |
| ... | ... | @@ -39,17 +47,17 @@ describe "Snippets" do |
| 39 | 47 | end |
| 40 | 48 | end |
| 41 | 49 | |
| 42 | - describe "New snippet" do | |
| 43 | - before do | |
| 50 | + describe "New snippet" do | |
| 51 | + before do | |
| 44 | 52 | visit project_snippets_path(project) |
| 45 | 53 | click_link "New Snippet" |
| 46 | 54 | end |
| 47 | 55 | |
| 48 | - it "should open new snippet popup" do | |
| 56 | + it "should open new snippet popup" do | |
| 49 | 57 | page.current_path.should == new_project_snippet_path(project) |
| 50 | 58 | end |
| 51 | 59 | |
| 52 | - describe "fill in" do | |
| 60 | + describe "fill in" do | |
| 53 | 61 | before do |
| 54 | 62 | fill_in "snippet_title", :with => "login function" |
| 55 | 63 | fill_in "snippet_file_name", :with => "test.rb" |
| ... | ... | @@ -58,7 +66,7 @@ describe "Snippets" do |
| 58 | 66 | |
| 59 | 67 | it { expect { click_button "Save" }.to change {Snippet.count}.by(1) } |
| 60 | 68 | |
| 61 | - it "should add new snippet to table" do | |
| 69 | + it "should add new snippet to table" do | |
| 62 | 70 | click_button "Save" |
| 63 | 71 | page.current_path.should == project_snippet_path(project, Snippet.last) |
| 64 | 72 | page.should have_content "login function" |
| ... | ... | @@ -67,8 +75,8 @@ describe "Snippets" do |
| 67 | 75 | end |
| 68 | 76 | end |
| 69 | 77 | |
| 70 | - describe "Edit snippet" do | |
| 71 | - before do | |
| 78 | + describe "Edit snippet" do | |
| 79 | + before do | |
| 72 | 80 | @snippet = Factory :snippet, |
| 73 | 81 | :author => @user, |
| 74 | 82 | :project => project |
| ... | ... | @@ -76,11 +84,11 @@ describe "Snippets" do |
| 76 | 84 | click_link "Edit" |
| 77 | 85 | end |
| 78 | 86 | |
| 79 | - it "should open edit page" do | |
| 87 | + it "should open edit page" do | |
| 80 | 88 | page.current_path.should == edit_project_snippet_path(project, @snippet) |
| 81 | 89 | end |
| 82 | 90 | |
| 83 | - describe "fill in" do | |
| 91 | + describe "fill in" do | |
| 84 | 92 | before do |
| 85 | 93 | fill_in "snippet_title", :with => "login function" |
| 86 | 94 | fill_in "snippet_file_name", :with => "test.rb" |
| ... | ... | @@ -89,7 +97,7 @@ describe "Snippets" do |
| 89 | 97 | |
| 90 | 98 | it { expect { click_button "Save" }.to_not change {Snippet.count} } |
| 91 | 99 | |
| 92 | - it "should update snippet fields" do | |
| 100 | + it "should update snippet fields" do | |
| 93 | 101 | click_button "Save" |
| 94 | 102 | |
| 95 | 103 | page.current_path.should == project_snippet_path(project, @snippet) | ... | ... |
| ... | ... | @@ -0,0 +1,31 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe "Tags" do | |
| 4 | + before { login_as :user } | |
| 5 | + | |
| 6 | + # describe "GET 'tags/index'" do | |
| 7 | + # it "should be successful" do | |
| 8 | + # get 'tags/index' | |
| 9 | + # response.should be_success | |
| 10 | + # end | |
| 11 | + # end | |
| 12 | + | |
| 13 | + | |
| 14 | + describe "GET '/tags.json'" do | |
| 15 | + before do | |
| 16 | + @project = Factory :project | |
| 17 | + @project.add_access(@user, :read) | |
| 18 | + @project.tag_list = 'demo1' | |
| 19 | + @project.save | |
| 20 | + visit '/tags.json' | |
| 21 | + end | |
| 22 | + | |
| 23 | + | |
| 24 | + it "should contains tags" do | |
| 25 | + page.should have_content('demo1') | |
| 26 | + end | |
| 27 | +end | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | +end | ... | ... |
spec/requests/team_members_spec.rb
| 1 | 1 | require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "TeamMembers" do |
| 4 | - before do | |
| 4 | + before do | |
| 5 | 5 | login_as :user |
| 6 | 6 | @project = Factory :project |
| 7 | 7 | @project.add_access(@user, :read, :admin) |
| ... | ... | @@ -10,7 +10,7 @@ describe "TeamMembers" do |
| 10 | 10 | describe "View profile" do |
| 11 | 11 | it "should be available" do |
| 12 | 12 | visit(team_project_path(@project)) |
| 13 | - within "#team-table" do | |
| 13 | + within "#team-table" do | |
| 14 | 14 | click_link(@user.name) |
| 15 | 15 | end |
| 16 | 16 | page.should have_content @user.skype |
| ... | ... | @@ -18,23 +18,23 @@ describe "TeamMembers" do |
| 18 | 18 | end |
| 19 | 19 | end |
| 20 | 20 | |
| 21 | - describe "New Team member", :js => true do | |
| 22 | - before do | |
| 21 | + describe "New Team member", :js => true do | |
| 22 | + before do | |
| 23 | 23 | @user_1 = Factory :user |
| 24 | 24 | visit team_project_path(@project) |
| 25 | 25 | click_link "Add new" |
| 26 | 26 | end |
| 27 | 27 | |
| 28 | - it "should open new team member popup" do | |
| 28 | + it "should open new team member popup" do | |
| 29 | 29 | page.should have_content("Add new member to project") |
| 30 | 30 | end |
| 31 | 31 | |
| 32 | - describe "fill in" do | |
| 32 | + describe "fill in" do | |
| 33 | 33 | before do |
| 34 | 34 | click_link "Select user" |
| 35 | 35 | click_link @user_1.name |
| 36 | 36 | |
| 37 | - within "#team_member_new" do | |
| 37 | + within "#team_member_new" do | |
| 38 | 38 | check "team_member_read" |
| 39 | 39 | check "team_member_write" |
| 40 | 40 | end |
| ... | ... | @@ -42,7 +42,7 @@ describe "TeamMembers" do |
| 42 | 42 | |
| 43 | 43 | it { expect { click_button "Save";sleep(1) }.to change {UsersProject.count}.by(1) } |
| 44 | 44 | |
| 45 | - it "should add new member to table" do | |
| 45 | + it "should add new member to table" do | |
| 46 | 46 | click_button "Save" |
| 47 | 47 | @member = UsersProject.last |
| 48 | 48 | |
| ... | ... | @@ -53,8 +53,8 @@ describe "TeamMembers" do |
| 53 | 53 | @member.admin.should be_false |
| 54 | 54 | end |
| 55 | 55 | |
| 56 | - it "should not allow creation without access selected" do | |
| 57 | - within "#team_member_new" do | |
| 56 | + it "should not allow creation without access selected" do | |
| 57 | + within "#team_member_new" do | |
| 58 | 58 | uncheck "team_member_read" |
| 59 | 59 | uncheck "team_member_write" |
| 60 | 60 | uncheck "team_member_admin" |
| ... | ... | @@ -66,8 +66,8 @@ describe "TeamMembers" do |
| 66 | 66 | end |
| 67 | 67 | end |
| 68 | 68 | |
| 69 | - describe "Cancel membership" do | |
| 70 | - it "should cancel membership" do | |
| 69 | + describe "Cancel membership" do | |
| 70 | + it "should cancel membership" do | |
| 71 | 71 | visit team_project_path(@project) |
| 72 | 72 | expect { click_link "Cancel" }.to change { UsersProject.count }.by(-1) |
| 73 | 73 | end | ... | ... |
spec/requests/top_panel_spec.rb
| ... | ... | @@ -4,7 +4,7 @@ describe "Top Panel", :js => true do |
| 4 | 4 | before { login_as :user } |
| 5 | 5 | |
| 6 | 6 | describe "Search autocomplete" do |
| 7 | - before do | |
| 7 | + before do | |
| 8 | 8 | visit projects_path |
| 9 | 9 | fill_in "search", :with => "Ke" |
| 10 | 10 | sleep(2) |
| ... | ... | @@ -12,12 +12,12 @@ describe "Top Panel", :js => true do |
| 12 | 12 | end |
| 13 | 13 | |
| 14 | 14 | it "should be on projects page" do |
| 15 | - current_path.should == keys_path | |
| 15 | + current_path.should == keys_path | |
| 16 | 16 | end |
| 17 | 17 | end |
| 18 | 18 | |
| 19 | 19 | describe "with project" do |
| 20 | - before do | |
| 20 | + before do | |
| 21 | 21 | @project = Factory :project |
| 22 | 22 | @project.add_access(@user, :read) |
| 23 | 23 | visit project_path(@project) |
| ... | ... | @@ -28,7 +28,7 @@ describe "Top Panel", :js => true do |
| 28 | 28 | end |
| 29 | 29 | |
| 30 | 30 | it "should be on projects page" do |
| 31 | - current_path.should == project_commits_path(@project) | |
| 31 | + current_path.should == project_commits_path(@project) | |
| 32 | 32 | end |
| 33 | 33 | end |
| 34 | 34 | end | ... | ... |
spec/requests/user_security_spec.rb
| ... | ... | @@ -2,32 +2,32 @@ require 'spec_helper' |
| 2 | 2 | |
| 3 | 3 | describe "Users Security" do |
| 4 | 4 | describe "Project" do |
| 5 | - before do | |
| 5 | + before do | |
| 6 | 6 | @u1 = Factory :user |
| 7 | 7 | end |
| 8 | 8 | |
| 9 | - describe "GET /login" do | |
| 9 | + describe "GET /login" do | |
| 10 | 10 | #it { new_user_session_path.should be_denied_for @u1 } |
| 11 | 11 | #it { new_user_session_path.should be_denied_for :admin } |
| 12 | 12 | #it { new_user_session_path.should be_denied_for :user } |
| 13 | 13 | it { new_user_session_path.should_not be_404_for :visitor } |
| 14 | 14 | end |
| 15 | 15 | |
| 16 | - describe "GET /keys" do | |
| 16 | + describe "GET /keys" do | |
| 17 | 17 | it { keys_path.should be_allowed_for @u1 } |
| 18 | 18 | it { keys_path.should be_allowed_for :admin } |
| 19 | 19 | it { keys_path.should be_allowed_for :user } |
| 20 | 20 | it { keys_path.should be_denied_for :visitor } |
| 21 | 21 | end |
| 22 | 22 | |
| 23 | - describe "GET /profile" do | |
| 23 | + describe "GET /profile" do | |
| 24 | 24 | it { profile_path.should be_allowed_for @u1 } |
| 25 | 25 | it { profile_path.should be_allowed_for :admin } |
| 26 | 26 | it { profile_path.should be_allowed_for :user } |
| 27 | 27 | it { profile_path.should be_denied_for :visitor } |
| 28 | 28 | end |
| 29 | 29 | |
| 30 | - describe "GET /profile/password" do | |
| 30 | + describe "GET /profile/password" do | |
| 31 | 31 | it { profile_password_path.should be_allowed_for @u1 } |
| 32 | 32 | it { profile_password_path.should be_allowed_for :admin } |
| 33 | 33 | it { profile_password_path.should be_allowed_for :user } | ... | ... |
spec/spec_helper.rb
| ... | ... | @@ -11,7 +11,6 @@ require 'capybara/dsl' |
| 11 | 11 | require 'factories' |
| 12 | 12 | require 'monkeypatch' |
| 13 | 13 | |
| 14 | - | |
| 15 | 14 | # Requires supporting ruby files with custom matchers and macros, etc, |
| 16 | 15 | # in spec/support/ and its subdirectories. |
| 17 | 16 | Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f} | ... | ... |
spec/support/login.rb
| 1 | 1 | module LoginMacros |
| 2 | 2 | def login_as role |
| 3 | - @user = User.create(:email => "user#{User.count}@mail.com", | |
| 3 | + @user = User.create(:email => "user#{User.count}@mail.com", | |
| 4 | 4 | :name => "John Smith", |
| 5 | 5 | :password => "123456", |
| 6 | 6 | :password_confirmation => "123456", |
| 7 | 7 | :skype => 'user_skype') |
| 8 | - | |
| 9 | - if role == :admin | |
| 8 | + | |
| 9 | + if role == :admin | |
| 10 | 10 | @user.admin = true |
| 11 | 11 | @user.save! |
| 12 | 12 | end |
| 13 | 13 | |
| 14 | 14 | visit new_user_session_path |
| 15 | - fill_in "Email", :with => @user.email | |
| 16 | - fill_in "Password", :with => "123456" | |
| 15 | + fill_in "user_email", :with => @user.email | |
| 16 | + fill_in "user_password", :with => "123456" | |
| 17 | 17 | click_button "Sign in" |
| 18 | 18 | end |
| 19 | 19 | |
| 20 | 20 | def login_with(user) |
| 21 | 21 | visit new_user_session_path |
| 22 | - fill_in "Email", :with => user.email | |
| 23 | - fill_in "Password", :with => "123456" | |
| 22 | + fill_in "user_email", :with => user.email | |
| 23 | + fill_in "user_password", :with => "123456" | |
| 24 | 24 | click_button "Sign in" |
| 25 | 25 | end |
| 26 | - | |
| 26 | + | |
| 27 | 27 | def logout |
| 28 | 28 | click_link "Logout" rescue nil |
| 29 | 29 | end | ... | ... |
spec/support/matchers.rb
| ... | ... | @@ -18,17 +18,17 @@ RSpec::Matchers.define :be_denied_for do |user| |
| 18 | 18 | match do |url| |
| 19 | 19 | include UrlAccess |
| 20 | 20 | url_denied?(user, url) |
| 21 | - end | |
| 21 | + end | |
| 22 | 22 | end |
| 23 | 23 | |
| 24 | 24 | RSpec::Matchers.define :be_404_for do |user| |
| 25 | 25 | match do |url| |
| 26 | 26 | include UrlAccess |
| 27 | 27 | url_404?(user, url) |
| 28 | - end | |
| 28 | + end | |
| 29 | 29 | end |
| 30 | 30 | |
| 31 | -module UrlAccess | |
| 31 | +module UrlAccess | |
| 32 | 32 | def url_allowed?(user, url) |
| 33 | 33 | emulate_user(user) |
| 34 | 34 | visit url | ... | ... |
spec/support/shared_examples.rb
| ... | ... | @@ -6,13 +6,12 @@ shared_examples_for :project_side_pane do |
| 6 | 6 | it { should have_content("Tree") } |
| 7 | 7 | end |
| 8 | 8 | |
| 9 | - | |
| 10 | 9 | shared_examples_for :tree_view do |
| 11 | 10 | subject { page } |
| 12 | 11 | |
| 13 | 12 | it "should have Tree View of project" do |
| 14 | - should have_content("app") | |
| 15 | - should have_content("history") | |
| 16 | - should have_content("Gemfile") | |
| 13 | + should have_content("app") | |
| 14 | + should have_content("history") | |
| 15 | + should have_content("Gemfile") | |
| 17 | 16 | end |
| 18 | 17 | end | ... | ... |
180 Bytes
178 Bytes
120 Bytes
105 Bytes
111 Bytes
110 Bytes
119 Bytes
vendor/assets/images/jquery-ui/ui-bg_highlight-soft_75_cccccc_1x100.png
0 → 100644
101 Bytes
4.27 KB
5.23 KB
4.27 KB
4.27 KB
4.27 KB
| ... | ... | @@ -0,0 +1,791 @@ |
| 1 | +/*! | |
| 2 | + * jQuery UI 1.8.16 | |
| 3 | + * | |
| 4 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 5 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 6 | + * http://jquery.org/license | |
| 7 | + * | |
| 8 | + * http://docs.jquery.com/UI | |
| 9 | + */ | |
| 10 | +(function(c,j){function k(a,b){var d=a.nodeName.toLowerCase();if("area"===d){b=a.parentNode;d=b.name;if(!a.href||!d||b.nodeName.toLowerCase()!=="map")return false;a=c("img[usemap=#"+d+"]")[0];return!!a&&l(a)}return(/input|select|textarea|button|object/.test(d)?!a.disabled:"a"==d?a.href||b:b)&&l(a)}function l(a){return!c(a).parents().andSelf().filter(function(){return c.curCSS(this,"visibility")==="hidden"||c.expr.filters.hidden(this)}).length}c.ui=c.ui||{};if(!c.ui.version){c.extend(c.ui,{version:"1.8.16", | |
| 11 | +keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}});c.fn.extend({propAttr:c.fn.prop||c.fn.attr,_focus:c.fn.focus,focus:function(a,b){return typeof a==="number"?this.each(function(){var d= | |
| 12 | +this;setTimeout(function(){c(d).focus();b&&b.call(d)},a)}):this._focus.apply(this,arguments)},scrollParent:function(){var a;a=c.browser.msie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?this.parents().filter(function(){return/(relative|absolute|fixed)/.test(c.curCSS(this,"position",1))&&/(auto|scroll)/.test(c.curCSS(this,"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0):this.parents().filter(function(){return/(auto|scroll)/.test(c.curCSS(this, | |
| 13 | +"overflow",1)+c.curCSS(this,"overflow-y",1)+c.curCSS(this,"overflow-x",1))}).eq(0);return/fixed/.test(this.css("position"))||!a.length?c(document):a},zIndex:function(a){if(a!==j)return this.css("zIndex",a);if(this.length){a=c(this[0]);for(var b;a.length&&a[0]!==document;){b=a.css("position");if(b==="absolute"||b==="relative"||b==="fixed"){b=parseInt(a.css("zIndex"),10);if(!isNaN(b)&&b!==0)return b}a=a.parent()}}return 0},disableSelection:function(){return this.bind((c.support.selectstart?"selectstart": | |
| 14 | +"mousedown")+".ui-disableSelection",function(a){a.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}});c.each(["Width","Height"],function(a,b){function d(f,g,m,n){c.each(e,function(){g-=parseFloat(c.curCSS(f,"padding"+this,true))||0;if(m)g-=parseFloat(c.curCSS(f,"border"+this+"Width",true))||0;if(n)g-=parseFloat(c.curCSS(f,"margin"+this,true))||0});return g}var e=b==="Width"?["Left","Right"]:["Top","Bottom"],h=b.toLowerCase(),i={innerWidth:c.fn.innerWidth,innerHeight:c.fn.innerHeight, | |
| 15 | +outerWidth:c.fn.outerWidth,outerHeight:c.fn.outerHeight};c.fn["inner"+b]=function(f){if(f===j)return i["inner"+b].call(this);return this.each(function(){c(this).css(h,d(this,f)+"px")})};c.fn["outer"+b]=function(f,g){if(typeof f!=="number")return i["outer"+b].call(this,f);return this.each(function(){c(this).css(h,d(this,f,true,g)+"px")})}});c.extend(c.expr[":"],{data:function(a,b,d){return!!c.data(a,d[3])},focusable:function(a){return k(a,!isNaN(c.attr(a,"tabindex")))},tabbable:function(a){var b=c.attr(a, | |
| 16 | +"tabindex"),d=isNaN(b);return(d||b>=0)&&k(a,!d)}});c(function(){var a=document.body,b=a.appendChild(b=document.createElement("div"));c.extend(b.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0});c.support.minHeight=b.offsetHeight===100;c.support.selectstart="onselectstart"in b;a.removeChild(b).style.display="none"});c.extend(c.ui,{plugin:{add:function(a,b,d){a=c.ui[a].prototype;for(var e in d){a.plugins[e]=a.plugins[e]||[];a.plugins[e].push([b,d[e]])}},call:function(a,b,d){if((b=a.plugins[b])&& | |
| 17 | +a.element[0].parentNode)for(var e=0;e<b.length;e++)a.options[b[e][0]]&&b[e][1].apply(a.element,d)}},contains:function(a,b){return document.compareDocumentPosition?a.compareDocumentPosition(b)&16:a!==b&&a.contains(b)},hasScroll:function(a,b){if(c(a).css("overflow")==="hidden")return false;b=b&&b==="left"?"scrollLeft":"scrollTop";var d=false;if(a[b]>0)return true;a[b]=1;d=a[b]>0;a[b]=0;return d},isOverAxis:function(a,b,d){return a>b&&a<b+d},isOver:function(a,b,d,e,h,i){return c.ui.isOverAxis(a,d,h)&& | |
| 18 | +c.ui.isOverAxis(b,e,i)}})}})(jQuery); | |
| 19 | +;/*! | |
| 20 | + * jQuery UI Widget 1.8.16 | |
| 21 | + * | |
| 22 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 23 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 24 | + * http://jquery.org/license | |
| 25 | + * | |
| 26 | + * http://docs.jquery.com/UI/Widget | |
| 27 | + */ | |
| 28 | +(function(b,j){if(b.cleanData){var k=b.cleanData;b.cleanData=function(a){for(var c=0,d;(d=a[c])!=null;c++)try{b(d).triggerHandler("remove")}catch(e){}k(a)}}else{var l=b.fn.remove;b.fn.remove=function(a,c){return this.each(function(){if(!c)if(!a||b.filter(a,[this]).length)b("*",this).add([this]).each(function(){try{b(this).triggerHandler("remove")}catch(d){}});return l.call(b(this),a,c)})}}b.widget=function(a,c,d){var e=a.split(".")[0],f;a=a.split(".")[1];f=e+"-"+a;if(!d){d=c;c=b.Widget}b.expr[":"][f]= | |
| 29 | +function(h){return!!b.data(h,a)};b[e]=b[e]||{};b[e][a]=function(h,g){arguments.length&&this._createWidget(h,g)};c=new c;c.options=b.extend(true,{},c.options);b[e][a].prototype=b.extend(true,c,{namespace:e,widgetName:a,widgetEventPrefix:b[e][a].prototype.widgetEventPrefix||a,widgetBaseClass:f},d);b.widget.bridge(a,b[e][a])};b.widget.bridge=function(a,c){b.fn[a]=function(d){var e=typeof d==="string",f=Array.prototype.slice.call(arguments,1),h=this;d=!e&&f.length?b.extend.apply(null,[true,d].concat(f)): | |
| 30 | +d;if(e&&d.charAt(0)==="_")return h;e?this.each(function(){var g=b.data(this,a),i=g&&b.isFunction(g[d])?g[d].apply(g,f):g;if(i!==g&&i!==j){h=i;return false}}):this.each(function(){var g=b.data(this,a);g?g.option(d||{})._init():b.data(this,a,new c(d,this))});return h}};b.Widget=function(a,c){arguments.length&&this._createWidget(a,c)};b.Widget.prototype={widgetName:"widget",widgetEventPrefix:"",options:{disabled:false},_createWidget:function(a,c){b.data(c,this.widgetName,this);this.element=b(c);this.options= | |
| 31 | +b.extend(true,{},this.options,this._getCreateOptions(),a);var d=this;this.element.bind("remove."+this.widgetName,function(){d.destroy()});this._create();this._trigger("create");this._init()},_getCreateOptions:function(){return b.metadata&&b.metadata.get(this.element[0])[this.widgetName]},_create:function(){},_init:function(){},destroy:function(){this.element.unbind("."+this.widgetName).removeData(this.widgetName);this.widget().unbind("."+this.widgetName).removeAttr("aria-disabled").removeClass(this.widgetBaseClass+ | |
| 32 | +"-disabled ui-state-disabled")},widget:function(){return this.element},option:function(a,c){var d=a;if(arguments.length===0)return b.extend({},this.options);if(typeof a==="string"){if(c===j)return this.options[a];d={};d[a]=c}this._setOptions(d);return this},_setOptions:function(a){var c=this;b.each(a,function(d,e){c._setOption(d,e)});return this},_setOption:function(a,c){this.options[a]=c;if(a==="disabled")this.widget()[c?"addClass":"removeClass"](this.widgetBaseClass+"-disabled ui-state-disabled").attr("aria-disabled", | |
| 33 | +c);return this},enable:function(){return this._setOption("disabled",false)},disable:function(){return this._setOption("disabled",true)},_trigger:function(a,c,d){var e=this.options[a];c=b.Event(c);c.type=(a===this.widgetEventPrefix?a:this.widgetEventPrefix+a).toLowerCase();d=d||{};if(c.originalEvent){a=b.event.props.length;for(var f;a;){f=b.event.props[--a];c[f]=c.originalEvent[f]}}this.element.trigger(c,d);return!(b.isFunction(e)&&e.call(this.element[0],c,d)===false||c.isDefaultPrevented())}}})(jQuery); | |
| 34 | +;/*! | |
| 35 | + * jQuery UI Mouse 1.8.16 | |
| 36 | + * | |
| 37 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 38 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 39 | + * http://jquery.org/license | |
| 40 | + * | |
| 41 | + * http://docs.jquery.com/UI/Mouse | |
| 42 | + * | |
| 43 | + * Depends: | |
| 44 | + * jquery.ui.widget.js | |
| 45 | + */ | |
| 46 | +(function(b){var d=false;b(document).mouseup(function(){d=false});b.widget("ui.mouse",{options:{cancel:":input,option",distance:1,delay:0},_mouseInit:function(){var a=this;this.element.bind("mousedown."+this.widgetName,function(c){return a._mouseDown(c)}).bind("click."+this.widgetName,function(c){if(true===b.data(c.target,a.widgetName+".preventClickEvent")){b.removeData(c.target,a.widgetName+".preventClickEvent");c.stopImmediatePropagation();return false}});this.started=false},_mouseDestroy:function(){this.element.unbind("."+ | |
| 47 | +this.widgetName)},_mouseDown:function(a){if(!d){this._mouseStarted&&this._mouseUp(a);this._mouseDownEvent=a;var c=this,f=a.which==1,g=typeof this.options.cancel=="string"&&a.target.nodeName?b(a.target).closest(this.options.cancel).length:false;if(!f||g||!this._mouseCapture(a))return true;this.mouseDelayMet=!this.options.delay;if(!this.mouseDelayMet)this._mouseDelayTimer=setTimeout(function(){c.mouseDelayMet=true},this.options.delay);if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a)){this._mouseStarted= | |
| 48 | +this._mouseStart(a)!==false;if(!this._mouseStarted){a.preventDefault();return true}}true===b.data(a.target,this.widgetName+".preventClickEvent")&&b.removeData(a.target,this.widgetName+".preventClickEvent");this._mouseMoveDelegate=function(e){return c._mouseMove(e)};this._mouseUpDelegate=function(e){return c._mouseUp(e)};b(document).bind("mousemove."+this.widgetName,this._mouseMoveDelegate).bind("mouseup."+this.widgetName,this._mouseUpDelegate);a.preventDefault();return d=true}},_mouseMove:function(a){if(b.browser.msie&& | |
| 49 | +!(document.documentMode>=9)&&!a.button)return this._mouseUp(a);if(this._mouseStarted){this._mouseDrag(a);return a.preventDefault()}if(this._mouseDistanceMet(a)&&this._mouseDelayMet(a))(this._mouseStarted=this._mouseStart(this._mouseDownEvent,a)!==false)?this._mouseDrag(a):this._mouseUp(a);return!this._mouseStarted},_mouseUp:function(a){b(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate);if(this._mouseStarted){this._mouseStarted= | |
| 50 | +false;a.target==this._mouseDownEvent.target&&b.data(a.target,this.widgetName+".preventClickEvent",true);this._mouseStop(a)}return false},_mouseDistanceMet:function(a){return Math.max(Math.abs(this._mouseDownEvent.pageX-a.pageX),Math.abs(this._mouseDownEvent.pageY-a.pageY))>=this.options.distance},_mouseDelayMet:function(){return this.mouseDelayMet},_mouseStart:function(){},_mouseDrag:function(){},_mouseStop:function(){},_mouseCapture:function(){return true}})})(jQuery); | |
| 51 | +;/* | |
| 52 | + * jQuery UI Position 1.8.16 | |
| 53 | + * | |
| 54 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 55 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 56 | + * http://jquery.org/license | |
| 57 | + * | |
| 58 | + * http://docs.jquery.com/UI/Position | |
| 59 | + */ | |
| 60 | +(function(c){c.ui=c.ui||{};var n=/left|center|right/,o=/top|center|bottom/,t=c.fn.position,u=c.fn.offset;c.fn.position=function(b){if(!b||!b.of)return t.apply(this,arguments);b=c.extend({},b);var a=c(b.of),d=a[0],g=(b.collision||"flip").split(" "),e=b.offset?b.offset.split(" "):[0,0],h,k,j;if(d.nodeType===9){h=a.width();k=a.height();j={top:0,left:0}}else if(d.setTimeout){h=a.width();k=a.height();j={top:a.scrollTop(),left:a.scrollLeft()}}else if(d.preventDefault){b.at="left top";h=k=0;j={top:b.of.pageY, | |
| 61 | +left:b.of.pageX}}else{h=a.outerWidth();k=a.outerHeight();j=a.offset()}c.each(["my","at"],function(){var f=(b[this]||"").split(" ");if(f.length===1)f=n.test(f[0])?f.concat(["center"]):o.test(f[0])?["center"].concat(f):["center","center"];f[0]=n.test(f[0])?f[0]:"center";f[1]=o.test(f[1])?f[1]:"center";b[this]=f});if(g.length===1)g[1]=g[0];e[0]=parseInt(e[0],10)||0;if(e.length===1)e[1]=e[0];e[1]=parseInt(e[1],10)||0;if(b.at[0]==="right")j.left+=h;else if(b.at[0]==="center")j.left+=h/2;if(b.at[1]==="bottom")j.top+= | |
| 62 | +k;else if(b.at[1]==="center")j.top+=k/2;j.left+=e[0];j.top+=e[1];return this.each(function(){var f=c(this),l=f.outerWidth(),m=f.outerHeight(),p=parseInt(c.curCSS(this,"marginLeft",true))||0,q=parseInt(c.curCSS(this,"marginTop",true))||0,v=l+p+(parseInt(c.curCSS(this,"marginRight",true))||0),w=m+q+(parseInt(c.curCSS(this,"marginBottom",true))||0),i=c.extend({},j),r;if(b.my[0]==="right")i.left-=l;else if(b.my[0]==="center")i.left-=l/2;if(b.my[1]==="bottom")i.top-=m;else if(b.my[1]==="center")i.top-= | |
| 63 | +m/2;i.left=Math.round(i.left);i.top=Math.round(i.top);r={left:i.left-p,top:i.top-q};c.each(["left","top"],function(s,x){c.ui.position[g[s]]&&c.ui.position[g[s]][x](i,{targetWidth:h,targetHeight:k,elemWidth:l,elemHeight:m,collisionPosition:r,collisionWidth:v,collisionHeight:w,offset:e,my:b.my,at:b.at})});c.fn.bgiframe&&f.bgiframe();f.offset(c.extend(i,{using:b.using}))})};c.ui.position={fit:{left:function(b,a){var d=c(window);d=a.collisionPosition.left+a.collisionWidth-d.width()-d.scrollLeft();b.left= | |
| 64 | +d>0?b.left-d:Math.max(b.left-a.collisionPosition.left,b.left)},top:function(b,a){var d=c(window);d=a.collisionPosition.top+a.collisionHeight-d.height()-d.scrollTop();b.top=d>0?b.top-d:Math.max(b.top-a.collisionPosition.top,b.top)}},flip:{left:function(b,a){if(a.at[0]!=="center"){var d=c(window);d=a.collisionPosition.left+a.collisionWidth-d.width()-d.scrollLeft();var g=a.my[0]==="left"?-a.elemWidth:a.my[0]==="right"?a.elemWidth:0,e=a.at[0]==="left"?a.targetWidth:-a.targetWidth,h=-2*a.offset[0];b.left+= | |
| 65 | +a.collisionPosition.left<0?g+e+h:d>0?g+e+h:0}},top:function(b,a){if(a.at[1]!=="center"){var d=c(window);d=a.collisionPosition.top+a.collisionHeight-d.height()-d.scrollTop();var g=a.my[1]==="top"?-a.elemHeight:a.my[1]==="bottom"?a.elemHeight:0,e=a.at[1]==="top"?a.targetHeight:-a.targetHeight,h=-2*a.offset[1];b.top+=a.collisionPosition.top<0?g+e+h:d>0?g+e+h:0}}}};if(!c.offset.setOffset){c.offset.setOffset=function(b,a){if(/static/.test(c.curCSS(b,"position")))b.style.position="relative";var d=c(b), | |
| 66 | +g=d.offset(),e=parseInt(c.curCSS(b,"top",true),10)||0,h=parseInt(c.curCSS(b,"left",true),10)||0;g={top:a.top-g.top+e,left:a.left-g.left+h};"using"in a?a.using.call(b,g):d.css(g)};c.fn.offset=function(b){var a=this[0];if(!a||!a.ownerDocument)return null;if(b)return this.each(function(){c.offset.setOffset(this,b)});return u.call(this)}}})(jQuery); | |
| 67 | +;/* | |
| 68 | + * jQuery UI Draggable 1.8.16 | |
| 69 | + * | |
| 70 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 71 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 72 | + * http://jquery.org/license | |
| 73 | + * | |
| 74 | + * http://docs.jquery.com/UI/Draggables | |
| 75 | + * | |
| 76 | + * Depends: | |
| 77 | + * jquery.ui.core.js | |
| 78 | + * jquery.ui.mouse.js | |
| 79 | + * jquery.ui.widget.js | |
| 80 | + */ | |
| 81 | +(function(d){d.widget("ui.draggable",d.ui.mouse,{widgetEventPrefix:"drag",options:{addClasses:true,appendTo:"parent",axis:false,connectToSortable:false,containment:false,cursor:"auto",cursorAt:false,grid:false,handle:false,helper:"original",iframeFix:false,opacity:false,refreshPositions:false,revert:false,revertDuration:500,scope:"default",scroll:true,scrollSensitivity:20,scrollSpeed:20,snap:false,snapMode:"both",snapTolerance:20,stack:false,zIndex:false},_create:function(){if(this.options.helper== | |
| 82 | +"original"&&!/^(?:r|a|f)/.test(this.element.css("position")))this.element[0].style.position="relative";this.options.addClasses&&this.element.addClass("ui-draggable");this.options.disabled&&this.element.addClass("ui-draggable-disabled");this._mouseInit()},destroy:function(){if(this.element.data("draggable")){this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled");this._mouseDestroy();return this}},_mouseCapture:function(a){var b= | |
| 83 | +this.options;if(this.helper||b.disabled||d(a.target).is(".ui-resizable-handle"))return false;this.handle=this._getHandle(a);if(!this.handle)return false;if(b.iframeFix)d(b.iframeFix===true?"iframe":b.iframeFix).each(function(){d('<div class="ui-draggable-iframeFix" style="background: #fff;"></div>').css({width:this.offsetWidth+"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1E3}).css(d(this).offset()).appendTo("body")});return true},_mouseStart:function(a){var b=this.options; | |
| 84 | +this.helper=this._createHelper(a);this._cacheHelperProportions();if(d.ui.ddmanager)d.ui.ddmanager.current=this;this._cacheMargins();this.cssPosition=this.helper.css("position");this.scrollParent=this.helper.scrollParent();this.offset=this.positionAbs=this.element.offset();this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left};d.extend(this.offset,{click:{left:a.pageX-this.offset.left,top:a.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()}); | |
| 85 | +this.originalPosition=this.position=this._generatePosition(a);this.originalPageX=a.pageX;this.originalPageY=a.pageY;b.cursorAt&&this._adjustOffsetFromHelper(b.cursorAt);b.containment&&this._setContainment();if(this._trigger("start",a)===false){this._clear();return false}this._cacheHelperProportions();d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,a);this.helper.addClass("ui-draggable-dragging");this._mouseDrag(a,true);d.ui.ddmanager&&d.ui.ddmanager.dragStart(this,a);return true}, | |
| 86 | +_mouseDrag:function(a,b){this.position=this._generatePosition(a);this.positionAbs=this._convertPositionTo("absolute");if(!b){b=this._uiHash();if(this._trigger("drag",a,b)===false){this._mouseUp({});return false}this.position=b.position}if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";d.ui.ddmanager&&d.ui.ddmanager.drag(this,a);return false},_mouseStop:function(a){var b= | |
| 87 | +false;if(d.ui.ddmanager&&!this.options.dropBehaviour)b=d.ui.ddmanager.drop(this,a);if(this.dropped){b=this.dropped;this.dropped=false}if((!this.element[0]||!this.element[0].parentNode)&&this.options.helper=="original")return false;if(this.options.revert=="invalid"&&!b||this.options.revert=="valid"&&b||this.options.revert===true||d.isFunction(this.options.revert)&&this.options.revert.call(this.element,b)){var c=this;d(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration, | |
| 88 | +10),function(){c._trigger("stop",a)!==false&&c._clear()})}else this._trigger("stop",a)!==false&&this._clear();return false},_mouseUp:function(a){this.options.iframeFix===true&&d("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)});d.ui.ddmanager&&d.ui.ddmanager.dragStop(this,a);return d.ui.mouse.prototype._mouseUp.call(this,a)},cancel:function(){this.helper.is(".ui-draggable-dragging")?this._mouseUp({}):this._clear();return this},_getHandle:function(a){var b=!this.options.handle|| | |
| 89 | +!d(this.options.handle,this.element).length?true:false;d(this.options.handle,this.element).find("*").andSelf().each(function(){if(this==a.target)b=true});return b},_createHelper:function(a){var b=this.options;a=d.isFunction(b.helper)?d(b.helper.apply(this.element[0],[a])):b.helper=="clone"?this.element.clone().removeAttr("id"):this.element;a.parents("body").length||a.appendTo(b.appendTo=="parent"?this.element[0].parentNode:b.appendTo);a[0]!=this.element[0]&&!/(fixed|absolute)/.test(a.css("position"))&& | |
| 90 | +a.css("position","absolute");return a},_adjustOffsetFromHelper:function(a){if(typeof a=="string")a=a.split(" ");if(d.isArray(a))a={left:+a[0],top:+a[1]||0};if("left"in a)this.offset.click.left=a.left+this.margins.left;if("right"in a)this.offset.click.left=this.helperProportions.width-a.right+this.margins.left;if("top"in a)this.offset.click.top=a.top+this.margins.top;if("bottom"in a)this.offset.click.top=this.helperProportions.height-a.bottom+this.margins.top},_getParentOffset:function(){this.offsetParent= | |
| 91 | +this.helper.offsetParent();var a=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0])){a.left+=this.scrollParent.scrollLeft();a.top+=this.scrollParent.scrollTop()}if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&d.browser.msie)a={top:0,left:0};return{top:a.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:a.left+(parseInt(this.offsetParent.css("borderLeftWidth"), | |
| 92 | +10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.element.position();return{top:a.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.element.css("marginLeft"),10)||0,top:parseInt(this.element.css("marginTop"),10)||0,right:parseInt(this.element.css("marginRight"),10)||0,bottom:parseInt(this.element.css("marginBottom"), | |
| 93 | +10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var a=this.options;if(a.containment=="parent")a.containment=this.helper[0].parentNode;if(a.containment=="document"||a.containment=="window")this.containment=[a.containment=="document"?0:d(window).scrollLeft()-this.offset.relative.left-this.offset.parent.left,a.containment=="document"?0:d(window).scrollTop()-this.offset.relative.top-this.offset.parent.top, | |
| 94 | +(a.containment=="document"?0:d(window).scrollLeft())+d(a.containment=="document"?document:window).width()-this.helperProportions.width-this.margins.left,(a.containment=="document"?0:d(window).scrollTop())+(d(a.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(a.containment)&&a.containment.constructor!=Array){a=d(a.containment);var b=a[0];if(b){a.offset();var c=d(b).css("overflow")!= | |
| 95 | +"hidden";this.containment=[(parseInt(d(b).css("borderLeftWidth"),10)||0)+(parseInt(d(b).css("paddingLeft"),10)||0),(parseInt(d(b).css("borderTopWidth"),10)||0)+(parseInt(d(b).css("paddingTop"),10)||0),(c?Math.max(b.scrollWidth,b.offsetWidth):b.offsetWidth)-(parseInt(d(b).css("borderLeftWidth"),10)||0)-(parseInt(d(b).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left-this.margins.right,(c?Math.max(b.scrollHeight,b.offsetHeight):b.offsetHeight)-(parseInt(d(b).css("borderTopWidth"), | |
| 96 | +10)||0)-(parseInt(d(b).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top-this.margins.bottom];this.relative_container=a}}else if(a.containment.constructor==Array)this.containment=a.containment},_convertPositionTo:function(a,b){if(!b)b=this.position;a=a=="absolute"?1:-1;var c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName);return{top:b.top+ | |
| 97 | +this.offset.relative.top*a+this.offset.parent.top*a-(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop())*a),left:b.left+this.offset.relative.left*a+this.offset.parent.left*a-(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():f?0:c.scrollLeft())*a)}},_generatePosition:function(a){var b=this.options,c=this.cssPosition=="absolute"&& | |
| 98 | +!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,f=/(html|body)/i.test(c[0].tagName),e=a.pageX,h=a.pageY;if(this.originalPosition){var g;if(this.containment){if(this.relative_container){g=this.relative_container.offset();g=[this.containment[0]+g.left,this.containment[1]+g.top,this.containment[2]+g.left,this.containment[3]+g.top]}else g=this.containment;if(a.pageX-this.offset.click.left<g[0])e=g[0]+this.offset.click.left; | |
| 99 | +if(a.pageY-this.offset.click.top<g[1])h=g[1]+this.offset.click.top;if(a.pageX-this.offset.click.left>g[2])e=g[2]+this.offset.click.left;if(a.pageY-this.offset.click.top>g[3])h=g[3]+this.offset.click.top}if(b.grid){h=b.grid[1]?this.originalPageY+Math.round((h-this.originalPageY)/b.grid[1])*b.grid[1]:this.originalPageY;h=g?!(h-this.offset.click.top<g[1]||h-this.offset.click.top>g[3])?h:!(h-this.offset.click.top<g[1])?h-b.grid[1]:h+b.grid[1]:h;e=b.grid[0]?this.originalPageX+Math.round((e-this.originalPageX)/ | |
| 100 | +b.grid[0])*b.grid[0]:this.originalPageX;e=g?!(e-this.offset.click.left<g[0]||e-this.offset.click.left>g[2])?e:!(e-this.offset.click.left<g[0])?e-b.grid[0]:e+b.grid[0]:e}}return{top:h-this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(d.browser.safari&&d.browser.version<526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollTop():f?0:c.scrollTop()),left:e-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(d.browser.safari&&d.browser.version< | |
| 101 | +526&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():f?0:c.scrollLeft())}},_clear:function(){this.helper.removeClass("ui-draggable-dragging");this.helper[0]!=this.element[0]&&!this.cancelHelperRemoval&&this.helper.remove();this.helper=null;this.cancelHelperRemoval=false},_trigger:function(a,b,c){c=c||this._uiHash();d.ui.plugin.call(this,a,[b,c]);if(a=="drag")this.positionAbs=this._convertPositionTo("absolute");return d.Widget.prototype._trigger.call(this,a,b, | |
| 102 | +c)},plugins:{},_uiHash:function(){return{helper:this.helper,position:this.position,originalPosition:this.originalPosition,offset:this.positionAbs}}});d.extend(d.ui.draggable,{version:"1.8.16"});d.ui.plugin.add("draggable","connectToSortable",{start:function(a,b){var c=d(this).data("draggable"),f=c.options,e=d.extend({},b,{item:c.element});c.sortables=[];d(f.connectToSortable).each(function(){var h=d.data(this,"sortable");if(h&&!h.options.disabled){c.sortables.push({instance:h,shouldRevert:h.options.revert}); | |
| 103 | +h.refreshPositions();h._trigger("activate",a,e)}})},stop:function(a,b){var c=d(this).data("draggable"),f=d.extend({},b,{item:c.element});d.each(c.sortables,function(){if(this.instance.isOver){this.instance.isOver=0;c.cancelHelperRemoval=true;this.instance.cancelHelperRemoval=false;if(this.shouldRevert)this.instance.options.revert=true;this.instance._mouseStop(a);this.instance.options.helper=this.instance.options._helper;c.options.helper=="original"&&this.instance.currentItem.css({top:"auto",left:"auto"})}else{this.instance.cancelHelperRemoval= | |
| 104 | +false;this.instance._trigger("deactivate",a,f)}})},drag:function(a,b){var c=d(this).data("draggable"),f=this;d.each(c.sortables,function(){this.instance.positionAbs=c.positionAbs;this.instance.helperProportions=c.helperProportions;this.instance.offset.click=c.offset.click;if(this.instance._intersectsWith(this.instance.containerCache)){if(!this.instance.isOver){this.instance.isOver=1;this.instance.currentItem=d(f).clone().removeAttr("id").appendTo(this.instance.element).data("sortable-item",true); | |
| 105 | +this.instance.options._helper=this.instance.options.helper;this.instance.options.helper=function(){return b.helper[0]};a.target=this.instance.currentItem[0];this.instance._mouseCapture(a,true);this.instance._mouseStart(a,true,true);this.instance.offset.click.top=c.offset.click.top;this.instance.offset.click.left=c.offset.click.left;this.instance.offset.parent.left-=c.offset.parent.left-this.instance.offset.parent.left;this.instance.offset.parent.top-=c.offset.parent.top-this.instance.offset.parent.top; | |
| 106 | +c._trigger("toSortable",a);c.dropped=this.instance.element;c.currentItem=c.element;this.instance.fromOutside=c}this.instance.currentItem&&this.instance._mouseDrag(a)}else if(this.instance.isOver){this.instance.isOver=0;this.instance.cancelHelperRemoval=true;this.instance.options.revert=false;this.instance._trigger("out",a,this.instance._uiHash(this.instance));this.instance._mouseStop(a,true);this.instance.options.helper=this.instance.options._helper;this.instance.currentItem.remove();this.instance.placeholder&& | |
| 107 | +this.instance.placeholder.remove();c._trigger("fromSortable",a);c.dropped=false}})}});d.ui.plugin.add("draggable","cursor",{start:function(){var a=d("body"),b=d(this).data("draggable").options;if(a.css("cursor"))b._cursor=a.css("cursor");a.css("cursor",b.cursor)},stop:function(){var a=d(this).data("draggable").options;a._cursor&&d("body").css("cursor",a._cursor)}});d.ui.plugin.add("draggable","opacity",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("opacity"))b._opacity= | |
| 108 | +a.css("opacity");a.css("opacity",b.opacity)},stop:function(a,b){a=d(this).data("draggable").options;a._opacity&&d(b.helper).css("opacity",a._opacity)}});d.ui.plugin.add("draggable","scroll",{start:function(){var a=d(this).data("draggable");if(a.scrollParent[0]!=document&&a.scrollParent[0].tagName!="HTML")a.overflowOffset=a.scrollParent.offset()},drag:function(a){var b=d(this).data("draggable"),c=b.options,f=false;if(b.scrollParent[0]!=document&&b.scrollParent[0].tagName!="HTML"){if(!c.axis||c.axis!= | |
| 109 | +"x")if(b.overflowOffset.top+b.scrollParent[0].offsetHeight-a.pageY<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop+c.scrollSpeed;else if(a.pageY-b.overflowOffset.top<c.scrollSensitivity)b.scrollParent[0].scrollTop=f=b.scrollParent[0].scrollTop-c.scrollSpeed;if(!c.axis||c.axis!="y")if(b.overflowOffset.left+b.scrollParent[0].offsetWidth-a.pageX<c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft+c.scrollSpeed;else if(a.pageX-b.overflowOffset.left< | |
| 110 | +c.scrollSensitivity)b.scrollParent[0].scrollLeft=f=b.scrollParent[0].scrollLeft-c.scrollSpeed}else{if(!c.axis||c.axis!="x")if(a.pageY-d(document).scrollTop()<c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()-c.scrollSpeed);else if(d(window).height()-(a.pageY-d(document).scrollTop())<c.scrollSensitivity)f=d(document).scrollTop(d(document).scrollTop()+c.scrollSpeed);if(!c.axis||c.axis!="y")if(a.pageX-d(document).scrollLeft()<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()- | |
| 111 | +c.scrollSpeed);else if(d(window).width()-(a.pageX-d(document).scrollLeft())<c.scrollSensitivity)f=d(document).scrollLeft(d(document).scrollLeft()+c.scrollSpeed)}f!==false&&d.ui.ddmanager&&!c.dropBehaviour&&d.ui.ddmanager.prepareOffsets(b,a)}});d.ui.plugin.add("draggable","snap",{start:function(){var a=d(this).data("draggable"),b=a.options;a.snapElements=[];d(b.snap.constructor!=String?b.snap.items||":data(draggable)":b.snap).each(function(){var c=d(this),f=c.offset();this!=a.element[0]&&a.snapElements.push({item:this, | |
| 112 | +width:c.outerWidth(),height:c.outerHeight(),top:f.top,left:f.left})})},drag:function(a,b){for(var c=d(this).data("draggable"),f=c.options,e=f.snapTolerance,h=b.offset.left,g=h+c.helperProportions.width,n=b.offset.top,o=n+c.helperProportions.height,i=c.snapElements.length-1;i>=0;i--){var j=c.snapElements[i].left,l=j+c.snapElements[i].width,k=c.snapElements[i].top,m=k+c.snapElements[i].height;if(j-e<h&&h<l+e&&k-e<n&&n<m+e||j-e<h&&h<l+e&&k-e<o&&o<m+e||j-e<g&&g<l+e&&k-e<n&&n<m+e||j-e<g&&g<l+e&&k-e<o&& | |
| 113 | +o<m+e){if(f.snapMode!="inner"){var p=Math.abs(k-o)<=e,q=Math.abs(m-n)<=e,r=Math.abs(j-g)<=e,s=Math.abs(l-h)<=e;if(p)b.position.top=c._convertPositionTo("relative",{top:k-c.helperProportions.height,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:m,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:j-c.helperProportions.width}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:l}).left-c.margins.left}var t= | |
| 114 | +p||q||r||s;if(f.snapMode!="outer"){p=Math.abs(k-n)<=e;q=Math.abs(m-o)<=e;r=Math.abs(j-h)<=e;s=Math.abs(l-g)<=e;if(p)b.position.top=c._convertPositionTo("relative",{top:k,left:0}).top-c.margins.top;if(q)b.position.top=c._convertPositionTo("relative",{top:m-c.helperProportions.height,left:0}).top-c.margins.top;if(r)b.position.left=c._convertPositionTo("relative",{top:0,left:j}).left-c.margins.left;if(s)b.position.left=c._convertPositionTo("relative",{top:0,left:l-c.helperProportions.width}).left-c.margins.left}if(!c.snapElements[i].snapping&& | |
| 115 | +(p||q||r||s||t))c.options.snap.snap&&c.options.snap.snap.call(c.element,a,d.extend(c._uiHash(),{snapItem:c.snapElements[i].item}));c.snapElements[i].snapping=p||q||r||s||t}else{c.snapElements[i].snapping&&c.options.snap.release&&c.options.snap.release.call(c.element,a,d.extend(c._uiHash(),{snapItem:c.snapElements[i].item}));c.snapElements[i].snapping=false}}}});d.ui.plugin.add("draggable","stack",{start:function(){var a=d(this).data("draggable").options;a=d.makeArray(d(a.stack)).sort(function(c,f){return(parseInt(d(c).css("zIndex"), | |
| 116 | +10)||0)-(parseInt(d(f).css("zIndex"),10)||0)});if(a.length){var b=parseInt(a[0].style.zIndex)||0;d(a).each(function(c){this.style.zIndex=b+c});this[0].style.zIndex=b+a.length}}});d.ui.plugin.add("draggable","zIndex",{start:function(a,b){a=d(b.helper);b=d(this).data("draggable").options;if(a.css("zIndex"))b._zIndex=a.css("zIndex");a.css("zIndex",b.zIndex)},stop:function(a,b){a=d(this).data("draggable").options;a._zIndex&&d(b.helper).css("zIndex",a._zIndex)}})})(jQuery); | |
| 117 | +;/* | |
| 118 | + * jQuery UI Droppable 1.8.16 | |
| 119 | + * | |
| 120 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 121 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 122 | + * http://jquery.org/license | |
| 123 | + * | |
| 124 | + * http://docs.jquery.com/UI/Droppables | |
| 125 | + * | |
| 126 | + * Depends: | |
| 127 | + * jquery.ui.core.js | |
| 128 | + * jquery.ui.widget.js | |
| 129 | + * jquery.ui.mouse.js | |
| 130 | + * jquery.ui.draggable.js | |
| 131 | + */ | |
| 132 | +(function(d){d.widget("ui.droppable",{widgetEventPrefix:"drop",options:{accept:"*",activeClass:false,addClasses:true,greedy:false,hoverClass:false,scope:"default",tolerance:"intersect"},_create:function(){var a=this.options,b=a.accept;this.isover=0;this.isout=1;this.accept=d.isFunction(b)?b:function(c){return c.is(b)};this.proportions={width:this.element[0].offsetWidth,height:this.element[0].offsetHeight};d.ui.ddmanager.droppables[a.scope]=d.ui.ddmanager.droppables[a.scope]||[];d.ui.ddmanager.droppables[a.scope].push(this); | |
| 133 | +a.addClasses&&this.element.addClass("ui-droppable")},destroy:function(){for(var a=d.ui.ddmanager.droppables[this.options.scope],b=0;b<a.length;b++)a[b]==this&&a.splice(b,1);this.element.removeClass("ui-droppable ui-droppable-disabled").removeData("droppable").unbind(".droppable");return this},_setOption:function(a,b){if(a=="accept")this.accept=d.isFunction(b)?b:function(c){return c.is(b)};d.Widget.prototype._setOption.apply(this,arguments)},_activate:function(a){var b=d.ui.ddmanager.current;this.options.activeClass&& | |
| 134 | +this.element.addClass(this.options.activeClass);b&&this._trigger("activate",a,this.ui(b))},_deactivate:function(a){var b=d.ui.ddmanager.current;this.options.activeClass&&this.element.removeClass(this.options.activeClass);b&&this._trigger("deactivate",a,this.ui(b))},_over:function(a){var b=d.ui.ddmanager.current;if(!(!b||(b.currentItem||b.element)[0]==this.element[0]))if(this.accept.call(this.element[0],b.currentItem||b.element)){this.options.hoverClass&&this.element.addClass(this.options.hoverClass); | |
| 135 | +this._trigger("over",a,this.ui(b))}},_out:function(a){var b=d.ui.ddmanager.current;if(!(!b||(b.currentItem||b.element)[0]==this.element[0]))if(this.accept.call(this.element[0],b.currentItem||b.element)){this.options.hoverClass&&this.element.removeClass(this.options.hoverClass);this._trigger("out",a,this.ui(b))}},_drop:function(a,b){var c=b||d.ui.ddmanager.current;if(!c||(c.currentItem||c.element)[0]==this.element[0])return false;var e=false;this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function(){var g= | |
| 136 | +d.data(this,"droppable");if(g.options.greedy&&!g.options.disabled&&g.options.scope==c.options.scope&&g.accept.call(g.element[0],c.currentItem||c.element)&&d.ui.intersect(c,d.extend(g,{offset:g.element.offset()}),g.options.tolerance)){e=true;return false}});if(e)return false;if(this.accept.call(this.element[0],c.currentItem||c.element)){this.options.activeClass&&this.element.removeClass(this.options.activeClass);this.options.hoverClass&&this.element.removeClass(this.options.hoverClass);this._trigger("drop", | |
| 137 | +a,this.ui(c));return this.element}return false},ui:function(a){return{draggable:a.currentItem||a.element,helper:a.helper,position:a.position,offset:a.positionAbs}}});d.extend(d.ui.droppable,{version:"1.8.16"});d.ui.intersect=function(a,b,c){if(!b.offset)return false;var e=(a.positionAbs||a.position.absolute).left,g=e+a.helperProportions.width,f=(a.positionAbs||a.position.absolute).top,h=f+a.helperProportions.height,i=b.offset.left,k=i+b.proportions.width,j=b.offset.top,l=j+b.proportions.height; | |
| 138 | +switch(c){case "fit":return i<=e&&g<=k&&j<=f&&h<=l;case "intersect":return i<e+a.helperProportions.width/2&&g-a.helperProportions.width/2<k&&j<f+a.helperProportions.height/2&&h-a.helperProportions.height/2<l;case "pointer":return d.ui.isOver((a.positionAbs||a.position.absolute).top+(a.clickOffset||a.offset.click).top,(a.positionAbs||a.position.absolute).left+(a.clickOffset||a.offset.click).left,j,i,b.proportions.height,b.proportions.width);case "touch":return(f>=j&&f<=l||h>=j&&h<=l||f<j&&h>l)&&(e>= | |
| 139 | +i&&e<=k||g>=i&&g<=k||e<i&&g>k);default:return false}};d.ui.ddmanager={current:null,droppables:{"default":[]},prepareOffsets:function(a,b){var c=d.ui.ddmanager.droppables[a.options.scope]||[],e=b?b.type:null,g=(a.currentItem||a.element).find(":data(droppable)").andSelf(),f=0;a:for(;f<c.length;f++)if(!(c[f].options.disabled||a&&!c[f].accept.call(c[f].element[0],a.currentItem||a.element))){for(var h=0;h<g.length;h++)if(g[h]==c[f].element[0]){c[f].proportions.height=0;continue a}c[f].visible=c[f].element.css("display")!= | |
| 140 | +"none";if(c[f].visible){e=="mousedown"&&c[f]._activate.call(c[f],b);c[f].offset=c[f].element.offset();c[f].proportions={width:c[f].element[0].offsetWidth,height:c[f].element[0].offsetHeight}}}},drop:function(a,b){var c=false;d.each(d.ui.ddmanager.droppables[a.options.scope]||[],function(){if(this.options){if(!this.options.disabled&&this.visible&&d.ui.intersect(a,this,this.options.tolerance))c=c||this._drop.call(this,b);if(!this.options.disabled&&this.visible&&this.accept.call(this.element[0],a.currentItem|| | |
| 141 | +a.element)){this.isout=1;this.isover=0;this._deactivate.call(this,b)}}});return c},dragStart:function(a,b){a.element.parents(":not(body,html)").bind("scroll.droppable",function(){a.options.refreshPositions||d.ui.ddmanager.prepareOffsets(a,b)})},drag:function(a,b){a.options.refreshPositions&&d.ui.ddmanager.prepareOffsets(a,b);d.each(d.ui.ddmanager.droppables[a.options.scope]||[],function(){if(!(this.options.disabled||this.greedyChild||!this.visible)){var c=d.ui.intersect(a,this,this.options.tolerance); | |
| 142 | +if(c=!c&&this.isover==1?"isout":c&&this.isover==0?"isover":null){var e;if(this.options.greedy){var g=this.element.parents(":data(droppable):eq(0)");if(g.length){e=d.data(g[0],"droppable");e.greedyChild=c=="isover"?1:0}}if(e&&c=="isover"){e.isover=0;e.isout=1;e._out.call(e,b)}this[c]=1;this[c=="isout"?"isover":"isout"]=0;this[c=="isover"?"_over":"_out"].call(this,b);if(e&&c=="isout"){e.isout=0;e.isover=1;e._over.call(e,b)}}}})},dragStop:function(a,b){a.element.parents(":not(body,html)").unbind("scroll.droppable"); | |
| 143 | +a.options.refreshPositions||d.ui.ddmanager.prepareOffsets(a,b)}}})(jQuery); | |
| 144 | +;/* | |
| 145 | + * jQuery UI Resizable 1.8.16 | |
| 146 | + * | |
| 147 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 148 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 149 | + * http://jquery.org/license | |
| 150 | + * | |
| 151 | + * http://docs.jquery.com/UI/Resizables | |
| 152 | + * | |
| 153 | + * Depends: | |
| 154 | + * jquery.ui.core.js | |
| 155 | + * jquery.ui.mouse.js | |
| 156 | + * jquery.ui.widget.js | |
| 157 | + */ | |
| 158 | +(function(e){e.widget("ui.resizable",e.ui.mouse,{widgetEventPrefix:"resize",options:{alsoResize:false,animate:false,animateDuration:"slow",animateEasing:"swing",aspectRatio:false,autoHide:false,containment:false,ghost:false,grid:false,handles:"e,s,se",helper:false,maxHeight:null,maxWidth:null,minHeight:10,minWidth:10,zIndex:1E3},_create:function(){var b=this,a=this.options;this.element.addClass("ui-resizable");e.extend(this,{_aspectRatio:!!a.aspectRatio,aspectRatio:a.aspectRatio,originalElement:this.element, | |
| 159 | +_proportionallyResizeElements:[],_helper:a.helper||a.ghost||a.animate?a.helper||"ui-resizable-helper":null});if(this.element[0].nodeName.match(/canvas|textarea|input|select|button|img/i)){/relative/.test(this.element.css("position"))&&e.browser.opera&&this.element.css({position:"relative",top:"auto",left:"auto"});this.element.wrap(e('<div class="ui-wrapper" style="overflow: hidden;"></div>').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(), | |
| 160 | +top:this.element.css("top"),left:this.element.css("left")}));this.element=this.element.parent().data("resizable",this.element.data("resizable"));this.elementIsWrapper=true;this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")});this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0});this.originalResizeStyle= | |
| 161 | +this.originalElement.css("resize");this.originalElement.css("resize","none");this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"}));this.originalElement.css({margin:this.originalElement.css("margin")});this._proportionallyResize()}this.handles=a.handles||(!e(".ui-resizable-handle",this.element).length?"e,s,se":{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne", | |
| 162 | +nw:".ui-resizable-nw"});if(this.handles.constructor==String){if(this.handles=="all")this.handles="n,e,s,w,se,sw,ne,nw";var c=this.handles.split(",");this.handles={};for(var d=0;d<c.length;d++){var f=e.trim(c[d]),g=e('<div class="ui-resizable-handle '+("ui-resizable-"+f)+'"></div>');/sw|se|ne|nw/.test(f)&&g.css({zIndex:++a.zIndex});"se"==f&&g.addClass("ui-icon ui-icon-gripsmall-diagonal-se");this.handles[f]=".ui-resizable-"+f;this.element.append(g)}}this._renderAxis=function(h){h=h||this.element;for(var i in this.handles){if(this.handles[i].constructor== | |
| 163 | +String)this.handles[i]=e(this.handles[i],this.element).show();if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var j=e(this.handles[i],this.element),l=0;l=/sw|ne|nw|se|n|s/.test(i)?j.outerHeight():j.outerWidth();j=["padding",/ne|nw|n/.test(i)?"Top":/se|sw|s/.test(i)?"Bottom":/^e$/.test(i)?"Right":"Left"].join("");h.css(j,l);this._proportionallyResize()}e(this.handles[i])}};this._renderAxis(this.element);this._handles=e(".ui-resizable-handle",this.element).disableSelection(); | |
| 164 | +this._handles.mouseover(function(){if(!b.resizing){if(this.className)var h=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);b.axis=h&&h[1]?h[1]:"se"}});if(a.autoHide){this._handles.hide();e(this.element).addClass("ui-resizable-autohide").hover(function(){if(!a.disabled){e(this).removeClass("ui-resizable-autohide");b._handles.show()}},function(){if(!a.disabled)if(!b.resizing){e(this).addClass("ui-resizable-autohide");b._handles.hide()}})}this._mouseInit()},destroy:function(){this._mouseDestroy(); | |
| 165 | +var b=function(c){e(c).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};if(this.elementIsWrapper){b(this.element);var a=this.element;a.after(this.originalElement.css({position:a.css("position"),width:a.outerWidth(),height:a.outerHeight(),top:a.css("top"),left:a.css("left")})).remove()}this.originalElement.css("resize",this.originalResizeStyle);b(this.originalElement);return this},_mouseCapture:function(b){var a= | |
| 166 | +false;for(var c in this.handles)if(e(this.handles[c])[0]==b.target)a=true;return!this.options.disabled&&a},_mouseStart:function(b){var a=this.options,c=this.element.position(),d=this.element;this.resizing=true;this.documentScroll={top:e(document).scrollTop(),left:e(document).scrollLeft()};if(d.is(".ui-draggable")||/absolute/.test(d.css("position")))d.css({position:"absolute",top:c.top,left:c.left});e.browser.opera&&/relative/.test(d.css("position"))&&d.css({position:"relative",top:"auto",left:"auto"}); | |
| 167 | +this._renderProxy();c=m(this.helper.css("left"));var f=m(this.helper.css("top"));if(a.containment){c+=e(a.containment).scrollLeft()||0;f+=e(a.containment).scrollTop()||0}this.offset=this.helper.offset();this.position={left:c,top:f};this.size=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalSize=this._helper?{width:d.outerWidth(),height:d.outerHeight()}:{width:d.width(),height:d.height()};this.originalPosition={left:c,top:f};this.sizeDiff= | |
| 168 | +{width:d.outerWidth()-d.width(),height:d.outerHeight()-d.height()};this.originalMousePosition={left:b.pageX,top:b.pageY};this.aspectRatio=typeof a.aspectRatio=="number"?a.aspectRatio:this.originalSize.width/this.originalSize.height||1;a=e(".ui-resizable-"+this.axis).css("cursor");e("body").css("cursor",a=="auto"?this.axis+"-resize":a);d.addClass("ui-resizable-resizing");this._propagate("start",b);return true},_mouseDrag:function(b){var a=this.helper,c=this.originalMousePosition,d=this._change[this.axis]; | |
| 169 | +if(!d)return false;c=d.apply(this,[b,b.pageX-c.left||0,b.pageY-c.top||0]);this._updateVirtualBoundaries(b.shiftKey);if(this._aspectRatio||b.shiftKey)c=this._updateRatio(c,b);c=this._respectSize(c,b);this._propagate("resize",b);a.css({top:this.position.top+"px",left:this.position.left+"px",width:this.size.width+"px",height:this.size.height+"px"});!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize();this._updateCache(c);this._trigger("resize",b,this.ui());return false}, | |
| 170 | +_mouseStop:function(b){this.resizing=false;var a=this.options,c=this;if(this._helper){var d=this._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName);d=f&&e.ui.hasScroll(d[0],"left")?0:c.sizeDiff.height;f=f?0:c.sizeDiff.width;f={width:c.helper.width()-f,height:c.helper.height()-d};d=parseInt(c.element.css("left"),10)+(c.position.left-c.originalPosition.left)||null;var g=parseInt(c.element.css("top"),10)+(c.position.top-c.originalPosition.top)||null;a.animate||this.element.css(e.extend(f, | |
| 171 | +{top:g,left:d}));c.helper.height(c.size.height);c.helper.width(c.size.width);this._helper&&!a.animate&&this._proportionallyResize()}e("body").css("cursor","auto");this.element.removeClass("ui-resizable-resizing");this._propagate("stop",b);this._helper&&this.helper.remove();return false},_updateVirtualBoundaries:function(b){var a=this.options,c,d,f;a={minWidth:k(a.minWidth)?a.minWidth:0,maxWidth:k(a.maxWidth)?a.maxWidth:Infinity,minHeight:k(a.minHeight)?a.minHeight:0,maxHeight:k(a.maxHeight)?a.maxHeight: | |
| 172 | +Infinity};if(this._aspectRatio||b){b=a.minHeight*this.aspectRatio;d=a.minWidth/this.aspectRatio;c=a.maxHeight*this.aspectRatio;f=a.maxWidth/this.aspectRatio;if(b>a.minWidth)a.minWidth=b;if(d>a.minHeight)a.minHeight=d;if(c<a.maxWidth)a.maxWidth=c;if(f<a.maxHeight)a.maxHeight=f}this._vBoundaries=a},_updateCache:function(b){this.offset=this.helper.offset();if(k(b.left))this.position.left=b.left;if(k(b.top))this.position.top=b.top;if(k(b.height))this.size.height=b.height;if(k(b.width))this.size.width= | |
| 173 | +b.width},_updateRatio:function(b){var a=this.position,c=this.size,d=this.axis;if(k(b.height))b.width=b.height*this.aspectRatio;else if(k(b.width))b.height=b.width/this.aspectRatio;if(d=="sw"){b.left=a.left+(c.width-b.width);b.top=null}if(d=="nw"){b.top=a.top+(c.height-b.height);b.left=a.left+(c.width-b.width)}return b},_respectSize:function(b){var a=this._vBoundaries,c=this.axis,d=k(b.width)&&a.maxWidth&&a.maxWidth<b.width,f=k(b.height)&&a.maxHeight&&a.maxHeight<b.height,g=k(b.width)&&a.minWidth&& | |
| 174 | +a.minWidth>b.width,h=k(b.height)&&a.minHeight&&a.minHeight>b.height;if(g)b.width=a.minWidth;if(h)b.height=a.minHeight;if(d)b.width=a.maxWidth;if(f)b.height=a.maxHeight;var i=this.originalPosition.left+this.originalSize.width,j=this.position.top+this.size.height,l=/sw|nw|w/.test(c);c=/nw|ne|n/.test(c);if(g&&l)b.left=i-a.minWidth;if(d&&l)b.left=i-a.maxWidth;if(h&&c)b.top=j-a.minHeight;if(f&&c)b.top=j-a.maxHeight;if((a=!b.width&&!b.height)&&!b.left&&b.top)b.top=null;else if(a&&!b.top&&b.left)b.left= | |
| 175 | +null;return b},_proportionallyResize:function(){if(this._proportionallyResizeElements.length)for(var b=this.helper||this.element,a=0;a<this._proportionallyResizeElements.length;a++){var c=this._proportionallyResizeElements[a];if(!this.borderDif){var d=[c.css("borderTopWidth"),c.css("borderRightWidth"),c.css("borderBottomWidth"),c.css("borderLeftWidth")],f=[c.css("paddingTop"),c.css("paddingRight"),c.css("paddingBottom"),c.css("paddingLeft")];this.borderDif=e.map(d,function(g,h){g=parseInt(g,10)|| | |
| 176 | +0;h=parseInt(f[h],10)||0;return g+h})}e.browser.msie&&(e(b).is(":hidden")||e(b).parents(":hidden").length)||c.css({height:b.height()-this.borderDif[0]-this.borderDif[2]||0,width:b.width()-this.borderDif[1]-this.borderDif[3]||0})}},_renderProxy:function(){var b=this.options;this.elementOffset=this.element.offset();if(this._helper){this.helper=this.helper||e('<div style="overflow:hidden;"></div>');var a=e.browser.msie&&e.browser.version<7,c=a?1:0;a=a?2:-1;this.helper.addClass(this._helper).css({width:this.element.outerWidth()+ | |
| 177 | +a,height:this.element.outerHeight()+a,position:"absolute",left:this.elementOffset.left-c+"px",top:this.elementOffset.top-c+"px",zIndex:++b.zIndex});this.helper.appendTo("body").disableSelection()}else this.helper=this.element},_change:{e:function(b,a){return{width:this.originalSize.width+a}},w:function(b,a){return{left:this.originalPosition.left+a,width:this.originalSize.width-a}},n:function(b,a,c){return{top:this.originalPosition.top+c,height:this.originalSize.height-c}},s:function(b,a,c){return{height:this.originalSize.height+ | |
| 178 | +c}},se:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},sw:function(b,a,c){return e.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[b,a,c]))},ne:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[b,a,c]))},nw:function(b,a,c){return e.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[b,a,c]))}},_propagate:function(b,a){e.ui.plugin.call(this,b,[a,this.ui()]); | |
| 179 | +b!="resize"&&this._trigger(b,a,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,originalPosition:this.originalPosition}}});e.extend(e.ui.resizable,{version:"1.8.16"});e.ui.plugin.add("resizable","alsoResize",{start:function(){var b=e(this).data("resizable").options,a=function(c){e(c).each(function(){var d=e(this);d.data("resizable-alsoresize",{width:parseInt(d.width(), | |
| 180 | +10),height:parseInt(d.height(),10),left:parseInt(d.css("left"),10),top:parseInt(d.css("top"),10),position:d.css("position")})})};if(typeof b.alsoResize=="object"&&!b.alsoResize.parentNode)if(b.alsoResize.length){b.alsoResize=b.alsoResize[0];a(b.alsoResize)}else e.each(b.alsoResize,function(c){a(c)});else a(b.alsoResize)},resize:function(b,a){var c=e(this).data("resizable");b=c.options;var d=c.originalSize,f=c.originalPosition,g={height:c.size.height-d.height||0,width:c.size.width-d.width||0,top:c.position.top- | |
| 181 | +f.top||0,left:c.position.left-f.left||0},h=function(i,j){e(i).each(function(){var l=e(this),q=e(this).data("resizable-alsoresize"),p={},r=j&&j.length?j:l.parents(a.originalElement[0]).length?["width","height"]:["width","height","top","left"];e.each(r,function(n,o){if((n=(q[o]||0)+(g[o]||0))&&n>=0)p[o]=n||null});if(e.browser.opera&&/relative/.test(l.css("position"))){c._revertToRelativePosition=true;l.css({position:"absolute",top:"auto",left:"auto"})}l.css(p)})};typeof b.alsoResize=="object"&&!b.alsoResize.nodeType? | |
| 182 | +e.each(b.alsoResize,function(i,j){h(i,j)}):h(b.alsoResize)},stop:function(){var b=e(this).data("resizable"),a=b.options,c=function(d){e(d).each(function(){var f=e(this);f.css({position:f.data("resizable-alsoresize").position})})};if(b._revertToRelativePosition){b._revertToRelativePosition=false;typeof a.alsoResize=="object"&&!a.alsoResize.nodeType?e.each(a.alsoResize,function(d){c(d)}):c(a.alsoResize)}e(this).removeData("resizable-alsoresize")}});e.ui.plugin.add("resizable","animate",{stop:function(b){var a= | |
| 183 | +e(this).data("resizable"),c=a.options,d=a._proportionallyResizeElements,f=d.length&&/textarea/i.test(d[0].nodeName),g=f&&e.ui.hasScroll(d[0],"left")?0:a.sizeDiff.height;f={width:a.size.width-(f?0:a.sizeDiff.width),height:a.size.height-g};g=parseInt(a.element.css("left"),10)+(a.position.left-a.originalPosition.left)||null;var h=parseInt(a.element.css("top"),10)+(a.position.top-a.originalPosition.top)||null;a.element.animate(e.extend(f,h&&g?{top:h,left:g}:{}),{duration:c.animateDuration,easing:c.animateEasing, | |
| 184 | +step:function(){var i={width:parseInt(a.element.css("width"),10),height:parseInt(a.element.css("height"),10),top:parseInt(a.element.css("top"),10),left:parseInt(a.element.css("left"),10)};d&&d.length&&e(d[0]).css({width:i.width,height:i.height});a._updateCache(i);a._propagate("resize",b)}})}});e.ui.plugin.add("resizable","containment",{start:function(){var b=e(this).data("resizable"),a=b.element,c=b.options.containment;if(a=c instanceof e?c.get(0):/parent/.test(c)?a.parent().get(0):c){b.containerElement= | |
| 185 | +e(a);if(/document/.test(c)||c==document){b.containerOffset={left:0,top:0};b.containerPosition={left:0,top:0};b.parentData={element:e(document),left:0,top:0,width:e(document).width(),height:e(document).height()||document.body.parentNode.scrollHeight}}else{var d=e(a),f=[];e(["Top","Right","Left","Bottom"]).each(function(i,j){f[i]=m(d.css("padding"+j))});b.containerOffset=d.offset();b.containerPosition=d.position();b.containerSize={height:d.innerHeight()-f[3],width:d.innerWidth()-f[1]};c=b.containerOffset; | |
| 186 | +var g=b.containerSize.height,h=b.containerSize.width;h=e.ui.hasScroll(a,"left")?a.scrollWidth:h;g=e.ui.hasScroll(a)?a.scrollHeight:g;b.parentData={element:a,left:c.left,top:c.top,width:h,height:g}}}},resize:function(b){var a=e(this).data("resizable"),c=a.options,d=a.containerOffset,f=a.position;b=a._aspectRatio||b.shiftKey;var g={top:0,left:0},h=a.containerElement;if(h[0]!=document&&/static/.test(h.css("position")))g=d;if(f.left<(a._helper?d.left:0)){a.size.width+=a._helper?a.position.left-d.left: | |
| 187 | +a.position.left-g.left;if(b)a.size.height=a.size.width/c.aspectRatio;a.position.left=c.helper?d.left:0}if(f.top<(a._helper?d.top:0)){a.size.height+=a._helper?a.position.top-d.top:a.position.top;if(b)a.size.width=a.size.height*c.aspectRatio;a.position.top=a._helper?d.top:0}a.offset.left=a.parentData.left+a.position.left;a.offset.top=a.parentData.top+a.position.top;c=Math.abs((a._helper?a.offset.left-g.left:a.offset.left-g.left)+a.sizeDiff.width);d=Math.abs((a._helper?a.offset.top-g.top:a.offset.top- | |
| 188 | +d.top)+a.sizeDiff.height);f=a.containerElement.get(0)==a.element.parent().get(0);g=/relative|absolute/.test(a.containerElement.css("position"));if(f&&g)c-=a.parentData.left;if(c+a.size.width>=a.parentData.width){a.size.width=a.parentData.width-c;if(b)a.size.height=a.size.width/a.aspectRatio}if(d+a.size.height>=a.parentData.height){a.size.height=a.parentData.height-d;if(b)a.size.width=a.size.height*a.aspectRatio}},stop:function(){var b=e(this).data("resizable"),a=b.options,c=b.containerOffset,d=b.containerPosition, | |
| 189 | +f=b.containerElement,g=e(b.helper),h=g.offset(),i=g.outerWidth()-b.sizeDiff.width;g=g.outerHeight()-b.sizeDiff.height;b._helper&&!a.animate&&/relative/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g});b._helper&&!a.animate&&/static/.test(f.css("position"))&&e(this).css({left:h.left-d.left-c.left,width:i,height:g})}});e.ui.plugin.add("resizable","ghost",{start:function(){var b=e(this).data("resizable"),a=b.options,c=b.size;b.ghost=b.originalElement.clone();b.ghost.css({opacity:0.25, | |
| 190 | +display:"block",position:"relative",height:c.height,width:c.width,margin:0,left:0,top:0}).addClass("ui-resizable-ghost").addClass(typeof a.ghost=="string"?a.ghost:"");b.ghost.appendTo(b.helper)},resize:function(){var b=e(this).data("resizable");b.ghost&&b.ghost.css({position:"relative",height:b.size.height,width:b.size.width})},stop:function(){var b=e(this).data("resizable");b.ghost&&b.helper&&b.helper.get(0).removeChild(b.ghost.get(0))}});e.ui.plugin.add("resizable","grid",{resize:function(){var b= | |
| 191 | +e(this).data("resizable"),a=b.options,c=b.size,d=b.originalSize,f=b.originalPosition,g=b.axis;a.grid=typeof a.grid=="number"?[a.grid,a.grid]:a.grid;var h=Math.round((c.width-d.width)/(a.grid[0]||1))*(a.grid[0]||1);a=Math.round((c.height-d.height)/(a.grid[1]||1))*(a.grid[1]||1);if(/^(se|s|e)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a}else if(/^(ne)$/.test(g)){b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}else{if(/^(sw)$/.test(g)){b.size.width=d.width+h;b.size.height= | |
| 192 | +d.height+a}else{b.size.width=d.width+h;b.size.height=d.height+a;b.position.top=f.top-a}b.position.left=f.left-h}}});var m=function(b){return parseInt(b,10)||0},k=function(b){return!isNaN(parseInt(b,10))}})(jQuery); | |
| 193 | +;/* | |
| 194 | + * jQuery UI Selectable 1.8.16 | |
| 195 | + * | |
| 196 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 197 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 198 | + * http://jquery.org/license | |
| 199 | + * | |
| 200 | + * http://docs.jquery.com/UI/Selectables | |
| 201 | + * | |
| 202 | + * Depends: | |
| 203 | + * jquery.ui.core.js | |
| 204 | + * jquery.ui.mouse.js | |
| 205 | + * jquery.ui.widget.js | |
| 206 | + */ | |
| 207 | +(function(e){e.widget("ui.selectable",e.ui.mouse,{options:{appendTo:"body",autoRefresh:true,distance:0,filter:"*",tolerance:"touch"},_create:function(){var c=this;this.element.addClass("ui-selectable");this.dragged=false;var f;this.refresh=function(){f=e(c.options.filter,c.element[0]);f.each(function(){var d=e(this),b=d.offset();e.data(this,"selectable-item",{element:this,$element:d,left:b.left,top:b.top,right:b.left+d.outerWidth(),bottom:b.top+d.outerHeight(),startselected:false,selected:d.hasClass("ui-selected"), | |
| 208 | +selecting:d.hasClass("ui-selecting"),unselecting:d.hasClass("ui-unselecting")})})};this.refresh();this.selectees=f.addClass("ui-selectee");this._mouseInit();this.helper=e("<div class='ui-selectable-helper'></div>")},destroy:function(){this.selectees.removeClass("ui-selectee").removeData("selectable-item");this.element.removeClass("ui-selectable ui-selectable-disabled").removeData("selectable").unbind(".selectable");this._mouseDestroy();return this},_mouseStart:function(c){var f=this;this.opos=[c.pageX, | |
| 209 | +c.pageY];if(!this.options.disabled){var d=this.options;this.selectees=e(d.filter,this.element[0]);this._trigger("start",c);e(d.appendTo).append(this.helper);this.helper.css({left:c.clientX,top:c.clientY,width:0,height:0});d.autoRefresh&&this.refresh();this.selectees.filter(".ui-selected").each(function(){var b=e.data(this,"selectable-item");b.startselected=true;if(!c.metaKey){b.$element.removeClass("ui-selected");b.selected=false;b.$element.addClass("ui-unselecting");b.unselecting=true;f._trigger("unselecting", | |
| 210 | +c,{unselecting:b.element})}});e(c.target).parents().andSelf().each(function(){var b=e.data(this,"selectable-item");if(b){var g=!c.metaKey||!b.$element.hasClass("ui-selected");b.$element.removeClass(g?"ui-unselecting":"ui-selected").addClass(g?"ui-selecting":"ui-unselecting");b.unselecting=!g;b.selecting=g;(b.selected=g)?f._trigger("selecting",c,{selecting:b.element}):f._trigger("unselecting",c,{unselecting:b.element});return false}})}},_mouseDrag:function(c){var f=this;this.dragged=true;if(!this.options.disabled){var d= | |
| 211 | +this.options,b=this.opos[0],g=this.opos[1],h=c.pageX,i=c.pageY;if(b>h){var j=h;h=b;b=j}if(g>i){j=i;i=g;g=j}this.helper.css({left:b,top:g,width:h-b,height:i-g});this.selectees.each(function(){var a=e.data(this,"selectable-item");if(!(!a||a.element==f.element[0])){var k=false;if(d.tolerance=="touch")k=!(a.left>h||a.right<b||a.top>i||a.bottom<g);else if(d.tolerance=="fit")k=a.left>b&&a.right<h&&a.top>g&&a.bottom<i;if(k){if(a.selected){a.$element.removeClass("ui-selected");a.selected=false}if(a.unselecting){a.$element.removeClass("ui-unselecting"); | |
| 212 | +a.unselecting=false}if(!a.selecting){a.$element.addClass("ui-selecting");a.selecting=true;f._trigger("selecting",c,{selecting:a.element})}}else{if(a.selecting)if(c.metaKey&&a.startselected){a.$element.removeClass("ui-selecting");a.selecting=false;a.$element.addClass("ui-selected");a.selected=true}else{a.$element.removeClass("ui-selecting");a.selecting=false;if(a.startselected){a.$element.addClass("ui-unselecting");a.unselecting=true}f._trigger("unselecting",c,{unselecting:a.element})}if(a.selected)if(!c.metaKey&& | |
| 213 | +!a.startselected){a.$element.removeClass("ui-selected");a.selected=false;a.$element.addClass("ui-unselecting");a.unselecting=true;f._trigger("unselecting",c,{unselecting:a.element})}}}});return false}},_mouseStop:function(c){var f=this;this.dragged=false;e(".ui-unselecting",this.element[0]).each(function(){var d=e.data(this,"selectable-item");d.$element.removeClass("ui-unselecting");d.unselecting=false;d.startselected=false;f._trigger("unselected",c,{unselected:d.element})});e(".ui-selecting",this.element[0]).each(function(){var d= | |
| 214 | +e.data(this,"selectable-item");d.$element.removeClass("ui-selecting").addClass("ui-selected");d.selecting=false;d.selected=true;d.startselected=true;f._trigger("selected",c,{selected:d.element})});this._trigger("stop",c);this.helper.remove();return false}});e.extend(e.ui.selectable,{version:"1.8.16"})})(jQuery); | |
| 215 | +;/* | |
| 216 | + * jQuery UI Sortable 1.8.16 | |
| 217 | + * | |
| 218 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 219 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 220 | + * http://jquery.org/license | |
| 221 | + * | |
| 222 | + * http://docs.jquery.com/UI/Sortables | |
| 223 | + * | |
| 224 | + * Depends: | |
| 225 | + * jquery.ui.core.js | |
| 226 | + * jquery.ui.mouse.js | |
| 227 | + * jquery.ui.widget.js | |
| 228 | + */ | |
| 229 | +(function(d){d.widget("ui.sortable",d.ui.mouse,{widgetEventPrefix:"sort",options:{appendTo:"parent",axis:false,connectWith:false,containment:false,cursor:"auto",cursorAt:false,dropOnEmpty:true,forcePlaceholderSize:false,forceHelperSize:false,grid:false,handle:false,helper:"original",items:"> *",opacity:false,placeholder:false,revert:false,scroll:true,scrollSensitivity:20,scrollSpeed:20,scope:"default",tolerance:"intersect",zIndex:1E3},_create:function(){var a=this.options;this.containerCache={};this.element.addClass("ui-sortable"); | |
| 230 | +this.refresh();this.floating=this.items.length?a.axis==="x"||/left|right/.test(this.items[0].item.css("float"))||/inline|table-cell/.test(this.items[0].item.css("display")):false;this.offset=this.element.offset();this._mouseInit()},destroy:function(){this.element.removeClass("ui-sortable ui-sortable-disabled").removeData("sortable").unbind(".sortable");this._mouseDestroy();for(var a=this.items.length-1;a>=0;a--)this.items[a].item.removeData("sortable-item");return this},_setOption:function(a,b){if(a=== | |
| 231 | +"disabled"){this.options[a]=b;this.widget()[b?"addClass":"removeClass"]("ui-sortable-disabled")}else d.Widget.prototype._setOption.apply(this,arguments)},_mouseCapture:function(a,b){if(this.reverting)return false;if(this.options.disabled||this.options.type=="static")return false;this._refreshItems(a);var c=null,e=this;d(a.target).parents().each(function(){if(d.data(this,"sortable-item")==e){c=d(this);return false}});if(d.data(a.target,"sortable-item")==e)c=d(a.target);if(!c)return false;if(this.options.handle&& | |
| 232 | +!b){var f=false;d(this.options.handle,c).find("*").andSelf().each(function(){if(this==a.target)f=true});if(!f)return false}this.currentItem=c;this._removeCurrentsFromItems();return true},_mouseStart:function(a,b,c){b=this.options;var e=this;this.currentContainer=this;this.refreshPositions();this.helper=this._createHelper(a);this._cacheHelperProportions();this._cacheMargins();this.scrollParent=this.helper.scrollParent();this.offset=this.currentItem.offset();this.offset={top:this.offset.top-this.margins.top, | |
| 233 | +left:this.offset.left-this.margins.left};this.helper.css("position","absolute");this.cssPosition=this.helper.css("position");d.extend(this.offset,{click:{left:a.pageX-this.offset.left,top:a.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()});this.originalPosition=this._generatePosition(a);this.originalPageX=a.pageX;this.originalPageY=a.pageY;b.cursorAt&&this._adjustOffsetFromHelper(b.cursorAt);this.domPosition={prev:this.currentItem.prev()[0],parent:this.currentItem.parent()[0]}; | |
| 234 | +this.helper[0]!=this.currentItem[0]&&this.currentItem.hide();this._createPlaceholder();b.containment&&this._setContainment();if(b.cursor){if(d("body").css("cursor"))this._storedCursor=d("body").css("cursor");d("body").css("cursor",b.cursor)}if(b.opacity){if(this.helper.css("opacity"))this._storedOpacity=this.helper.css("opacity");this.helper.css("opacity",b.opacity)}if(b.zIndex){if(this.helper.css("zIndex"))this._storedZIndex=this.helper.css("zIndex");this.helper.css("zIndex",b.zIndex)}if(this.scrollParent[0]!= | |
| 235 | +document&&this.scrollParent[0].tagName!="HTML")this.overflowOffset=this.scrollParent.offset();this._trigger("start",a,this._uiHash());this._preserveHelperProportions||this._cacheHelperProportions();if(!c)for(c=this.containers.length-1;c>=0;c--)this.containers[c]._trigger("activate",a,e._uiHash(this));if(d.ui.ddmanager)d.ui.ddmanager.current=this;d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this,a);this.dragging=true;this.helper.addClass("ui-sortable-helper");this._mouseDrag(a); | |
| 236 | +return true},_mouseDrag:function(a){this.position=this._generatePosition(a);this.positionAbs=this._convertPositionTo("absolute");if(!this.lastPositionAbs)this.lastPositionAbs=this.positionAbs;if(this.options.scroll){var b=this.options,c=false;if(this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"){if(this.overflowOffset.top+this.scrollParent[0].offsetHeight-a.pageY<b.scrollSensitivity)this.scrollParent[0].scrollTop=c=this.scrollParent[0].scrollTop+b.scrollSpeed;else if(a.pageY-this.overflowOffset.top< | |
| 237 | +b.scrollSensitivity)this.scrollParent[0].scrollTop=c=this.scrollParent[0].scrollTop-b.scrollSpeed;if(this.overflowOffset.left+this.scrollParent[0].offsetWidth-a.pageX<b.scrollSensitivity)this.scrollParent[0].scrollLeft=c=this.scrollParent[0].scrollLeft+b.scrollSpeed;else if(a.pageX-this.overflowOffset.left<b.scrollSensitivity)this.scrollParent[0].scrollLeft=c=this.scrollParent[0].scrollLeft-b.scrollSpeed}else{if(a.pageY-d(document).scrollTop()<b.scrollSensitivity)c=d(document).scrollTop(d(document).scrollTop()- | |
| 238 | +b.scrollSpeed);else if(d(window).height()-(a.pageY-d(document).scrollTop())<b.scrollSensitivity)c=d(document).scrollTop(d(document).scrollTop()+b.scrollSpeed);if(a.pageX-d(document).scrollLeft()<b.scrollSensitivity)c=d(document).scrollLeft(d(document).scrollLeft()-b.scrollSpeed);else if(d(window).width()-(a.pageX-d(document).scrollLeft())<b.scrollSensitivity)c=d(document).scrollLeft(d(document).scrollLeft()+b.scrollSpeed)}c!==false&&d.ui.ddmanager&&!b.dropBehaviour&&d.ui.ddmanager.prepareOffsets(this, | |
| 239 | +a)}this.positionAbs=this._convertPositionTo("absolute");if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";for(b=this.items.length-1;b>=0;b--){c=this.items[b];var e=c.item[0],f=this._intersectsWithPointer(c);if(f)if(e!=this.currentItem[0]&&this.placeholder[f==1?"next":"prev"]()[0]!=e&&!d.ui.contains(this.placeholder[0],e)&&(this.options.type=="semi-dynamic"?!d.ui.contains(this.element[0], | |
| 240 | +e):true)){this.direction=f==1?"down":"up";if(this.options.tolerance=="pointer"||this._intersectsWithSides(c))this._rearrange(a,c);else break;this._trigger("change",a,this._uiHash());break}}this._contactContainers(a);d.ui.ddmanager&&d.ui.ddmanager.drag(this,a);this._trigger("sort",a,this._uiHash());this.lastPositionAbs=this.positionAbs;return false},_mouseStop:function(a,b){if(a){d.ui.ddmanager&&!this.options.dropBehaviour&&d.ui.ddmanager.drop(this,a);if(this.options.revert){var c=this;b=c.placeholder.offset(); | |
| 241 | +c.reverting=true;d(this.helper).animate({left:b.left-this.offset.parent.left-c.margins.left+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollLeft),top:b.top-this.offset.parent.top-c.margins.top+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollTop)},parseInt(this.options.revert,10)||500,function(){c._clear(a)})}else this._clear(a,b);return false}},cancel:function(){var a=this;if(this.dragging){this._mouseUp({target:null});this.options.helper=="original"?this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper"): | |
| 242 | +this.currentItem.show();for(var b=this.containers.length-1;b>=0;b--){this.containers[b]._trigger("deactivate",null,a._uiHash(this));if(this.containers[b].containerCache.over){this.containers[b]._trigger("out",null,a._uiHash(this));this.containers[b].containerCache.over=0}}}if(this.placeholder){this.placeholder[0].parentNode&&this.placeholder[0].parentNode.removeChild(this.placeholder[0]);this.options.helper!="original"&&this.helper&&this.helper[0].parentNode&&this.helper.remove();d.extend(this,{helper:null, | |
| 243 | +dragging:false,reverting:false,_noFinalSort:null});this.domPosition.prev?d(this.domPosition.prev).after(this.currentItem):d(this.domPosition.parent).prepend(this.currentItem)}return this},serialize:function(a){var b=this._getItemsAsjQuery(a&&a.connected),c=[];a=a||{};d(b).each(function(){var e=(d(a.item||this).attr(a.attribute||"id")||"").match(a.expression||/(.+)[-=_](.+)/);if(e)c.push((a.key||e[1]+"[]")+"="+(a.key&&a.expression?e[1]:e[2]))});!c.length&&a.key&&c.push(a.key+"=");return c.join("&")}, | |
| 244 | +toArray:function(a){var b=this._getItemsAsjQuery(a&&a.connected),c=[];a=a||{};b.each(function(){c.push(d(a.item||this).attr(a.attribute||"id")||"")});return c},_intersectsWith:function(a){var b=this.positionAbs.left,c=b+this.helperProportions.width,e=this.positionAbs.top,f=e+this.helperProportions.height,g=a.left,h=g+a.width,i=a.top,k=i+a.height,j=this.offset.click.top,l=this.offset.click.left;j=e+j>i&&e+j<k&&b+l>g&&b+l<h;return this.options.tolerance=="pointer"||this.options.forcePointerForContainers|| | |
| 245 | +this.options.tolerance!="pointer"&&this.helperProportions[this.floating?"width":"height"]>a[this.floating?"width":"height"]?j:g<b+this.helperProportions.width/2&&c-this.helperProportions.width/2<h&&i<e+this.helperProportions.height/2&&f-this.helperProportions.height/2<k},_intersectsWithPointer:function(a){var b=d.ui.isOverAxis(this.positionAbs.top+this.offset.click.top,a.top,a.height);a=d.ui.isOverAxis(this.positionAbs.left+this.offset.click.left,a.left,a.width);b=b&&a;a=this._getDragVerticalDirection(); | |
| 246 | +var c=this._getDragHorizontalDirection();if(!b)return false;return this.floating?c&&c=="right"||a=="down"?2:1:a&&(a=="down"?2:1)},_intersectsWithSides:function(a){var b=d.ui.isOverAxis(this.positionAbs.top+this.offset.click.top,a.top+a.height/2,a.height);a=d.ui.isOverAxis(this.positionAbs.left+this.offset.click.left,a.left+a.width/2,a.width);var c=this._getDragVerticalDirection(),e=this._getDragHorizontalDirection();return this.floating&&e?e=="right"&&a||e=="left"&&!a:c&&(c=="down"&&b||c=="up"&&!b)}, | |
| 247 | +_getDragVerticalDirection:function(){var a=this.positionAbs.top-this.lastPositionAbs.top;return a!=0&&(a>0?"down":"up")},_getDragHorizontalDirection:function(){var a=this.positionAbs.left-this.lastPositionAbs.left;return a!=0&&(a>0?"right":"left")},refresh:function(a){this._refreshItems(a);this.refreshPositions();return this},_connectWith:function(){var a=this.options;return a.connectWith.constructor==String?[a.connectWith]:a.connectWith},_getItemsAsjQuery:function(a){var b=[],c=[],e=this._connectWith(); | |
| 248 | +if(e&&a)for(a=e.length-1;a>=0;a--)for(var f=d(e[a]),g=f.length-1;g>=0;g--){var h=d.data(f[g],"sortable");if(h&&h!=this&&!h.options.disabled)c.push([d.isFunction(h.options.items)?h.options.items.call(h.element):d(h.options.items,h.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"),h])}c.push([d.isFunction(this.options.items)?this.options.items.call(this.element,null,{options:this.options,item:this.currentItem}):d(this.options.items,this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), | |
| 249 | +this]);for(a=c.length-1;a>=0;a--)c[a][0].each(function(){b.push(this)});return d(b)},_removeCurrentsFromItems:function(){for(var a=this.currentItem.find(":data(sortable-item)"),b=0;b<this.items.length;b++)for(var c=0;c<a.length;c++)a[c]==this.items[b].item[0]&&this.items.splice(b,1)},_refreshItems:function(a){this.items=[];this.containers=[this];var b=this.items,c=[[d.isFunction(this.options.items)?this.options.items.call(this.element[0],a,{item:this.currentItem}):d(this.options.items,this.element), | |
| 250 | +this]],e=this._connectWith();if(e)for(var f=e.length-1;f>=0;f--)for(var g=d(e[f]),h=g.length-1;h>=0;h--){var i=d.data(g[h],"sortable");if(i&&i!=this&&!i.options.disabled){c.push([d.isFunction(i.options.items)?i.options.items.call(i.element[0],a,{item:this.currentItem}):d(i.options.items,i.element),i]);this.containers.push(i)}}for(f=c.length-1;f>=0;f--){a=c[f][1];e=c[f][0];h=0;for(g=e.length;h<g;h++){i=d(e[h]);i.data("sortable-item",a);b.push({item:i,instance:a,width:0,height:0,left:0,top:0})}}},refreshPositions:function(a){if(this.offsetParent&& | |
| 251 | +this.helper)this.offset.parent=this._getParentOffset();for(var b=this.items.length-1;b>=0;b--){var c=this.items[b];if(!(c.instance!=this.currentContainer&&this.currentContainer&&c.item[0]!=this.currentItem[0])){var e=this.options.toleranceElement?d(this.options.toleranceElement,c.item):c.item;if(!a){c.width=e.outerWidth();c.height=e.outerHeight()}e=e.offset();c.left=e.left;c.top=e.top}}if(this.options.custom&&this.options.custom.refreshContainers)this.options.custom.refreshContainers.call(this);else for(b= | |
| 252 | +this.containers.length-1;b>=0;b--){e=this.containers[b].element.offset();this.containers[b].containerCache.left=e.left;this.containers[b].containerCache.top=e.top;this.containers[b].containerCache.width=this.containers[b].element.outerWidth();this.containers[b].containerCache.height=this.containers[b].element.outerHeight()}return this},_createPlaceholder:function(a){var b=a||this,c=b.options;if(!c.placeholder||c.placeholder.constructor==String){var e=c.placeholder;c.placeholder={element:function(){var f= | |
| 253 | +d(document.createElement(b.currentItem[0].nodeName)).addClass(e||b.currentItem[0].className+" ui-sortable-placeholder").removeClass("ui-sortable-helper")[0];if(!e)f.style.visibility="hidden";return f},update:function(f,g){if(!(e&&!c.forcePlaceholderSize)){g.height()||g.height(b.currentItem.innerHeight()-parseInt(b.currentItem.css("paddingTop")||0,10)-parseInt(b.currentItem.css("paddingBottom")||0,10));g.width()||g.width(b.currentItem.innerWidth()-parseInt(b.currentItem.css("paddingLeft")||0,10)-parseInt(b.currentItem.css("paddingRight")|| | |
| 254 | +0,10))}}}}b.placeholder=d(c.placeholder.element.call(b.element,b.currentItem));b.currentItem.after(b.placeholder);c.placeholder.update(b,b.placeholder)},_contactContainers:function(a){for(var b=null,c=null,e=this.containers.length-1;e>=0;e--)if(!d.ui.contains(this.currentItem[0],this.containers[e].element[0]))if(this._intersectsWith(this.containers[e].containerCache)){if(!(b&&d.ui.contains(this.containers[e].element[0],b.element[0]))){b=this.containers[e];c=e}}else if(this.containers[e].containerCache.over){this.containers[e]._trigger("out", | |
| 255 | +a,this._uiHash(this));this.containers[e].containerCache.over=0}if(b)if(this.containers.length===1){this.containers[c]._trigger("over",a,this._uiHash(this));this.containers[c].containerCache.over=1}else if(this.currentContainer!=this.containers[c]){b=1E4;e=null;for(var f=this.positionAbs[this.containers[c].floating?"left":"top"],g=this.items.length-1;g>=0;g--)if(d.ui.contains(this.containers[c].element[0],this.items[g].item[0])){var h=this.items[g][this.containers[c].floating?"left":"top"];if(Math.abs(h- | |
| 256 | +f)<b){b=Math.abs(h-f);e=this.items[g]}}if(e||this.options.dropOnEmpty){this.currentContainer=this.containers[c];e?this._rearrange(a,e,null,true):this._rearrange(a,null,this.containers[c].element,true);this._trigger("change",a,this._uiHash());this.containers[c]._trigger("change",a,this._uiHash(this));this.options.placeholder.update(this.currentContainer,this.placeholder);this.containers[c]._trigger("over",a,this._uiHash(this));this.containers[c].containerCache.over=1}}},_createHelper:function(a){var b= | |
| 257 | +this.options;a=d.isFunction(b.helper)?d(b.helper.apply(this.element[0],[a,this.currentItem])):b.helper=="clone"?this.currentItem.clone():this.currentItem;a.parents("body").length||d(b.appendTo!="parent"?b.appendTo:this.currentItem[0].parentNode)[0].appendChild(a[0]);if(a[0]==this.currentItem[0])this._storedCSS={width:this.currentItem[0].style.width,height:this.currentItem[0].style.height,position:this.currentItem.css("position"),top:this.currentItem.css("top"),left:this.currentItem.css("left")};if(a[0].style.width== | |
| 258 | +""||b.forceHelperSize)a.width(this.currentItem.width());if(a[0].style.height==""||b.forceHelperSize)a.height(this.currentItem.height());return a},_adjustOffsetFromHelper:function(a){if(typeof a=="string")a=a.split(" ");if(d.isArray(a))a={left:+a[0],top:+a[1]||0};if("left"in a)this.offset.click.left=a.left+this.margins.left;if("right"in a)this.offset.click.left=this.helperProportions.width-a.right+this.margins.left;if("top"in a)this.offset.click.top=a.top+this.margins.top;if("bottom"in a)this.offset.click.top= | |
| 259 | +this.helperProportions.height-a.bottom+this.margins.top},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var a=this.offsetParent.offset();if(this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0])){a.left+=this.scrollParent.scrollLeft();a.top+=this.scrollParent.scrollTop()}if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&d.browser.msie)a= | |
| 260 | +{top:0,left:0};return{top:a.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:a.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.currentItem.position();return{top:a.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}else return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.currentItem.css("marginLeft"), | |
| 261 | +10)||0,top:parseInt(this.currentItem.css("marginTop"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var a=this.options;if(a.containment=="parent")a.containment=this.helper[0].parentNode;if(a.containment=="document"||a.containment=="window")this.containment=[0-this.offset.relative.left-this.offset.parent.left,0-this.offset.relative.top-this.offset.parent.top,d(a.containment=="document"? | |
| 262 | +document:window).width()-this.helperProportions.width-this.margins.left,(d(a.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(a.containment)){var b=d(a.containment)[0];a=d(a.containment).offset();var c=d(b).css("overflow")!="hidden";this.containment=[a.left+(parseInt(d(b).css("borderLeftWidth"),10)||0)+(parseInt(d(b).css("paddingLeft"),10)||0)-this.margins.left,a.top+(parseInt(d(b).css("borderTopWidth"), | |
| 263 | +10)||0)+(parseInt(d(b).css("paddingTop"),10)||0)-this.margins.top,a.left+(c?Math.max(b.scrollWidth,b.offsetWidth):b.offsetWidth)-(parseInt(d(b).css("borderLeftWidth"),10)||0)-(parseInt(d(b).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left,a.top+(c?Math.max(b.scrollHeight,b.offsetHeight):b.offsetHeight)-(parseInt(d(b).css("borderTopWidth"),10)||0)-(parseInt(d(b).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top]}},_convertPositionTo:function(a,b){if(!b)b= | |
| 264 | +this.position;a=a=="absolute"?1:-1;var c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(c[0].tagName);return{top:b.top+this.offset.relative.top*a+this.offset.parent.top*a-(d.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():e?0:c.scrollTop())*a),left:b.left+this.offset.relative.left*a+this.offset.parent.left*a-(d.browser.safari&& | |
| 265 | +this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():e?0:c.scrollLeft())*a)}},_generatePosition:function(a){var b=this.options,c=this.cssPosition=="absolute"&&!(this.scrollParent[0]!=document&&d.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(c[0].tagName);if(this.cssPosition=="relative"&&!(this.scrollParent[0]!=document&&this.scrollParent[0]!=this.offsetParent[0]))this.offset.relative=this._getRelativeOffset(); | |
| 266 | +var f=a.pageX,g=a.pageY;if(this.originalPosition){if(this.containment){if(a.pageX-this.offset.click.left<this.containment[0])f=this.containment[0]+this.offset.click.left;if(a.pageY-this.offset.click.top<this.containment[1])g=this.containment[1]+this.offset.click.top;if(a.pageX-this.offset.click.left>this.containment[2])f=this.containment[2]+this.offset.click.left;if(a.pageY-this.offset.click.top>this.containment[3])g=this.containment[3]+this.offset.click.top}if(b.grid){g=this.originalPageY+Math.round((g- | |
| 267 | +this.originalPageY)/b.grid[1])*b.grid[1];g=this.containment?!(g-this.offset.click.top<this.containment[1]||g-this.offset.click.top>this.containment[3])?g:!(g-this.offset.click.top<this.containment[1])?g-b.grid[1]:g+b.grid[1]:g;f=this.originalPageX+Math.round((f-this.originalPageX)/b.grid[0])*b.grid[0];f=this.containment?!(f-this.offset.click.left<this.containment[0]||f-this.offset.click.left>this.containment[2])?f:!(f-this.offset.click.left<this.containment[0])?f-b.grid[0]:f+b.grid[0]:f}}return{top:g- | |
| 268 | +this.offset.click.top-this.offset.relative.top-this.offset.parent.top+(d.browser.safari&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollTop():e?0:c.scrollTop()),left:f-this.offset.click.left-this.offset.relative.left-this.offset.parent.left+(d.browser.safari&&this.cssPosition=="fixed"?0:this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():e?0:c.scrollLeft())}},_rearrange:function(a,b,c,e){c?c[0].appendChild(this.placeholder[0]):b.item[0].parentNode.insertBefore(this.placeholder[0], | |
| 269 | +this.direction=="down"?b.item[0]:b.item[0].nextSibling);this.counter=this.counter?++this.counter:1;var f=this,g=this.counter;window.setTimeout(function(){g==f.counter&&f.refreshPositions(!e)},0)},_clear:function(a,b){this.reverting=false;var c=[];!this._noFinalSort&&this.currentItem.parent().length&&this.placeholder.before(this.currentItem);this._noFinalSort=null;if(this.helper[0]==this.currentItem[0]){for(var e in this._storedCSS)if(this._storedCSS[e]=="auto"||this._storedCSS[e]=="static")this._storedCSS[e]= | |
| 270 | +"";this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper")}else this.currentItem.show();this.fromOutside&&!b&&c.push(function(f){this._trigger("receive",f,this._uiHash(this.fromOutside))});if((this.fromOutside||this.domPosition.prev!=this.currentItem.prev().not(".ui-sortable-helper")[0]||this.domPosition.parent!=this.currentItem.parent()[0])&&!b)c.push(function(f){this._trigger("update",f,this._uiHash())});if(!d.ui.contains(this.element[0],this.currentItem[0])){b||c.push(function(f){this._trigger("remove", | |
| 271 | +f,this._uiHash())});for(e=this.containers.length-1;e>=0;e--)if(d.ui.contains(this.containers[e].element[0],this.currentItem[0])&&!b){c.push(function(f){return function(g){f._trigger("receive",g,this._uiHash(this))}}.call(this,this.containers[e]));c.push(function(f){return function(g){f._trigger("update",g,this._uiHash(this))}}.call(this,this.containers[e]))}}for(e=this.containers.length-1;e>=0;e--){b||c.push(function(f){return function(g){f._trigger("deactivate",g,this._uiHash(this))}}.call(this, | |
| 272 | +this.containers[e]));if(this.containers[e].containerCache.over){c.push(function(f){return function(g){f._trigger("out",g,this._uiHash(this))}}.call(this,this.containers[e]));this.containers[e].containerCache.over=0}}this._storedCursor&&d("body").css("cursor",this._storedCursor);this._storedOpacity&&this.helper.css("opacity",this._storedOpacity);if(this._storedZIndex)this.helper.css("zIndex",this._storedZIndex=="auto"?"":this._storedZIndex);this.dragging=false;if(this.cancelHelperRemoval){if(!b){this._trigger("beforeStop", | |
| 273 | +a,this._uiHash());for(e=0;e<c.length;e++)c[e].call(this,a);this._trigger("stop",a,this._uiHash())}return false}b||this._trigger("beforeStop",a,this._uiHash());this.placeholder[0].parentNode.removeChild(this.placeholder[0]);this.helper[0]!=this.currentItem[0]&&this.helper.remove();this.helper=null;if(!b){for(e=0;e<c.length;e++)c[e].call(this,a);this._trigger("stop",a,this._uiHash())}this.fromOutside=false;return true},_trigger:function(){d.Widget.prototype._trigger.apply(this,arguments)===false&&this.cancel()}, | |
| 274 | +_uiHash:function(a){var b=a||this;return{helper:b.helper,placeholder:b.placeholder||d([]),position:b.position,originalPosition:b.originalPosition,offset:b.positionAbs,item:b.currentItem,sender:a?a.element:null}}});d.extend(d.ui.sortable,{version:"1.8.16"})})(jQuery); | |
| 275 | +;/* | |
| 276 | + * jQuery UI Accordion 1.8.16 | |
| 277 | + * | |
| 278 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 279 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 280 | + * http://jquery.org/license | |
| 281 | + * | |
| 282 | + * http://docs.jquery.com/UI/Accordion | |
| 283 | + * | |
| 284 | + * Depends: | |
| 285 | + * jquery.ui.core.js | |
| 286 | + * jquery.ui.widget.js | |
| 287 | + */ | |
| 288 | +(function(c){c.widget("ui.accordion",{options:{active:0,animated:"slide",autoHeight:true,clearStyle:false,collapsible:false,event:"click",fillSpace:false,header:"> li > :first-child,> :not(li):even",icons:{header:"ui-icon-triangle-1-e",headerSelected:"ui-icon-triangle-1-s"},navigation:false,navigationFilter:function(){return this.href.toLowerCase()===location.href.toLowerCase()}},_create:function(){var a=this,b=a.options;a.running=0;a.element.addClass("ui-accordion ui-widget ui-helper-reset").children("li").addClass("ui-accordion-li-fix"); | |
| 289 | +a.headers=a.element.find(b.header).addClass("ui-accordion-header ui-helper-reset ui-state-default ui-corner-all").bind("mouseenter.accordion",function(){b.disabled||c(this).addClass("ui-state-hover")}).bind("mouseleave.accordion",function(){b.disabled||c(this).removeClass("ui-state-hover")}).bind("focus.accordion",function(){b.disabled||c(this).addClass("ui-state-focus")}).bind("blur.accordion",function(){b.disabled||c(this).removeClass("ui-state-focus")});a.headers.next().addClass("ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom"); | |
| 290 | +if(b.navigation){var d=a.element.find("a").filter(b.navigationFilter).eq(0);if(d.length){var h=d.closest(".ui-accordion-header");a.active=h.length?h:d.closest(".ui-accordion-content").prev()}}a.active=a._findActive(a.active||b.active).addClass("ui-state-default ui-state-active").toggleClass("ui-corner-all").toggleClass("ui-corner-top");a.active.next().addClass("ui-accordion-content-active");a._createIcons();a.resize();a.element.attr("role","tablist");a.headers.attr("role","tab").bind("keydown.accordion", | |
| 291 | +function(f){return a._keydown(f)}).next().attr("role","tabpanel");a.headers.not(a.active||"").attr({"aria-expanded":"false","aria-selected":"false",tabIndex:-1}).next().hide();a.active.length?a.active.attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}):a.headers.eq(0).attr("tabIndex",0);c.browser.safari||a.headers.find("a").attr("tabIndex",-1);b.event&&a.headers.bind(b.event.split(" ").join(".accordion ")+".accordion",function(f){a._clickHandler.call(a,f,this);f.preventDefault()})},_createIcons:function(){var a= | |
| 292 | +this.options;if(a.icons){c("<span></span>").addClass("ui-icon "+a.icons.header).prependTo(this.headers);this.active.children(".ui-icon").toggleClass(a.icons.header).toggleClass(a.icons.headerSelected);this.element.addClass("ui-accordion-icons")}},_destroyIcons:function(){this.headers.children(".ui-icon").remove();this.element.removeClass("ui-accordion-icons")},destroy:function(){var a=this.options;this.element.removeClass("ui-accordion ui-widget ui-helper-reset").removeAttr("role");this.headers.unbind(".accordion").removeClass("ui-accordion-header ui-accordion-disabled ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top").removeAttr("role").removeAttr("aria-expanded").removeAttr("aria-selected").removeAttr("tabIndex"); | |
| 293 | +this.headers.find("a").removeAttr("tabIndex");this._destroyIcons();var b=this.headers.next().css("display","").removeAttr("role").removeClass("ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-accordion-disabled ui-state-disabled");if(a.autoHeight||a.fillHeight)b.css("height","");return c.Widget.prototype.destroy.call(this)},_setOption:function(a,b){c.Widget.prototype._setOption.apply(this,arguments);a=="active"&&this.activate(b);if(a=="icons"){this._destroyIcons(); | |
| 294 | +b&&this._createIcons()}if(a=="disabled")this.headers.add(this.headers.next())[b?"addClass":"removeClass"]("ui-accordion-disabled ui-state-disabled")},_keydown:function(a){if(!(this.options.disabled||a.altKey||a.ctrlKey)){var b=c.ui.keyCode,d=this.headers.length,h=this.headers.index(a.target),f=false;switch(a.keyCode){case b.RIGHT:case b.DOWN:f=this.headers[(h+1)%d];break;case b.LEFT:case b.UP:f=this.headers[(h-1+d)%d];break;case b.SPACE:case b.ENTER:this._clickHandler({target:a.target},a.target); | |
| 295 | +a.preventDefault()}if(f){c(a.target).attr("tabIndex",-1);c(f).attr("tabIndex",0);f.focus();return false}return true}},resize:function(){var a=this.options,b;if(a.fillSpace){if(c.browser.msie){var d=this.element.parent().css("overflow");this.element.parent().css("overflow","hidden")}b=this.element.parent().height();c.browser.msie&&this.element.parent().css("overflow",d);this.headers.each(function(){b-=c(this).outerHeight(true)});this.headers.next().each(function(){c(this).height(Math.max(0,b-c(this).innerHeight()+ | |
| 296 | +c(this).height()))}).css("overflow","auto")}else if(a.autoHeight){b=0;this.headers.next().each(function(){b=Math.max(b,c(this).height("").height())}).height(b)}return this},activate:function(a){this.options.active=a;a=this._findActive(a)[0];this._clickHandler({target:a},a);return this},_findActive:function(a){return a?typeof a==="number"?this.headers.filter(":eq("+a+")"):this.headers.not(this.headers.not(a)):a===false?c([]):this.headers.filter(":eq(0)")},_clickHandler:function(a,b){var d=this.options; | |
| 297 | +if(!d.disabled)if(a.target){a=c(a.currentTarget||b);b=a[0]===this.active[0];d.active=d.collapsible&&b?false:this.headers.index(a);if(!(this.running||!d.collapsible&&b)){var h=this.active;j=a.next();g=this.active.next();e={options:d,newHeader:b&&d.collapsible?c([]):a,oldHeader:this.active,newContent:b&&d.collapsible?c([]):j,oldContent:g};var f=this.headers.index(this.active[0])>this.headers.index(a[0]);this.active=b?c([]):a;this._toggle(j,g,e,b,f);h.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header); | |
| 298 | +if(!b){a.removeClass("ui-state-default ui-corner-all").addClass("ui-state-active ui-corner-top").children(".ui-icon").removeClass(d.icons.header).addClass(d.icons.headerSelected);a.next().addClass("ui-accordion-content-active")}}}else if(d.collapsible){this.active.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header);this.active.next().addClass("ui-accordion-content-active");var g=this.active.next(), | |
| 299 | +e={options:d,newHeader:c([]),oldHeader:d.active,newContent:c([]),oldContent:g},j=this.active=c([]);this._toggle(j,g,e)}},_toggle:function(a,b,d,h,f){var g=this,e=g.options;g.toShow=a;g.toHide=b;g.data=d;var j=function(){if(g)return g._completed.apply(g,arguments)};g._trigger("changestart",null,g.data);g.running=b.size()===0?a.size():b.size();if(e.animated){d={};d=e.collapsible&&h?{toShow:c([]),toHide:b,complete:j,down:f,autoHeight:e.autoHeight||e.fillSpace}:{toShow:a,toHide:b,complete:j,down:f,autoHeight:e.autoHeight|| | |
| 300 | +e.fillSpace};if(!e.proxied)e.proxied=e.animated;if(!e.proxiedDuration)e.proxiedDuration=e.duration;e.animated=c.isFunction(e.proxied)?e.proxied(d):e.proxied;e.duration=c.isFunction(e.proxiedDuration)?e.proxiedDuration(d):e.proxiedDuration;h=c.ui.accordion.animations;var i=e.duration,k=e.animated;if(k&&!h[k]&&!c.easing[k])k="slide";h[k]||(h[k]=function(l){this.slide(l,{easing:k,duration:i||700})});h[k](d)}else{if(e.collapsible&&h)a.toggle();else{b.hide();a.show()}j(true)}b.prev().attr({"aria-expanded":"false", | |
| 301 | +"aria-selected":"false",tabIndex:-1}).blur();a.prev().attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}).focus()},_completed:function(a){this.running=a?0:--this.running;if(!this.running){this.options.clearStyle&&this.toShow.add(this.toHide).css({height:"",overflow:""});this.toHide.removeClass("ui-accordion-content-active");if(this.toHide.length)this.toHide.parent()[0].className=this.toHide.parent()[0].className;this._trigger("change",null,this.data)}}});c.extend(c.ui.accordion,{version:"1.8.16", | |
| 302 | +animations:{slide:function(a,b){a=c.extend({easing:"swing",duration:300},a,b);if(a.toHide.size())if(a.toShow.size()){var d=a.toShow.css("overflow"),h=0,f={},g={},e;b=a.toShow;e=b[0].style.width;b.width(parseInt(b.parent().width(),10)-parseInt(b.css("paddingLeft"),10)-parseInt(b.css("paddingRight"),10)-(parseInt(b.css("borderLeftWidth"),10)||0)-(parseInt(b.css("borderRightWidth"),10)||0));c.each(["height","paddingTop","paddingBottom"],function(j,i){g[i]="hide";j=(""+c.css(a.toShow[0],i)).match(/^([\d+-.]+)(.*)$/); | |
| 303 | +f[i]={value:j[1],unit:j[2]||"px"}});a.toShow.css({height:0,overflow:"hidden"}).show();a.toHide.filter(":hidden").each(a.complete).end().filter(":visible").animate(g,{step:function(j,i){if(i.prop=="height")h=i.end-i.start===0?0:(i.now-i.start)/(i.end-i.start);a.toShow[0].style[i.prop]=h*f[i.prop].value+f[i.prop].unit},duration:a.duration,easing:a.easing,complete:function(){a.autoHeight||a.toShow.css("height","");a.toShow.css({width:e,overflow:d});a.complete()}})}else a.toHide.animate({height:"hide", | |
| 304 | +paddingTop:"hide",paddingBottom:"hide"},a);else a.toShow.animate({height:"show",paddingTop:"show",paddingBottom:"show"},a)},bounceslide:function(a){this.slide(a,{easing:a.down?"easeOutBounce":"swing",duration:a.down?1E3:200})}}})})(jQuery); | |
| 305 | +;/* | |
| 306 | + * jQuery UI Autocomplete 1.8.16 | |
| 307 | + * | |
| 308 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 309 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 310 | + * http://jquery.org/license | |
| 311 | + * | |
| 312 | + * http://docs.jquery.com/UI/Autocomplete | |
| 313 | + * | |
| 314 | + * Depends: | |
| 315 | + * jquery.ui.core.js | |
| 316 | + * jquery.ui.widget.js | |
| 317 | + * jquery.ui.position.js | |
| 318 | + */ | |
| 319 | +(function(d){var e=0;d.widget("ui.autocomplete",{options:{appendTo:"body",autoFocus:false,delay:300,minLength:1,position:{my:"left top",at:"left bottom",collision:"none"},source:null},pending:0,_create:function(){var a=this,b=this.element[0].ownerDocument,g;this.element.addClass("ui-autocomplete-input").attr("autocomplete","off").attr({role:"textbox","aria-autocomplete":"list","aria-haspopup":"true"}).bind("keydown.autocomplete",function(c){if(!(a.options.disabled||a.element.propAttr("readOnly"))){g= | |
| 320 | +false;var f=d.ui.keyCode;switch(c.keyCode){case f.PAGE_UP:a._move("previousPage",c);break;case f.PAGE_DOWN:a._move("nextPage",c);break;case f.UP:a._move("previous",c);c.preventDefault();break;case f.DOWN:a._move("next",c);c.preventDefault();break;case f.ENTER:case f.NUMPAD_ENTER:if(a.menu.active){g=true;c.preventDefault()}case f.TAB:if(!a.menu.active)return;a.menu.select(c);break;case f.ESCAPE:a.element.val(a.term);a.close(c);break;default:clearTimeout(a.searching);a.searching=setTimeout(function(){if(a.term!= | |
| 321 | +a.element.val()){a.selectedItem=null;a.search(null,c)}},a.options.delay);break}}}).bind("keypress.autocomplete",function(c){if(g){g=false;c.preventDefault()}}).bind("focus.autocomplete",function(){if(!a.options.disabled){a.selectedItem=null;a.previous=a.element.val()}}).bind("blur.autocomplete",function(c){if(!a.options.disabled){clearTimeout(a.searching);a.closing=setTimeout(function(){a.close(c);a._change(c)},150)}});this._initSource();this.response=function(){return a._response.apply(a,arguments)}; | |
| 322 | +this.menu=d("<ul></ul>").addClass("ui-autocomplete").appendTo(d(this.options.appendTo||"body",b)[0]).mousedown(function(c){var f=a.menu.element[0];d(c.target).closest(".ui-menu-item").length||setTimeout(function(){d(document).one("mousedown",function(h){h.target!==a.element[0]&&h.target!==f&&!d.ui.contains(f,h.target)&&a.close()})},1);setTimeout(function(){clearTimeout(a.closing)},13)}).menu({focus:function(c,f){f=f.item.data("item.autocomplete");false!==a._trigger("focus",c,{item:f})&&/^key/.test(c.originalEvent.type)&& | |
| 323 | +a.element.val(f.value)},selected:function(c,f){var h=f.item.data("item.autocomplete"),i=a.previous;if(a.element[0]!==b.activeElement){a.element.focus();a.previous=i;setTimeout(function(){a.previous=i;a.selectedItem=h},1)}false!==a._trigger("select",c,{item:h})&&a.element.val(h.value);a.term=a.element.val();a.close(c);a.selectedItem=h},blur:function(){a.menu.element.is(":visible")&&a.element.val()!==a.term&&a.element.val(a.term)}}).zIndex(this.element.zIndex()+1).css({top:0,left:0}).hide().data("menu"); | |
| 324 | +d.fn.bgiframe&&this.menu.element.bgiframe()},destroy:function(){this.element.removeClass("ui-autocomplete-input").removeAttr("autocomplete").removeAttr("role").removeAttr("aria-autocomplete").removeAttr("aria-haspopup");this.menu.element.remove();d.Widget.prototype.destroy.call(this)},_setOption:function(a,b){d.Widget.prototype._setOption.apply(this,arguments);a==="source"&&this._initSource();if(a==="appendTo")this.menu.element.appendTo(d(b||"body",this.element[0].ownerDocument)[0]);a==="disabled"&& | |
| 325 | +b&&this.xhr&&this.xhr.abort()},_initSource:function(){var a=this,b,g;if(d.isArray(this.options.source)){b=this.options.source;this.source=function(c,f){f(d.ui.autocomplete.filter(b,c.term))}}else if(typeof this.options.source==="string"){g=this.options.source;this.source=function(c,f){a.xhr&&a.xhr.abort();a.xhr=d.ajax({url:g,data:c,dataType:"json",autocompleteRequest:++e,success:function(h){this.autocompleteRequest===e&&f(h)},error:function(){this.autocompleteRequest===e&&f([])}})}}else this.source= | |
| 326 | +this.options.source},search:function(a,b){a=a!=null?a:this.element.val();this.term=this.element.val();if(a.length<this.options.minLength)return this.close(b);clearTimeout(this.closing);if(this._trigger("search",b)!==false)return this._search(a)},_search:function(a){this.pending++;this.element.addClass("ui-autocomplete-loading");this.source({term:a},this.response)},_response:function(a){if(!this.options.disabled&&a&&a.length){a=this._normalize(a);this._suggest(a);this._trigger("open")}else this.close(); | |
| 327 | +this.pending--;this.pending||this.element.removeClass("ui-autocomplete-loading")},close:function(a){clearTimeout(this.closing);if(this.menu.element.is(":visible")){this.menu.element.hide();this.menu.deactivate();this._trigger("close",a)}},_change:function(a){this.previous!==this.element.val()&&this._trigger("change",a,{item:this.selectedItem})},_normalize:function(a){if(a.length&&a[0].label&&a[0].value)return a;return d.map(a,function(b){if(typeof b==="string")return{label:b,value:b};return d.extend({label:b.label|| | |
| 328 | +b.value,value:b.value||b.label},b)})},_suggest:function(a){var b=this.menu.element.empty().zIndex(this.element.zIndex()+1);this._renderMenu(b,a);this.menu.deactivate();this.menu.refresh();b.show();this._resizeMenu();b.position(d.extend({of:this.element},this.options.position));this.options.autoFocus&&this.menu.next(new d.Event("mouseover"))},_resizeMenu:function(){var a=this.menu.element;a.outerWidth(Math.max(a.width("").outerWidth(),this.element.outerWidth()))},_renderMenu:function(a,b){var g=this; | |
| 329 | +d.each(b,function(c,f){g._renderItem(a,f)})},_renderItem:function(a,b){return d("<li></li>").data("item.autocomplete",b).append(d("<a></a>").text(b.label)).appendTo(a)},_move:function(a,b){if(this.menu.element.is(":visible"))if(this.menu.first()&&/^previous/.test(a)||this.menu.last()&&/^next/.test(a)){this.element.val(this.term);this.menu.deactivate()}else this.menu[a](b);else this.search(null,b)},widget:function(){return this.menu.element}});d.extend(d.ui.autocomplete,{escapeRegex:function(a){return a.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, | |
| 330 | +"\\$&")},filter:function(a,b){var g=new RegExp(d.ui.autocomplete.escapeRegex(b),"i");return d.grep(a,function(c){return g.test(c.label||c.value||c)})}})})(jQuery); | |
| 331 | +(function(d){d.widget("ui.menu",{_create:function(){var e=this;this.element.addClass("ui-menu ui-widget ui-widget-content ui-corner-all").attr({role:"listbox","aria-activedescendant":"ui-active-menuitem"}).click(function(a){if(d(a.target).closest(".ui-menu-item a").length){a.preventDefault();e.select(a)}});this.refresh()},refresh:function(){var e=this;this.element.children("li:not(.ui-menu-item):has(a)").addClass("ui-menu-item").attr("role","menuitem").children("a").addClass("ui-corner-all").attr("tabindex", | |
| 332 | +-1).mouseenter(function(a){e.activate(a,d(this).parent())}).mouseleave(function(){e.deactivate()})},activate:function(e,a){this.deactivate();if(this.hasScroll()){var b=a.offset().top-this.element.offset().top,g=this.element.scrollTop(),c=this.element.height();if(b<0)this.element.scrollTop(g+b);else b>=c&&this.element.scrollTop(g+b-c+a.height())}this.active=a.eq(0).children("a").addClass("ui-state-hover").attr("id","ui-active-menuitem").end();this._trigger("focus",e,{item:a})},deactivate:function(){if(this.active){this.active.children("a").removeClass("ui-state-hover").removeAttr("id"); | |
| 333 | +this._trigger("blur");this.active=null}},next:function(e){this.move("next",".ui-menu-item:first",e)},previous:function(e){this.move("prev",".ui-menu-item:last",e)},first:function(){return this.active&&!this.active.prevAll(".ui-menu-item").length},last:function(){return this.active&&!this.active.nextAll(".ui-menu-item").length},move:function(e,a,b){if(this.active){e=this.active[e+"All"](".ui-menu-item").eq(0);e.length?this.activate(b,e):this.activate(b,this.element.children(a))}else this.activate(b, | |
| 334 | +this.element.children(a))},nextPage:function(e){if(this.hasScroll())if(!this.active||this.last())this.activate(e,this.element.children(".ui-menu-item:first"));else{var a=this.active.offset().top,b=this.element.height(),g=this.element.children(".ui-menu-item").filter(function(){var c=d(this).offset().top-a-b+d(this).height();return c<10&&c>-10});g.length||(g=this.element.children(".ui-menu-item:last"));this.activate(e,g)}else this.activate(e,this.element.children(".ui-menu-item").filter(!this.active|| | |
| 335 | +this.last()?":first":":last"))},previousPage:function(e){if(this.hasScroll())if(!this.active||this.first())this.activate(e,this.element.children(".ui-menu-item:last"));else{var a=this.active.offset().top,b=this.element.height();result=this.element.children(".ui-menu-item").filter(function(){var g=d(this).offset().top-a+b-d(this).height();return g<10&&g>-10});result.length||(result=this.element.children(".ui-menu-item:first"));this.activate(e,result)}else this.activate(e,this.element.children(".ui-menu-item").filter(!this.active|| | |
| 336 | +this.first()?":last":":first"))},hasScroll:function(){return this.element.height()<this.element[d.fn.prop?"prop":"attr"]("scrollHeight")},select:function(e){this._trigger("selected",e,{item:this.active})}})})(jQuery); | |
| 337 | +;/* | |
| 338 | + * jQuery UI Button 1.8.16 | |
| 339 | + * | |
| 340 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 341 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 342 | + * http://jquery.org/license | |
| 343 | + * | |
| 344 | + * http://docs.jquery.com/UI/Button | |
| 345 | + * | |
| 346 | + * Depends: | |
| 347 | + * jquery.ui.core.js | |
| 348 | + * jquery.ui.widget.js | |
| 349 | + */ | |
| 350 | +(function(b){var h,i,j,g,l=function(){var a=b(this).find(":ui-button");setTimeout(function(){a.button("refresh")},1)},k=function(a){var c=a.name,e=a.form,f=b([]);if(c)f=e?b(e).find("[name='"+c+"']"):b("[name='"+c+"']",a.ownerDocument).filter(function(){return!this.form});return f};b.widget("ui.button",{options:{disabled:null,text:true,label:null,icons:{primary:null,secondary:null}},_create:function(){this.element.closest("form").unbind("reset.button").bind("reset.button",l);if(typeof this.options.disabled!== | |
| 351 | +"boolean")this.options.disabled=this.element.propAttr("disabled");this._determineButtonType();this.hasTitle=!!this.buttonElement.attr("title");var a=this,c=this.options,e=this.type==="checkbox"||this.type==="radio",f="ui-state-hover"+(!e?" ui-state-active":"");if(c.label===null)c.label=this.buttonElement.html();if(this.element.is(":disabled"))c.disabled=true;this.buttonElement.addClass("ui-button ui-widget ui-state-default ui-corner-all").attr("role","button").bind("mouseenter.button",function(){if(!c.disabled){b(this).addClass("ui-state-hover"); | |
| 352 | +this===h&&b(this).addClass("ui-state-active")}}).bind("mouseleave.button",function(){c.disabled||b(this).removeClass(f)}).bind("click.button",function(d){if(c.disabled){d.preventDefault();d.stopImmediatePropagation()}});this.element.bind("focus.button",function(){a.buttonElement.addClass("ui-state-focus")}).bind("blur.button",function(){a.buttonElement.removeClass("ui-state-focus")});if(e){this.element.bind("change.button",function(){g||a.refresh()});this.buttonElement.bind("mousedown.button",function(d){if(!c.disabled){g= | |
| 353 | +false;i=d.pageX;j=d.pageY}}).bind("mouseup.button",function(d){if(!c.disabled)if(i!==d.pageX||j!==d.pageY)g=true})}if(this.type==="checkbox")this.buttonElement.bind("click.button",function(){if(c.disabled||g)return false;b(this).toggleClass("ui-state-active");a.buttonElement.attr("aria-pressed",a.element[0].checked)});else if(this.type==="radio")this.buttonElement.bind("click.button",function(){if(c.disabled||g)return false;b(this).addClass("ui-state-active");a.buttonElement.attr("aria-pressed","true"); | |
| 354 | +var d=a.element[0];k(d).not(d).map(function(){return b(this).button("widget")[0]}).removeClass("ui-state-active").attr("aria-pressed","false")});else{this.buttonElement.bind("mousedown.button",function(){if(c.disabled)return false;b(this).addClass("ui-state-active");h=this;b(document).one("mouseup",function(){h=null})}).bind("mouseup.button",function(){if(c.disabled)return false;b(this).removeClass("ui-state-active")}).bind("keydown.button",function(d){if(c.disabled)return false;if(d.keyCode==b.ui.keyCode.SPACE|| | |
| 355 | +d.keyCode==b.ui.keyCode.ENTER)b(this).addClass("ui-state-active")}).bind("keyup.button",function(){b(this).removeClass("ui-state-active")});this.buttonElement.is("a")&&this.buttonElement.keyup(function(d){d.keyCode===b.ui.keyCode.SPACE&&b(this).click()})}this._setOption("disabled",c.disabled);this._resetButton()},_determineButtonType:function(){this.type=this.element.is(":checkbox")?"checkbox":this.element.is(":radio")?"radio":this.element.is("input")?"input":"button";if(this.type==="checkbox"||this.type=== | |
| 356 | +"radio"){var a=this.element.parents().filter(":last"),c="label[for='"+this.element.attr("id")+"']";this.buttonElement=a.find(c);if(!this.buttonElement.length){a=a.length?a.siblings():this.element.siblings();this.buttonElement=a.filter(c);if(!this.buttonElement.length)this.buttonElement=a.find(c)}this.element.addClass("ui-helper-hidden-accessible");(a=this.element.is(":checked"))&&this.buttonElement.addClass("ui-state-active");this.buttonElement.attr("aria-pressed",a)}else this.buttonElement=this.element}, | |
| 357 | +widget:function(){return this.buttonElement},destroy:function(){this.element.removeClass("ui-helper-hidden-accessible");this.buttonElement.removeClass("ui-button ui-widget ui-state-default ui-corner-all ui-state-hover ui-state-active ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only").removeAttr("role").removeAttr("aria-pressed").html(this.buttonElement.find(".ui-button-text").html());this.hasTitle||this.buttonElement.removeAttr("title"); | |
| 358 | +b.Widget.prototype.destroy.call(this)},_setOption:function(a,c){b.Widget.prototype._setOption.apply(this,arguments);if(a==="disabled")c?this.element.propAttr("disabled",true):this.element.propAttr("disabled",false);else this._resetButton()},refresh:function(){var a=this.element.is(":disabled");a!==this.options.disabled&&this._setOption("disabled",a);if(this.type==="radio")k(this.element[0]).each(function(){b(this).is(":checked")?b(this).button("widget").addClass("ui-state-active").attr("aria-pressed", | |
| 359 | +"true"):b(this).button("widget").removeClass("ui-state-active").attr("aria-pressed","false")});else if(this.type==="checkbox")this.element.is(":checked")?this.buttonElement.addClass("ui-state-active").attr("aria-pressed","true"):this.buttonElement.removeClass("ui-state-active").attr("aria-pressed","false")},_resetButton:function(){if(this.type==="input")this.options.label&&this.element.val(this.options.label);else{var a=this.buttonElement.removeClass("ui-button-icons-only ui-button-icon-only ui-button-text-icons ui-button-text-icon-primary ui-button-text-icon-secondary ui-button-text-only"), | |
| 360 | +c=b("<span></span>").addClass("ui-button-text").html(this.options.label).appendTo(a.empty()).text(),e=this.options.icons,f=e.primary&&e.secondary,d=[];if(e.primary||e.secondary){if(this.options.text)d.push("ui-button-text-icon"+(f?"s":e.primary?"-primary":"-secondary"));e.primary&&a.prepend("<span class='ui-button-icon-primary ui-icon "+e.primary+"'></span>");e.secondary&&a.append("<span class='ui-button-icon-secondary ui-icon "+e.secondary+"'></span>");if(!this.options.text){d.push(f?"ui-button-icons-only": | |
| 361 | +"ui-button-icon-only");this.hasTitle||a.attr("title",c)}}else d.push("ui-button-text-only");a.addClass(d.join(" "))}}});b.widget("ui.buttonset",{options:{items:":button, :submit, :reset, :checkbox, :radio, a, :data(button)"},_create:function(){this.element.addClass("ui-buttonset")},_init:function(){this.refresh()},_setOption:function(a,c){a==="disabled"&&this.buttons.button("option",a,c);b.Widget.prototype._setOption.apply(this,arguments)},refresh:function(){var a=this.element.css("direction")=== | |
| 362 | +"ltr";this.buttons=this.element.find(this.options.items).filter(":ui-button").button("refresh").end().not(":ui-button").button().end().map(function(){return b(this).button("widget")[0]}).removeClass("ui-corner-all ui-corner-left ui-corner-right").filter(":first").addClass(a?"ui-corner-left":"ui-corner-right").end().filter(":last").addClass(a?"ui-corner-right":"ui-corner-left").end().end()},destroy:function(){this.element.removeClass("ui-buttonset");this.buttons.map(function(){return b(this).button("widget")[0]}).removeClass("ui-corner-left ui-corner-right").end().button("destroy"); | |
| 363 | +b.Widget.prototype.destroy.call(this)}})})(jQuery); | |
| 364 | +;/* | |
| 365 | + * jQuery UI Dialog 1.8.16 | |
| 366 | + * | |
| 367 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 368 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 369 | + * http://jquery.org/license | |
| 370 | + * | |
| 371 | + * http://docs.jquery.com/UI/Dialog | |
| 372 | + * | |
| 373 | + * Depends: | |
| 374 | + * jquery.ui.core.js | |
| 375 | + * jquery.ui.widget.js | |
| 376 | + * jquery.ui.button.js | |
| 377 | + * jquery.ui.draggable.js | |
| 378 | + * jquery.ui.mouse.js | |
| 379 | + * jquery.ui.position.js | |
| 380 | + * jquery.ui.resizable.js | |
| 381 | + */ | |
| 382 | +(function(c,l){var m={buttons:true,height:true,maxHeight:true,maxWidth:true,minHeight:true,minWidth:true,width:true},n={maxHeight:true,maxWidth:true,minHeight:true,minWidth:true},o=c.attrFn||{val:true,css:true,html:true,text:true,data:true,width:true,height:true,offset:true,click:true};c.widget("ui.dialog",{options:{autoOpen:true,buttons:{},closeOnEscape:true,closeText:"close",dialogClass:"",draggable:true,hide:null,height:"auto",maxHeight:false,maxWidth:false,minHeight:150,minWidth:150,modal:false, | |
| 383 | +position:{my:"center",at:"center",collision:"fit",using:function(a){var b=c(this).css(a).offset().top;b<0&&c(this).css("top",a.top-b)}},resizable:true,show:null,stack:true,title:"",width:300,zIndex:1E3},_create:function(){this.originalTitle=this.element.attr("title");if(typeof this.originalTitle!=="string")this.originalTitle="";this.options.title=this.options.title||this.originalTitle;var a=this,b=a.options,d=b.title||" ",e=c.ui.dialog.getTitleId(a.element),g=(a.uiDialog=c("<div></div>")).appendTo(document.body).hide().addClass("ui-dialog ui-widget ui-widget-content ui-corner-all "+ | |
| 384 | +b.dialogClass).css({zIndex:b.zIndex}).attr("tabIndex",-1).css("outline",0).keydown(function(i){if(b.closeOnEscape&&!i.isDefaultPrevented()&&i.keyCode&&i.keyCode===c.ui.keyCode.ESCAPE){a.close(i);i.preventDefault()}}).attr({role:"dialog","aria-labelledby":e}).mousedown(function(i){a.moveToTop(false,i)});a.element.show().removeAttr("title").addClass("ui-dialog-content ui-widget-content").appendTo(g);var f=(a.uiDialogTitlebar=c("<div></div>")).addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix").prependTo(g), | |
| 385 | +h=c('<a href="#"></a>').addClass("ui-dialog-titlebar-close ui-corner-all").attr("role","button").hover(function(){h.addClass("ui-state-hover")},function(){h.removeClass("ui-state-hover")}).focus(function(){h.addClass("ui-state-focus")}).blur(function(){h.removeClass("ui-state-focus")}).click(function(i){a.close(i);return false}).appendTo(f);(a.uiDialogTitlebarCloseText=c("<span></span>")).addClass("ui-icon ui-icon-closethick").text(b.closeText).appendTo(h);c("<span></span>").addClass("ui-dialog-title").attr("id", | |
| 386 | +e).html(d).prependTo(f);if(c.isFunction(b.beforeclose)&&!c.isFunction(b.beforeClose))b.beforeClose=b.beforeclose;f.find("*").add(f).disableSelection();b.draggable&&c.fn.draggable&&a._makeDraggable();b.resizable&&c.fn.resizable&&a._makeResizable();a._createButtons(b.buttons);a._isOpen=false;c.fn.bgiframe&&g.bgiframe()},_init:function(){this.options.autoOpen&&this.open()},destroy:function(){var a=this;a.overlay&&a.overlay.destroy();a.uiDialog.hide();a.element.unbind(".dialog").removeData("dialog").removeClass("ui-dialog-content ui-widget-content").hide().appendTo("body"); | |
| 387 | +a.uiDialog.remove();a.originalTitle&&a.element.attr("title",a.originalTitle);return a},widget:function(){return this.uiDialog},close:function(a){var b=this,d,e;if(false!==b._trigger("beforeClose",a)){b.overlay&&b.overlay.destroy();b.uiDialog.unbind("keypress.ui-dialog");b._isOpen=false;if(b.options.hide)b.uiDialog.hide(b.options.hide,function(){b._trigger("close",a)});else{b.uiDialog.hide();b._trigger("close",a)}c.ui.dialog.overlay.resize();if(b.options.modal){d=0;c(".ui-dialog").each(function(){if(this!== | |
| 388 | +b.uiDialog[0]){e=c(this).css("z-index");isNaN(e)||(d=Math.max(d,e))}});c.ui.dialog.maxZ=d}return b}},isOpen:function(){return this._isOpen},moveToTop:function(a,b){var d=this,e=d.options;if(e.modal&&!a||!e.stack&&!e.modal)return d._trigger("focus",b);if(e.zIndex>c.ui.dialog.maxZ)c.ui.dialog.maxZ=e.zIndex;if(d.overlay){c.ui.dialog.maxZ+=1;d.overlay.$el.css("z-index",c.ui.dialog.overlay.maxZ=c.ui.dialog.maxZ)}a={scrollTop:d.element.scrollTop(),scrollLeft:d.element.scrollLeft()};c.ui.dialog.maxZ+=1; | |
| 389 | +d.uiDialog.css("z-index",c.ui.dialog.maxZ);d.element.attr(a);d._trigger("focus",b);return d},open:function(){if(!this._isOpen){var a=this,b=a.options,d=a.uiDialog;a.overlay=b.modal?new c.ui.dialog.overlay(a):null;a._size();a._position(b.position);d.show(b.show);a.moveToTop(true);b.modal&&d.bind("keypress.ui-dialog",function(e){if(e.keyCode===c.ui.keyCode.TAB){var g=c(":tabbable",this),f=g.filter(":first");g=g.filter(":last");if(e.target===g[0]&&!e.shiftKey){f.focus(1);return false}else if(e.target=== | |
| 390 | +f[0]&&e.shiftKey){g.focus(1);return false}}});c(a.element.find(":tabbable").get().concat(d.find(".ui-dialog-buttonpane :tabbable").get().concat(d.get()))).eq(0).focus();a._isOpen=true;a._trigger("open");return a}},_createButtons:function(a){var b=this,d=false,e=c("<div></div>").addClass("ui-dialog-buttonpane ui-widget-content ui-helper-clearfix"),g=c("<div></div>").addClass("ui-dialog-buttonset").appendTo(e);b.uiDialog.find(".ui-dialog-buttonpane").remove();typeof a==="object"&&a!==null&&c.each(a, | |
| 391 | +function(){return!(d=true)});if(d){c.each(a,function(f,h){h=c.isFunction(h)?{click:h,text:f}:h;var i=c('<button type="button"></button>').click(function(){h.click.apply(b.element[0],arguments)}).appendTo(g);c.each(h,function(j,k){if(j!=="click")j in o?i[j](k):i.attr(j,k)});c.fn.button&&i.button()});e.appendTo(b.uiDialog)}},_makeDraggable:function(){function a(f){return{position:f.position,offset:f.offset}}var b=this,d=b.options,e=c(document),g;b.uiDialog.draggable({cancel:".ui-dialog-content, .ui-dialog-titlebar-close", | |
| 392 | +handle:".ui-dialog-titlebar",containment:"document",start:function(f,h){g=d.height==="auto"?"auto":c(this).height();c(this).height(c(this).height()).addClass("ui-dialog-dragging");b._trigger("dragStart",f,a(h))},drag:function(f,h){b._trigger("drag",f,a(h))},stop:function(f,h){d.position=[h.position.left-e.scrollLeft(),h.position.top-e.scrollTop()];c(this).removeClass("ui-dialog-dragging").height(g);b._trigger("dragStop",f,a(h));c.ui.dialog.overlay.resize()}})},_makeResizable:function(a){function b(f){return{originalPosition:f.originalPosition, | |
| 393 | +originalSize:f.originalSize,position:f.position,size:f.size}}a=a===l?this.options.resizable:a;var d=this,e=d.options,g=d.uiDialog.css("position");a=typeof a==="string"?a:"n,e,s,w,se,sw,ne,nw";d.uiDialog.resizable({cancel:".ui-dialog-content",containment:"document",alsoResize:d.element,maxWidth:e.maxWidth,maxHeight:e.maxHeight,minWidth:e.minWidth,minHeight:d._minHeight(),handles:a,start:function(f,h){c(this).addClass("ui-dialog-resizing");d._trigger("resizeStart",f,b(h))},resize:function(f,h){d._trigger("resize", | |
| 394 | +f,b(h))},stop:function(f,h){c(this).removeClass("ui-dialog-resizing");e.height=c(this).height();e.width=c(this).width();d._trigger("resizeStop",f,b(h));c.ui.dialog.overlay.resize()}}).css("position",g).find(".ui-resizable-se").addClass("ui-icon ui-icon-grip-diagonal-se")},_minHeight:function(){var a=this.options;return a.height==="auto"?a.minHeight:Math.min(a.minHeight,a.height)},_position:function(a){var b=[],d=[0,0],e;if(a){if(typeof a==="string"||typeof a==="object"&&"0"in a){b=a.split?a.split(" "): | |
| 395 | +[a[0],a[1]];if(b.length===1)b[1]=b[0];c.each(["left","top"],function(g,f){if(+b[g]===b[g]){d[g]=b[g];b[g]=f}});a={my:b.join(" "),at:b.join(" "),offset:d.join(" ")}}a=c.extend({},c.ui.dialog.prototype.options.position,a)}else a=c.ui.dialog.prototype.options.position;(e=this.uiDialog.is(":visible"))||this.uiDialog.show();this.uiDialog.css({top:0,left:0}).position(c.extend({of:window},a));e||this.uiDialog.hide()},_setOptions:function(a){var b=this,d={},e=false;c.each(a,function(g,f){b._setOption(g,f); | |
| 396 | +if(g in m)e=true;if(g in n)d[g]=f});e&&this._size();this.uiDialog.is(":data(resizable)")&&this.uiDialog.resizable("option",d)},_setOption:function(a,b){var d=this,e=d.uiDialog;switch(a){case "beforeclose":a="beforeClose";break;case "buttons":d._createButtons(b);break;case "closeText":d.uiDialogTitlebarCloseText.text(""+b);break;case "dialogClass":e.removeClass(d.options.dialogClass).addClass("ui-dialog ui-widget ui-widget-content ui-corner-all "+b);break;case "disabled":b?e.addClass("ui-dialog-disabled"): | |
| 397 | +e.removeClass("ui-dialog-disabled");break;case "draggable":var g=e.is(":data(draggable)");g&&!b&&e.draggable("destroy");!g&&b&&d._makeDraggable();break;case "position":d._position(b);break;case "resizable":(g=e.is(":data(resizable)"))&&!b&&e.resizable("destroy");g&&typeof b==="string"&&e.resizable("option","handles",b);!g&&b!==false&&d._makeResizable(b);break;case "title":c(".ui-dialog-title",d.uiDialogTitlebar).html(""+(b||" "));break}c.Widget.prototype._setOption.apply(d,arguments)},_size:function(){var a= | |
| 398 | +this.options,b,d,e=this.uiDialog.is(":visible");this.element.show().css({width:"auto",minHeight:0,height:0});if(a.minWidth>a.width)a.width=a.minWidth;b=this.uiDialog.css({height:"auto",width:a.width}).height();d=Math.max(0,a.minHeight-b);if(a.height==="auto")if(c.support.minHeight)this.element.css({minHeight:d,height:"auto"});else{this.uiDialog.show();a=this.element.css("height","auto").height();e||this.uiDialog.hide();this.element.height(Math.max(a,d))}else this.element.height(Math.max(a.height- | |
| 399 | +b,0));this.uiDialog.is(":data(resizable)")&&this.uiDialog.resizable("option","minHeight",this._minHeight())}});c.extend(c.ui.dialog,{version:"1.8.16",uuid:0,maxZ:0,getTitleId:function(a){a=a.attr("id");if(!a){this.uuid+=1;a=this.uuid}return"ui-dialog-title-"+a},overlay:function(a){this.$el=c.ui.dialog.overlay.create(a)}});c.extend(c.ui.dialog.overlay,{instances:[],oldInstances:[],maxZ:0,events:c.map("focus,mousedown,mouseup,keydown,keypress,click".split(","),function(a){return a+".dialog-overlay"}).join(" "), | |
| 400 | +create:function(a){if(this.instances.length===0){setTimeout(function(){c.ui.dialog.overlay.instances.length&&c(document).bind(c.ui.dialog.overlay.events,function(d){if(c(d.target).zIndex()<c.ui.dialog.overlay.maxZ)return false})},1);c(document).bind("keydown.dialog-overlay",function(d){if(a.options.closeOnEscape&&!d.isDefaultPrevented()&&d.keyCode&&d.keyCode===c.ui.keyCode.ESCAPE){a.close(d);d.preventDefault()}});c(window).bind("resize.dialog-overlay",c.ui.dialog.overlay.resize)}var b=(this.oldInstances.pop()|| | |
| 401 | +c("<div></div>").addClass("ui-widget-overlay")).appendTo(document.body).css({width:this.width(),height:this.height()});c.fn.bgiframe&&b.bgiframe();this.instances.push(b);return b},destroy:function(a){var b=c.inArray(a,this.instances);b!=-1&&this.oldInstances.push(this.instances.splice(b,1)[0]);this.instances.length===0&&c([document,window]).unbind(".dialog-overlay");a.remove();var d=0;c.each(this.instances,function(){d=Math.max(d,this.css("z-index"))});this.maxZ=d},height:function(){var a,b;if(c.browser.msie&& | |
| 402 | +c.browser.version<7){a=Math.max(document.documentElement.scrollHeight,document.body.scrollHeight);b=Math.max(document.documentElement.offsetHeight,document.body.offsetHeight);return a<b?c(window).height()+"px":a+"px"}else return c(document).height()+"px"},width:function(){var a,b;if(c.browser.msie){a=Math.max(document.documentElement.scrollWidth,document.body.scrollWidth);b=Math.max(document.documentElement.offsetWidth,document.body.offsetWidth);return a<b?c(window).width()+"px":a+"px"}else return c(document).width()+ | |
| 403 | +"px"},resize:function(){var a=c([]);c.each(c.ui.dialog.overlay.instances,function(){a=a.add(this)});a.css({width:0,height:0}).css({width:c.ui.dialog.overlay.width(),height:c.ui.dialog.overlay.height()})}});c.extend(c.ui.dialog.overlay.prototype,{destroy:function(){c.ui.dialog.overlay.destroy(this.$el)}})})(jQuery); | |
| 404 | +;/* | |
| 405 | + * jQuery UI Slider 1.8.16 | |
| 406 | + * | |
| 407 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 408 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 409 | + * http://jquery.org/license | |
| 410 | + * | |
| 411 | + * http://docs.jquery.com/UI/Slider | |
| 412 | + * | |
| 413 | + * Depends: | |
| 414 | + * jquery.ui.core.js | |
| 415 | + * jquery.ui.mouse.js | |
| 416 | + * jquery.ui.widget.js | |
| 417 | + */ | |
| 418 | +(function(d){d.widget("ui.slider",d.ui.mouse,{widgetEventPrefix:"slide",options:{animate:false,distance:0,max:100,min:0,orientation:"horizontal",range:false,step:1,value:0,values:null},_create:function(){var a=this,b=this.options,c=this.element.find(".ui-slider-handle").addClass("ui-state-default ui-corner-all"),f=b.values&&b.values.length||1,e=[];this._mouseSliding=this._keySliding=false;this._animateOff=true;this._handleIndex=null;this._detectOrientation();this._mouseInit();this.element.addClass("ui-slider ui-slider-"+ | |
| 419 | +this.orientation+" ui-widget ui-widget-content ui-corner-all"+(b.disabled?" ui-slider-disabled ui-disabled":""));this.range=d([]);if(b.range){if(b.range===true){if(!b.values)b.values=[this._valueMin(),this._valueMin()];if(b.values.length&&b.values.length!==2)b.values=[b.values[0],b.values[0]]}this.range=d("<div></div>").appendTo(this.element).addClass("ui-slider-range ui-widget-header"+(b.range==="min"||b.range==="max"?" ui-slider-range-"+b.range:""))}for(var j=c.length;j<f;j+=1)e.push("<a class='ui-slider-handle ui-state-default ui-corner-all' href='#'></a>"); | |
| 420 | +this.handles=c.add(d(e.join("")).appendTo(a.element));this.handle=this.handles.eq(0);this.handles.add(this.range).filter("a").click(function(g){g.preventDefault()}).hover(function(){b.disabled||d(this).addClass("ui-state-hover")},function(){d(this).removeClass("ui-state-hover")}).focus(function(){if(b.disabled)d(this).blur();else{d(".ui-slider .ui-state-focus").removeClass("ui-state-focus");d(this).addClass("ui-state-focus")}}).blur(function(){d(this).removeClass("ui-state-focus")});this.handles.each(function(g){d(this).data("index.ui-slider-handle", | |
| 421 | +g)});this.handles.keydown(function(g){var k=true,l=d(this).data("index.ui-slider-handle"),i,h,m;if(!a.options.disabled){switch(g.keyCode){case d.ui.keyCode.HOME:case d.ui.keyCode.END:case d.ui.keyCode.PAGE_UP:case d.ui.keyCode.PAGE_DOWN:case d.ui.keyCode.UP:case d.ui.keyCode.RIGHT:case d.ui.keyCode.DOWN:case d.ui.keyCode.LEFT:k=false;if(!a._keySliding){a._keySliding=true;d(this).addClass("ui-state-active");i=a._start(g,l);if(i===false)return}break}m=a.options.step;i=a.options.values&&a.options.values.length? | |
| 422 | +(h=a.values(l)):(h=a.value());switch(g.keyCode){case d.ui.keyCode.HOME:h=a._valueMin();break;case d.ui.keyCode.END:h=a._valueMax();break;case d.ui.keyCode.PAGE_UP:h=a._trimAlignValue(i+(a._valueMax()-a._valueMin())/5);break;case d.ui.keyCode.PAGE_DOWN:h=a._trimAlignValue(i-(a._valueMax()-a._valueMin())/5);break;case d.ui.keyCode.UP:case d.ui.keyCode.RIGHT:if(i===a._valueMax())return;h=a._trimAlignValue(i+m);break;case d.ui.keyCode.DOWN:case d.ui.keyCode.LEFT:if(i===a._valueMin())return;h=a._trimAlignValue(i- | |
| 423 | +m);break}a._slide(g,l,h);return k}}).keyup(function(g){var k=d(this).data("index.ui-slider-handle");if(a._keySliding){a._keySliding=false;a._stop(g,k);a._change(g,k);d(this).removeClass("ui-state-active")}});this._refreshValue();this._animateOff=false},destroy:function(){this.handles.remove();this.range.remove();this.element.removeClass("ui-slider ui-slider-horizontal ui-slider-vertical ui-slider-disabled ui-widget ui-widget-content ui-corner-all").removeData("slider").unbind(".slider");this._mouseDestroy(); | |
| 424 | +return this},_mouseCapture:function(a){var b=this.options,c,f,e,j,g;if(b.disabled)return false;this.elementSize={width:this.element.outerWidth(),height:this.element.outerHeight()};this.elementOffset=this.element.offset();c=this._normValueFromMouse({x:a.pageX,y:a.pageY});f=this._valueMax()-this._valueMin()+1;j=this;this.handles.each(function(k){var l=Math.abs(c-j.values(k));if(f>l){f=l;e=d(this);g=k}});if(b.range===true&&this.values(1)===b.min){g+=1;e=d(this.handles[g])}if(this._start(a,g)===false)return false; | |
| 425 | +this._mouseSliding=true;j._handleIndex=g;e.addClass("ui-state-active").focus();b=e.offset();this._clickOffset=!d(a.target).parents().andSelf().is(".ui-slider-handle")?{left:0,top:0}:{left:a.pageX-b.left-e.width()/2,top:a.pageY-b.top-e.height()/2-(parseInt(e.css("borderTopWidth"),10)||0)-(parseInt(e.css("borderBottomWidth"),10)||0)+(parseInt(e.css("marginTop"),10)||0)};this.handles.hasClass("ui-state-hover")||this._slide(a,g,c);return this._animateOff=true},_mouseStart:function(){return true},_mouseDrag:function(a){var b= | |
| 426 | +this._normValueFromMouse({x:a.pageX,y:a.pageY});this._slide(a,this._handleIndex,b);return false},_mouseStop:function(a){this.handles.removeClass("ui-state-active");this._mouseSliding=false;this._stop(a,this._handleIndex);this._change(a,this._handleIndex);this._clickOffset=this._handleIndex=null;return this._animateOff=false},_detectOrientation:function(){this.orientation=this.options.orientation==="vertical"?"vertical":"horizontal"},_normValueFromMouse:function(a){var b;if(this.orientation==="horizontal"){b= | |
| 427 | +this.elementSize.width;a=a.x-this.elementOffset.left-(this._clickOffset?this._clickOffset.left:0)}else{b=this.elementSize.height;a=a.y-this.elementOffset.top-(this._clickOffset?this._clickOffset.top:0)}b=a/b;if(b>1)b=1;if(b<0)b=0;if(this.orientation==="vertical")b=1-b;a=this._valueMax()-this._valueMin();return this._trimAlignValue(this._valueMin()+b*a)},_start:function(a,b){var c={handle:this.handles[b],value:this.value()};if(this.options.values&&this.options.values.length){c.value=this.values(b); | |
| 428 | +c.values=this.values()}return this._trigger("start",a,c)},_slide:function(a,b,c){var f;if(this.options.values&&this.options.values.length){f=this.values(b?0:1);if(this.options.values.length===2&&this.options.range===true&&(b===0&&c>f||b===1&&c<f))c=f;if(c!==this.values(b)){f=this.values();f[b]=c;a=this._trigger("slide",a,{handle:this.handles[b],value:c,values:f});this.values(b?0:1);a!==false&&this.values(b,c,true)}}else if(c!==this.value()){a=this._trigger("slide",a,{handle:this.handles[b],value:c}); | |
| 429 | +a!==false&&this.value(c)}},_stop:function(a,b){var c={handle:this.handles[b],value:this.value()};if(this.options.values&&this.options.values.length){c.value=this.values(b);c.values=this.values()}this._trigger("stop",a,c)},_change:function(a,b){if(!this._keySliding&&!this._mouseSliding){var c={handle:this.handles[b],value:this.value()};if(this.options.values&&this.options.values.length){c.value=this.values(b);c.values=this.values()}this._trigger("change",a,c)}},value:function(a){if(arguments.length){this.options.value= | |
| 430 | +this._trimAlignValue(a);this._refreshValue();this._change(null,0)}else return this._value()},values:function(a,b){var c,f,e;if(arguments.length>1){this.options.values[a]=this._trimAlignValue(b);this._refreshValue();this._change(null,a)}else if(arguments.length)if(d.isArray(arguments[0])){c=this.options.values;f=arguments[0];for(e=0;e<c.length;e+=1){c[e]=this._trimAlignValue(f[e]);this._change(null,e)}this._refreshValue()}else return this.options.values&&this.options.values.length?this._values(a): | |
| 431 | +this.value();else return this._values()},_setOption:function(a,b){var c,f=0;if(d.isArray(this.options.values))f=this.options.values.length;d.Widget.prototype._setOption.apply(this,arguments);switch(a){case "disabled":if(b){this.handles.filter(".ui-state-focus").blur();this.handles.removeClass("ui-state-hover");this.handles.propAttr("disabled",true);this.element.addClass("ui-disabled")}else{this.handles.propAttr("disabled",false);this.element.removeClass("ui-disabled")}break;case "orientation":this._detectOrientation(); | |
| 432 | +this.element.removeClass("ui-slider-horizontal ui-slider-vertical").addClass("ui-slider-"+this.orientation);this._refreshValue();break;case "value":this._animateOff=true;this._refreshValue();this._change(null,0);this._animateOff=false;break;case "values":this._animateOff=true;this._refreshValue();for(c=0;c<f;c+=1)this._change(null,c);this._animateOff=false;break}},_value:function(){var a=this.options.value;return a=this._trimAlignValue(a)},_values:function(a){var b,c;if(arguments.length){b=this.options.values[a]; | |
| 433 | +return b=this._trimAlignValue(b)}else{b=this.options.values.slice();for(c=0;c<b.length;c+=1)b[c]=this._trimAlignValue(b[c]);return b}},_trimAlignValue:function(a){if(a<=this._valueMin())return this._valueMin();if(a>=this._valueMax())return this._valueMax();var b=this.options.step>0?this.options.step:1,c=(a-this._valueMin())%b;a=a-c;if(Math.abs(c)*2>=b)a+=c>0?b:-b;return parseFloat(a.toFixed(5))},_valueMin:function(){return this.options.min},_valueMax:function(){return this.options.max},_refreshValue:function(){var a= | |
| 434 | +this.options.range,b=this.options,c=this,f=!this._animateOff?b.animate:false,e,j={},g,k,l,i;if(this.options.values&&this.options.values.length)this.handles.each(function(h){e=(c.values(h)-c._valueMin())/(c._valueMax()-c._valueMin())*100;j[c.orientation==="horizontal"?"left":"bottom"]=e+"%";d(this).stop(1,1)[f?"animate":"css"](j,b.animate);if(c.options.range===true)if(c.orientation==="horizontal"){if(h===0)c.range.stop(1,1)[f?"animate":"css"]({left:e+"%"},b.animate);if(h===1)c.range[f?"animate":"css"]({width:e- | |
| 435 | +g+"%"},{queue:false,duration:b.animate})}else{if(h===0)c.range.stop(1,1)[f?"animate":"css"]({bottom:e+"%"},b.animate);if(h===1)c.range[f?"animate":"css"]({height:e-g+"%"},{queue:false,duration:b.animate})}g=e});else{k=this.value();l=this._valueMin();i=this._valueMax();e=i!==l?(k-l)/(i-l)*100:0;j[c.orientation==="horizontal"?"left":"bottom"]=e+"%";this.handle.stop(1,1)[f?"animate":"css"](j,b.animate);if(a==="min"&&this.orientation==="horizontal")this.range.stop(1,1)[f?"animate":"css"]({width:e+"%"}, | |
| 436 | +b.animate);if(a==="max"&&this.orientation==="horizontal")this.range[f?"animate":"css"]({width:100-e+"%"},{queue:false,duration:b.animate});if(a==="min"&&this.orientation==="vertical")this.range.stop(1,1)[f?"animate":"css"]({height:e+"%"},b.animate);if(a==="max"&&this.orientation==="vertical")this.range[f?"animate":"css"]({height:100-e+"%"},{queue:false,duration:b.animate})}}});d.extend(d.ui.slider,{version:"1.8.16"})})(jQuery); | |
| 437 | +;/* | |
| 438 | + * jQuery UI Tabs 1.8.16 | |
| 439 | + * | |
| 440 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 441 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 442 | + * http://jquery.org/license | |
| 443 | + * | |
| 444 | + * http://docs.jquery.com/UI/Tabs | |
| 445 | + * | |
| 446 | + * Depends: | |
| 447 | + * jquery.ui.core.js | |
| 448 | + * jquery.ui.widget.js | |
| 449 | + */ | |
| 450 | +(function(d,p){function u(){return++v}function w(){return++x}var v=0,x=0;d.widget("ui.tabs",{options:{add:null,ajaxOptions:null,cache:false,cookie:null,collapsible:false,disable:null,disabled:[],enable:null,event:"click",fx:null,idPrefix:"ui-tabs-",load:null,panelTemplate:"<div></div>",remove:null,select:null,show:null,spinner:"<em>Loading…</em>",tabTemplate:"<li><a href='#{href}'><span>#{label}</span></a></li>"},_create:function(){this._tabify(true)},_setOption:function(b,e){if(b=="selected")this.options.collapsible&& | |
| 451 | +e==this.options.selected||this.select(e);else{this.options[b]=e;this._tabify()}},_tabId:function(b){return b.title&&b.title.replace(/\s/g,"_").replace(/[^\w\u00c0-\uFFFF-]/g,"")||this.options.idPrefix+u()},_sanitizeSelector:function(b){return b.replace(/:/g,"\\:")},_cookie:function(){var b=this.cookie||(this.cookie=this.options.cookie.name||"ui-tabs-"+w());return d.cookie.apply(null,[b].concat(d.makeArray(arguments)))},_ui:function(b,e){return{tab:b,panel:e,index:this.anchors.index(b)}},_cleanup:function(){this.lis.filter(".ui-state-processing").removeClass("ui-state-processing").find("span:data(label.tabs)").each(function(){var b= | |
| 452 | +d(this);b.html(b.data("label.tabs")).removeData("label.tabs")})},_tabify:function(b){function e(g,f){g.css("display","");!d.support.opacity&&f.opacity&&g[0].style.removeAttribute("filter")}var a=this,c=this.options,h=/^#.+/;this.list=this.element.find("ol,ul").eq(0);this.lis=d(" > li:has(a[href])",this.list);this.anchors=this.lis.map(function(){return d("a",this)[0]});this.panels=d([]);this.anchors.each(function(g,f){var i=d(f).attr("href"),l=i.split("#")[0],q;if(l&&(l===location.toString().split("#")[0]|| | |
| 453 | +(q=d("base")[0])&&l===q.href)){i=f.hash;f.href=i}if(h.test(i))a.panels=a.panels.add(a.element.find(a._sanitizeSelector(i)));else if(i&&i!=="#"){d.data(f,"href.tabs",i);d.data(f,"load.tabs",i.replace(/#.*$/,""));i=a._tabId(f);f.href="#"+i;f=a.element.find("#"+i);if(!f.length){f=d(c.panelTemplate).attr("id",i).addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").insertAfter(a.panels[g-1]||a.list);f.data("destroy.tabs",true)}a.panels=a.panels.add(f)}else c.disabled.push(g)});if(b){this.element.addClass("ui-tabs ui-widget ui-widget-content ui-corner-all"); | |
| 454 | +this.list.addClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all");this.lis.addClass("ui-state-default ui-corner-top");this.panels.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom");if(c.selected===p){location.hash&&this.anchors.each(function(g,f){if(f.hash==location.hash){c.selected=g;return false}});if(typeof c.selected!=="number"&&c.cookie)c.selected=parseInt(a._cookie(),10);if(typeof c.selected!=="number"&&this.lis.filter(".ui-tabs-selected").length)c.selected= | |
| 455 | +this.lis.index(this.lis.filter(".ui-tabs-selected"));c.selected=c.selected||(this.lis.length?0:-1)}else if(c.selected===null)c.selected=-1;c.selected=c.selected>=0&&this.anchors[c.selected]||c.selected<0?c.selected:0;c.disabled=d.unique(c.disabled.concat(d.map(this.lis.filter(".ui-state-disabled"),function(g){return a.lis.index(g)}))).sort();d.inArray(c.selected,c.disabled)!=-1&&c.disabled.splice(d.inArray(c.selected,c.disabled),1);this.panels.addClass("ui-tabs-hide");this.lis.removeClass("ui-tabs-selected ui-state-active"); | |
| 456 | +if(c.selected>=0&&this.anchors.length){a.element.find(a._sanitizeSelector(a.anchors[c.selected].hash)).removeClass("ui-tabs-hide");this.lis.eq(c.selected).addClass("ui-tabs-selected ui-state-active");a.element.queue("tabs",function(){a._trigger("show",null,a._ui(a.anchors[c.selected],a.element.find(a._sanitizeSelector(a.anchors[c.selected].hash))[0]))});this.load(c.selected)}d(window).bind("unload",function(){a.lis.add(a.anchors).unbind(".tabs");a.lis=a.anchors=a.panels=null})}else c.selected=this.lis.index(this.lis.filter(".ui-tabs-selected")); | |
| 457 | +this.element[c.collapsible?"addClass":"removeClass"]("ui-tabs-collapsible");c.cookie&&this._cookie(c.selected,c.cookie);b=0;for(var j;j=this.lis[b];b++)d(j)[d.inArray(b,c.disabled)!=-1&&!d(j).hasClass("ui-tabs-selected")?"addClass":"removeClass"]("ui-state-disabled");c.cache===false&&this.anchors.removeData("cache.tabs");this.lis.add(this.anchors).unbind(".tabs");if(c.event!=="mouseover"){var k=function(g,f){f.is(":not(.ui-state-disabled)")&&f.addClass("ui-state-"+g)},n=function(g,f){f.removeClass("ui-state-"+ | |
| 458 | +g)};this.lis.bind("mouseover.tabs",function(){k("hover",d(this))});this.lis.bind("mouseout.tabs",function(){n("hover",d(this))});this.anchors.bind("focus.tabs",function(){k("focus",d(this).closest("li"))});this.anchors.bind("blur.tabs",function(){n("focus",d(this).closest("li"))})}var m,o;if(c.fx)if(d.isArray(c.fx)){m=c.fx[0];o=c.fx[1]}else m=o=c.fx;var r=o?function(g,f){d(g).closest("li").addClass("ui-tabs-selected ui-state-active");f.hide().removeClass("ui-tabs-hide").animate(o,o.duration||"normal", | |
| 459 | +function(){e(f,o);a._trigger("show",null,a._ui(g,f[0]))})}:function(g,f){d(g).closest("li").addClass("ui-tabs-selected ui-state-active");f.removeClass("ui-tabs-hide");a._trigger("show",null,a._ui(g,f[0]))},s=m?function(g,f){f.animate(m,m.duration||"normal",function(){a.lis.removeClass("ui-tabs-selected ui-state-active");f.addClass("ui-tabs-hide");e(f,m);a.element.dequeue("tabs")})}:function(g,f){a.lis.removeClass("ui-tabs-selected ui-state-active");f.addClass("ui-tabs-hide");a.element.dequeue("tabs")}; | |
| 460 | +this.anchors.bind(c.event+".tabs",function(){var g=this,f=d(g).closest("li"),i=a.panels.filter(":not(.ui-tabs-hide)"),l=a.element.find(a._sanitizeSelector(g.hash));if(f.hasClass("ui-tabs-selected")&&!c.collapsible||f.hasClass("ui-state-disabled")||f.hasClass("ui-state-processing")||a.panels.filter(":animated").length||a._trigger("select",null,a._ui(this,l[0]))===false){this.blur();return false}c.selected=a.anchors.index(this);a.abort();if(c.collapsible)if(f.hasClass("ui-tabs-selected")){c.selected= | |
| 461 | +-1;c.cookie&&a._cookie(c.selected,c.cookie);a.element.queue("tabs",function(){s(g,i)}).dequeue("tabs");this.blur();return false}else if(!i.length){c.cookie&&a._cookie(c.selected,c.cookie);a.element.queue("tabs",function(){r(g,l)});a.load(a.anchors.index(this));this.blur();return false}c.cookie&&a._cookie(c.selected,c.cookie);if(l.length){i.length&&a.element.queue("tabs",function(){s(g,i)});a.element.queue("tabs",function(){r(g,l)});a.load(a.anchors.index(this))}else throw"jQuery UI Tabs: Mismatching fragment identifier."; | |
| 462 | +d.browser.msie&&this.blur()});this.anchors.bind("click.tabs",function(){return false})},_getIndex:function(b){if(typeof b=="string")b=this.anchors.index(this.anchors.filter("[href$="+b+"]"));return b},destroy:function(){var b=this.options;this.abort();this.element.unbind(".tabs").removeClass("ui-tabs ui-widget ui-widget-content ui-corner-all ui-tabs-collapsible").removeData("tabs");this.list.removeClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all");this.anchors.each(function(){var e= | |
| 463 | +d.data(this,"href.tabs");if(e)this.href=e;var a=d(this).unbind(".tabs");d.each(["href","load","cache"],function(c,h){a.removeData(h+".tabs")})});this.lis.unbind(".tabs").add(this.panels).each(function(){d.data(this,"destroy.tabs")?d(this).remove():d(this).removeClass("ui-state-default ui-corner-top ui-tabs-selected ui-state-active ui-state-hover ui-state-focus ui-state-disabled ui-tabs-panel ui-widget-content ui-corner-bottom ui-tabs-hide")});b.cookie&&this._cookie(null,b.cookie);return this},add:function(b, | |
| 464 | +e,a){if(a===p)a=this.anchors.length;var c=this,h=this.options;e=d(h.tabTemplate.replace(/#\{href\}/g,b).replace(/#\{label\}/g,e));b=!b.indexOf("#")?b.replace("#",""):this._tabId(d("a",e)[0]);e.addClass("ui-state-default ui-corner-top").data("destroy.tabs",true);var j=c.element.find("#"+b);j.length||(j=d(h.panelTemplate).attr("id",b).data("destroy.tabs",true));j.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom ui-tabs-hide");if(a>=this.lis.length){e.appendTo(this.list);j.appendTo(this.list[0].parentNode)}else{e.insertBefore(this.lis[a]); | |
| 465 | +j.insertBefore(this.panels[a])}h.disabled=d.map(h.disabled,function(k){return k>=a?++k:k});this._tabify();if(this.anchors.length==1){h.selected=0;e.addClass("ui-tabs-selected ui-state-active");j.removeClass("ui-tabs-hide");this.element.queue("tabs",function(){c._trigger("show",null,c._ui(c.anchors[0],c.panels[0]))});this.load(0)}this._trigger("add",null,this._ui(this.anchors[a],this.panels[a]));return this},remove:function(b){b=this._getIndex(b);var e=this.options,a=this.lis.eq(b).remove(),c=this.panels.eq(b).remove(); | |
| 466 | +if(a.hasClass("ui-tabs-selected")&&this.anchors.length>1)this.select(b+(b+1<this.anchors.length?1:-1));e.disabled=d.map(d.grep(e.disabled,function(h){return h!=b}),function(h){return h>=b?--h:h});this._tabify();this._trigger("remove",null,this._ui(a.find("a")[0],c[0]));return this},enable:function(b){b=this._getIndex(b);var e=this.options;if(d.inArray(b,e.disabled)!=-1){this.lis.eq(b).removeClass("ui-state-disabled");e.disabled=d.grep(e.disabled,function(a){return a!=b});this._trigger("enable",null, | |
| 467 | +this._ui(this.anchors[b],this.panels[b]));return this}},disable:function(b){b=this._getIndex(b);var e=this.options;if(b!=e.selected){this.lis.eq(b).addClass("ui-state-disabled");e.disabled.push(b);e.disabled.sort();this._trigger("disable",null,this._ui(this.anchors[b],this.panels[b]))}return this},select:function(b){b=this._getIndex(b);if(b==-1)if(this.options.collapsible&&this.options.selected!=-1)b=this.options.selected;else return this;this.anchors.eq(b).trigger(this.options.event+".tabs");return this}, | |
| 468 | +load:function(b){b=this._getIndex(b);var e=this,a=this.options,c=this.anchors.eq(b)[0],h=d.data(c,"load.tabs");this.abort();if(!h||this.element.queue("tabs").length!==0&&d.data(c,"cache.tabs"))this.element.dequeue("tabs");else{this.lis.eq(b).addClass("ui-state-processing");if(a.spinner){var j=d("span",c);j.data("label.tabs",j.html()).html(a.spinner)}this.xhr=d.ajax(d.extend({},a.ajaxOptions,{url:h,success:function(k,n){e.element.find(e._sanitizeSelector(c.hash)).html(k);e._cleanup();a.cache&&d.data(c, | |
| 469 | +"cache.tabs",true);e._trigger("load",null,e._ui(e.anchors[b],e.panels[b]));try{a.ajaxOptions.success(k,n)}catch(m){}},error:function(k,n){e._cleanup();e._trigger("load",null,e._ui(e.anchors[b],e.panels[b]));try{a.ajaxOptions.error(k,n,b,c)}catch(m){}}}));e.element.dequeue("tabs");return this}},abort:function(){this.element.queue([]);this.panels.stop(false,true);this.element.queue("tabs",this.element.queue("tabs").splice(-2,2));if(this.xhr){this.xhr.abort();delete this.xhr}this._cleanup();return this}, | |
| 470 | +url:function(b,e){this.anchors.eq(b).removeData("cache.tabs").data("load.tabs",e);return this},length:function(){return this.anchors.length}});d.extend(d.ui.tabs,{version:"1.8.16"});d.extend(d.ui.tabs.prototype,{rotation:null,rotate:function(b,e){var a=this,c=this.options,h=a._rotate||(a._rotate=function(j){clearTimeout(a.rotation);a.rotation=setTimeout(function(){var k=c.selected;a.select(++k<a.anchors.length?k:0)},b);j&&j.stopPropagation()});e=a._unrotate||(a._unrotate=!e?function(j){j.clientX&& | |
| 471 | +a.rotate(null)}:function(){t=c.selected;h()});if(b){this.element.bind("tabsshow",h);this.anchors.bind(c.event+".tabs",e);h()}else{clearTimeout(a.rotation);this.element.unbind("tabsshow",h);this.anchors.unbind(c.event+".tabs",e);delete this._rotate;delete this._unrotate}return this}})})(jQuery); | |
| 472 | +;/* | |
| 473 | + * jQuery UI Datepicker 1.8.16 | |
| 474 | + * | |
| 475 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 476 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 477 | + * http://jquery.org/license | |
| 478 | + * | |
| 479 | + * http://docs.jquery.com/UI/Datepicker | |
| 480 | + * | |
| 481 | + * Depends: | |
| 482 | + * jquery.ui.core.js | |
| 483 | + */ | |
| 484 | +(function(d,C){function M(){this.debug=false;this._curInst=null;this._keyEvent=false;this._disabledInputs=[];this._inDialog=this._datepickerShowing=false;this._mainDivId="ui-datepicker-div";this._inlineClass="ui-datepicker-inline";this._appendClass="ui-datepicker-append";this._triggerClass="ui-datepicker-trigger";this._dialogClass="ui-datepicker-dialog";this._disableClass="ui-datepicker-disabled";this._unselectableClass="ui-datepicker-unselectable";this._currentClass="ui-datepicker-current-day";this._dayOverClass= | |
| 485 | +"ui-datepicker-days-cell-over";this.regional=[];this.regional[""]={closeText:"Done",prevText:"Prev",nextText:"Next",currentText:"Today",monthNames:["January","February","March","April","May","June","July","August","September","October","November","December"],monthNamesShort:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],dayNamesShort:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],dayNamesMin:["Su", | |
| 486 | +"Mo","Tu","We","Th","Fr","Sa"],weekHeader:"Wk",dateFormat:"mm/dd/yy",firstDay:0,isRTL:false,showMonthAfterYear:false,yearSuffix:""};this._defaults={showOn:"focus",showAnim:"fadeIn",showOptions:{},defaultDate:null,appendText:"",buttonText:"...",buttonImage:"",buttonImageOnly:false,hideIfNoPrevNext:false,navigationAsDateFormat:false,gotoCurrent:false,changeMonth:false,changeYear:false,yearRange:"c-10:c+10",showOtherMonths:false,selectOtherMonths:false,showWeek:false,calculateWeek:this.iso8601Week,shortYearCutoff:"+10", | |
| 487 | +minDate:null,maxDate:null,duration:"fast",beforeShowDay:null,beforeShow:null,onSelect:null,onChangeMonthYear:null,onClose:null,numberOfMonths:1,showCurrentAtPos:0,stepMonths:1,stepBigMonths:12,altField:"",altFormat:"",constrainInput:true,showButtonPanel:false,autoSize:false,disabled:false};d.extend(this._defaults,this.regional[""]);this.dpDiv=N(d('<div id="'+this._mainDivId+'" class="ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))}function N(a){return a.bind("mouseout", | |
| 488 | +function(b){b=d(b.target).closest("button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a");b.length&&b.removeClass("ui-state-hover ui-datepicker-prev-hover ui-datepicker-next-hover")}).bind("mouseover",function(b){b=d(b.target).closest("button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a");if(!(d.datepicker._isDisabledDatepicker(J.inline?a.parent()[0]:J.input[0])||!b.length)){b.parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover"); | |
| 489 | +b.addClass("ui-state-hover");b.hasClass("ui-datepicker-prev")&&b.addClass("ui-datepicker-prev-hover");b.hasClass("ui-datepicker-next")&&b.addClass("ui-datepicker-next-hover")}})}function H(a,b){d.extend(a,b);for(var c in b)if(b[c]==null||b[c]==C)a[c]=b[c];return a}d.extend(d.ui,{datepicker:{version:"1.8.16"}});var B=(new Date).getTime(),J;d.extend(M.prototype,{markerClassName:"hasDatepicker",maxRows:4,log:function(){this.debug&&console.log.apply("",arguments)},_widgetDatepicker:function(){return this.dpDiv}, | |
| 490 | +setDefaults:function(a){H(this._defaults,a||{});return this},_attachDatepicker:function(a,b){var c=null;for(var e in this._defaults){var f=a.getAttribute("date:"+e);if(f){c=c||{};try{c[e]=eval(f)}catch(h){c[e]=f}}}e=a.nodeName.toLowerCase();f=e=="div"||e=="span";if(!a.id){this.uuid+=1;a.id="dp"+this.uuid}var i=this._newInst(d(a),f);i.settings=d.extend({},b||{},c||{});if(e=="input")this._connectDatepicker(a,i);else f&&this._inlineDatepicker(a,i)},_newInst:function(a,b){return{id:a[0].id.replace(/([^A-Za-z0-9_-])/g, | |
| 491 | +"\\\\$1"),input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:b,dpDiv:!b?this.dpDiv:N(d('<div class="'+this._inlineClass+' ui-datepicker ui-widget ui-widget-content ui-helper-clearfix ui-corner-all"></div>'))}},_connectDatepicker:function(a,b){var c=d(a);b.append=d([]);b.trigger=d([]);if(!c.hasClass(this.markerClassName)){this._attachments(c,b);c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setData.datepicker", | |
| 492 | +function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});this._autoSize(b);d.data(a,"datepicker",b);b.settings.disabled&&this._disableDatepicker(a)}},_attachments:function(a,b){var c=this._get(b,"appendText"),e=this._get(b,"isRTL");b.append&&b.append.remove();if(c){b.append=d('<span class="'+this._appendClass+'">'+c+"</span>");a[e?"before":"after"](b.append)}a.unbind("focus",this._showDatepicker);b.trigger&&b.trigger.remove();c=this._get(b,"showOn");if(c== | |
| 493 | +"focus"||c=="both")a.focus(this._showDatepicker);if(c=="button"||c=="both"){c=this._get(b,"buttonText");var f=this._get(b,"buttonImage");b.trigger=d(this._get(b,"buttonImageOnly")?d("<img/>").addClass(this._triggerClass).attr({src:f,alt:c,title:c}):d('<button type="button"></button>').addClass(this._triggerClass).html(f==""?c:d("<img/>").attr({src:f,alt:c,title:c})));a[e?"before":"after"](b.trigger);b.trigger.click(function(){d.datepicker._datepickerShowing&&d.datepicker._lastInput==a[0]?d.datepicker._hideDatepicker(): | |
| 494 | +d.datepicker._showDatepicker(a[0]);return false})}},_autoSize:function(a){if(this._get(a,"autoSize")&&!a.inline){var b=new Date(2009,11,20),c=this._get(a,"dateFormat");if(c.match(/[DM]/)){var e=function(f){for(var h=0,i=0,g=0;g<f.length;g++)if(f[g].length>h){h=f[g].length;i=g}return i};b.setMonth(e(this._get(a,c.match(/MM/)?"monthNames":"monthNamesShort")));b.setDate(e(this._get(a,c.match(/DD/)?"dayNames":"dayNamesShort"))+20-b.getDay())}a.input.attr("size",this._formatDate(a,b).length)}},_inlineDatepicker:function(a, | |
| 495 | +b){var c=d(a);if(!c.hasClass(this.markerClassName)){c.addClass(this.markerClassName).append(b.dpDiv).bind("setData.datepicker",function(e,f,h){b.settings[f]=h}).bind("getData.datepicker",function(e,f){return this._get(b,f)});d.data(a,"datepicker",b);this._setDate(b,this._getDefaultDate(b),true);this._updateDatepicker(b);this._updateAlternate(b);b.settings.disabled&&this._disableDatepicker(a);b.dpDiv.css("display","block")}},_dialogDatepicker:function(a,b,c,e,f){a=this._dialogInst;if(!a){this.uuid+= | |
| 496 | +1;this._dialogInput=d('<input type="text" id="'+("dp"+this.uuid)+'" style="position: absolute; top: -100px; width: 0px; z-index: -10;"/>');this._dialogInput.keydown(this._doKeyDown);d("body").append(this._dialogInput);a=this._dialogInst=this._newInst(this._dialogInput,false);a.settings={};d.data(this._dialogInput[0],"datepicker",a)}H(a.settings,e||{});b=b&&b.constructor==Date?this._formatDate(a,b):b;this._dialogInput.val(b);this._pos=f?f.length?f:[f.pageX,f.pageY]:null;if(!this._pos)this._pos=[document.documentElement.clientWidth/ | |
| 497 | +2-100+(document.documentElement.scrollLeft||document.body.scrollLeft),document.documentElement.clientHeight/2-150+(document.documentElement.scrollTop||document.body.scrollTop)];this._dialogInput.css("left",this._pos[0]+20+"px").css("top",this._pos[1]+"px");a.settings.onSelect=c;this._inDialog=true;this.dpDiv.addClass(this._dialogClass);this._showDatepicker(this._dialogInput[0]);d.blockUI&&d.blockUI(this.dpDiv);d.data(this._dialogInput[0],"datepicker",a);return this},_destroyDatepicker:function(a){var b= | |
| 498 | +d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();d.removeData(a,"datepicker");if(e=="input"){c.append.remove();c.trigger.remove();b.removeClass(this.markerClassName).unbind("focus",this._showDatepicker).unbind("keydown",this._doKeyDown).unbind("keypress",this._doKeyPress).unbind("keyup",this._doKeyUp)}else if(e=="div"||e=="span")b.removeClass(this.markerClassName).empty()}},_enableDatepicker:function(a){var b=d(a),c=d.data(a,"datepicker");if(b.hasClass(this.markerClassName)){var e= | |
| 499 | +a.nodeName.toLowerCase();if(e=="input"){a.disabled=false;c.trigger.filter("button").each(function(){this.disabled=false}).end().filter("img").css({opacity:"1.0",cursor:""})}else if(e=="div"||e=="span"){b=b.children("."+this._inlineClass);b.children().removeClass("ui-state-disabled");b.find("select.ui-datepicker-month, select.ui-datepicker-year").removeAttr("disabled")}this._disabledInputs=d.map(this._disabledInputs,function(f){return f==a?null:f})}},_disableDatepicker:function(a){var b=d(a),c=d.data(a, | |
| 500 | +"datepicker");if(b.hasClass(this.markerClassName)){var e=a.nodeName.toLowerCase();if(e=="input"){a.disabled=true;c.trigger.filter("button").each(function(){this.disabled=true}).end().filter("img").css({opacity:"0.5",cursor:"default"})}else if(e=="div"||e=="span"){b=b.children("."+this._inlineClass);b.children().addClass("ui-state-disabled");b.find("select.ui-datepicker-month, select.ui-datepicker-year").attr("disabled","disabled")}this._disabledInputs=d.map(this._disabledInputs,function(f){return f== | |
| 501 | +a?null:f});this._disabledInputs[this._disabledInputs.length]=a}},_isDisabledDatepicker:function(a){if(!a)return false;for(var b=0;b<this._disabledInputs.length;b++)if(this._disabledInputs[b]==a)return true;return false},_getInst:function(a){try{return d.data(a,"datepicker")}catch(b){throw"Missing instance data for this datepicker";}},_optionDatepicker:function(a,b,c){var e=this._getInst(a);if(arguments.length==2&&typeof b=="string")return b=="defaults"?d.extend({},d.datepicker._defaults):e?b=="all"? | |
| 502 | +d.extend({},e.settings):this._get(e,b):null;var f=b||{};if(typeof b=="string"){f={};f[b]=c}if(e){this._curInst==e&&this._hideDatepicker();var h=this._getDateDatepicker(a,true),i=this._getMinMaxDate(e,"min"),g=this._getMinMaxDate(e,"max");H(e.settings,f);if(i!==null&&f.dateFormat!==C&&f.minDate===C)e.settings.minDate=this._formatDate(e,i);if(g!==null&&f.dateFormat!==C&&f.maxDate===C)e.settings.maxDate=this._formatDate(e,g);this._attachments(d(a),e);this._autoSize(e);this._setDate(e,h);this._updateAlternate(e); | |
| 503 | +this._updateDatepicker(e)}},_changeDatepicker:function(a,b,c){this._optionDatepicker(a,b,c)},_refreshDatepicker:function(a){(a=this._getInst(a))&&this._updateDatepicker(a)},_setDateDatepicker:function(a,b){if(a=this._getInst(a)){this._setDate(a,b);this._updateDatepicker(a);this._updateAlternate(a)}},_getDateDatepicker:function(a,b){(a=this._getInst(a))&&!a.inline&&this._setDateFromField(a,b);return a?this._getDate(a):null},_doKeyDown:function(a){var b=d.datepicker._getInst(a.target),c=true,e=b.dpDiv.is(".ui-datepicker-rtl"); | |
| 504 | +b._keyEvent=true;if(d.datepicker._datepickerShowing)switch(a.keyCode){case 9:d.datepicker._hideDatepicker();c=false;break;case 13:c=d("td."+d.datepicker._dayOverClass+":not(."+d.datepicker._currentClass+")",b.dpDiv);c[0]&&d.datepicker._selectDay(a.target,b.selectedMonth,b.selectedYear,c[0]);if(a=d.datepicker._get(b,"onSelect")){c=d.datepicker._formatDate(b);a.apply(b.input?b.input[0]:null,[c,b])}else d.datepicker._hideDatepicker();return false;case 27:d.datepicker._hideDatepicker();break;case 33:d.datepicker._adjustDate(a.target, | |
| 505 | +a.ctrlKey?-d.datepicker._get(b,"stepBigMonths"):-d.datepicker._get(b,"stepMonths"),"M");break;case 34:d.datepicker._adjustDate(a.target,a.ctrlKey?+d.datepicker._get(b,"stepBigMonths"):+d.datepicker._get(b,"stepMonths"),"M");break;case 35:if(a.ctrlKey||a.metaKey)d.datepicker._clearDate(a.target);c=a.ctrlKey||a.metaKey;break;case 36:if(a.ctrlKey||a.metaKey)d.datepicker._gotoToday(a.target);c=a.ctrlKey||a.metaKey;break;case 37:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,e?+1:-1,"D");c= | |
| 506 | +a.ctrlKey||a.metaKey;if(a.originalEvent.altKey)d.datepicker._adjustDate(a.target,a.ctrlKey?-d.datepicker._get(b,"stepBigMonths"):-d.datepicker._get(b,"stepMonths"),"M");break;case 38:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,-7,"D");c=a.ctrlKey||a.metaKey;break;case 39:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,e?-1:+1,"D");c=a.ctrlKey||a.metaKey;if(a.originalEvent.altKey)d.datepicker._adjustDate(a.target,a.ctrlKey?+d.datepicker._get(b,"stepBigMonths"):+d.datepicker._get(b, | |
| 507 | +"stepMonths"),"M");break;case 40:if(a.ctrlKey||a.metaKey)d.datepicker._adjustDate(a.target,+7,"D");c=a.ctrlKey||a.metaKey;break;default:c=false}else if(a.keyCode==36&&a.ctrlKey)d.datepicker._showDatepicker(this);else c=false;if(c){a.preventDefault();a.stopPropagation()}},_doKeyPress:function(a){var b=d.datepicker._getInst(a.target);if(d.datepicker._get(b,"constrainInput")){b=d.datepicker._possibleChars(d.datepicker._get(b,"dateFormat"));var c=String.fromCharCode(a.charCode==C?a.keyCode:a.charCode); | |
| 508 | +return a.ctrlKey||a.metaKey||c<" "||!b||b.indexOf(c)>-1}},_doKeyUp:function(a){a=d.datepicker._getInst(a.target);if(a.input.val()!=a.lastVal)try{if(d.datepicker.parseDate(d.datepicker._get(a,"dateFormat"),a.input?a.input.val():null,d.datepicker._getFormatConfig(a))){d.datepicker._setDateFromField(a);d.datepicker._updateAlternate(a);d.datepicker._updateDatepicker(a)}}catch(b){d.datepicker.log(b)}return true},_showDatepicker:function(a){a=a.target||a;if(a.nodeName.toLowerCase()!="input")a=d("input", | |
| 509 | +a.parentNode)[0];if(!(d.datepicker._isDisabledDatepicker(a)||d.datepicker._lastInput==a)){var b=d.datepicker._getInst(a);if(d.datepicker._curInst&&d.datepicker._curInst!=b){d.datepicker._datepickerShowing&&d.datepicker._triggerOnClose(d.datepicker._curInst);d.datepicker._curInst.dpDiv.stop(true,true)}var c=d.datepicker._get(b,"beforeShow");c=c?c.apply(a,[a,b]):{};if(c!==false){H(b.settings,c);b.lastVal=null;d.datepicker._lastInput=a;d.datepicker._setDateFromField(b);if(d.datepicker._inDialog)a.value= | |
| 510 | +"";if(!d.datepicker._pos){d.datepicker._pos=d.datepicker._findPos(a);d.datepicker._pos[1]+=a.offsetHeight}var e=false;d(a).parents().each(function(){e|=d(this).css("position")=="fixed";return!e});if(e&&d.browser.opera){d.datepicker._pos[0]-=document.documentElement.scrollLeft;d.datepicker._pos[1]-=document.documentElement.scrollTop}c={left:d.datepicker._pos[0],top:d.datepicker._pos[1]};d.datepicker._pos=null;b.dpDiv.empty();b.dpDiv.css({position:"absolute",display:"block",top:"-1000px"});d.datepicker._updateDatepicker(b); | |
| 511 | +c=d.datepicker._checkOffset(b,c,e);b.dpDiv.css({position:d.datepicker._inDialog&&d.blockUI?"static":e?"fixed":"absolute",display:"none",left:c.left+"px",top:c.top+"px"});if(!b.inline){c=d.datepicker._get(b,"showAnim");var f=d.datepicker._get(b,"duration"),h=function(){var i=b.dpDiv.find("iframe.ui-datepicker-cover");if(i.length){var g=d.datepicker._getBorders(b.dpDiv);i.css({left:-g[0],top:-g[1],width:b.dpDiv.outerWidth(),height:b.dpDiv.outerHeight()})}};b.dpDiv.zIndex(d(a).zIndex()+1);d.datepicker._datepickerShowing= | |
| 512 | +true;d.effects&&d.effects[c]?b.dpDiv.show(c,d.datepicker._get(b,"showOptions"),f,h):b.dpDiv[c||"show"](c?f:null,h);if(!c||!f)h();b.input.is(":visible")&&!b.input.is(":disabled")&&b.input.focus();d.datepicker._curInst=b}}}},_updateDatepicker:function(a){this.maxRows=4;var b=d.datepicker._getBorders(a.dpDiv);J=a;a.dpDiv.empty().append(this._generateHTML(a));var c=a.dpDiv.find("iframe.ui-datepicker-cover");c.length&&c.css({left:-b[0],top:-b[1],width:a.dpDiv.outerWidth(),height:a.dpDiv.outerHeight()}); | |
| 513 | +a.dpDiv.find("."+this._dayOverClass+" a").mouseover();b=this._getNumberOfMonths(a);c=b[1];a.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width("");c>1&&a.dpDiv.addClass("ui-datepicker-multi-"+c).css("width",17*c+"em");a.dpDiv[(b[0]!=1||b[1]!=1?"add":"remove")+"Class"]("ui-datepicker-multi");a.dpDiv[(this._get(a,"isRTL")?"add":"remove")+"Class"]("ui-datepicker-rtl");a==d.datepicker._curInst&&d.datepicker._datepickerShowing&&a.input&&a.input.is(":visible")&& | |
| 514 | +!a.input.is(":disabled")&&a.input[0]!=document.activeElement&&a.input.focus();if(a.yearshtml){var e=a.yearshtml;setTimeout(function(){e===a.yearshtml&&a.yearshtml&&a.dpDiv.find("select.ui-datepicker-year:first").replaceWith(a.yearshtml);e=a.yearshtml=null},0)}},_getBorders:function(a){var b=function(c){return{thin:1,medium:2,thick:3}[c]||c};return[parseFloat(b(a.css("border-left-width"))),parseFloat(b(a.css("border-top-width")))]},_checkOffset:function(a,b,c){var e=a.dpDiv.outerWidth(),f=a.dpDiv.outerHeight(), | |
| 515 | +h=a.input?a.input.outerWidth():0,i=a.input?a.input.outerHeight():0,g=document.documentElement.clientWidth+d(document).scrollLeft(),j=document.documentElement.clientHeight+d(document).scrollTop();b.left-=this._get(a,"isRTL")?e-h:0;b.left-=c&&b.left==a.input.offset().left?d(document).scrollLeft():0;b.top-=c&&b.top==a.input.offset().top+i?d(document).scrollTop():0;b.left-=Math.min(b.left,b.left+e>g&&g>e?Math.abs(b.left+e-g):0);b.top-=Math.min(b.top,b.top+f>j&&j>f?Math.abs(f+i):0);return b},_findPos:function(a){for(var b= | |
| 516 | +this._get(this._getInst(a),"isRTL");a&&(a.type=="hidden"||a.nodeType!=1||d.expr.filters.hidden(a));)a=a[b?"previousSibling":"nextSibling"];a=d(a).offset();return[a.left,a.top]},_triggerOnClose:function(a){var b=this._get(a,"onClose");if(b)b.apply(a.input?a.input[0]:null,[a.input?a.input.val():"",a])},_hideDatepicker:function(a){var b=this._curInst;if(!(!b||a&&b!=d.data(a,"datepicker")))if(this._datepickerShowing){a=this._get(b,"showAnim");var c=this._get(b,"duration"),e=function(){d.datepicker._tidyDialog(b); | |
| 517 | +this._curInst=null};d.effects&&d.effects[a]?b.dpDiv.hide(a,d.datepicker._get(b,"showOptions"),c,e):b.dpDiv[a=="slideDown"?"slideUp":a=="fadeIn"?"fadeOut":"hide"](a?c:null,e);a||e();d.datepicker._triggerOnClose(b);this._datepickerShowing=false;this._lastInput=null;if(this._inDialog){this._dialogInput.css({position:"absolute",left:"0",top:"-100px"});if(d.blockUI){d.unblockUI();d("body").append(this.dpDiv)}}this._inDialog=false}},_tidyDialog:function(a){a.dpDiv.removeClass(this._dialogClass).unbind(".ui-datepicker-calendar")}, | |
| 518 | +_checkExternalClick:function(a){if(d.datepicker._curInst){a=d(a.target);a[0].id!=d.datepicker._mainDivId&&a.parents("#"+d.datepicker._mainDivId).length==0&&!a.hasClass(d.datepicker.markerClassName)&&!a.hasClass(d.datepicker._triggerClass)&&d.datepicker._datepickerShowing&&!(d.datepicker._inDialog&&d.blockUI)&&d.datepicker._hideDatepicker()}},_adjustDate:function(a,b,c){a=d(a);var e=this._getInst(a[0]);if(!this._isDisabledDatepicker(a[0])){this._adjustInstDate(e,b+(c=="M"?this._get(e,"showCurrentAtPos"): | |
| 519 | +0),c);this._updateDatepicker(e)}},_gotoToday:function(a){a=d(a);var b=this._getInst(a[0]);if(this._get(b,"gotoCurrent")&&b.currentDay){b.selectedDay=b.currentDay;b.drawMonth=b.selectedMonth=b.currentMonth;b.drawYear=b.selectedYear=b.currentYear}else{var c=new Date;b.selectedDay=c.getDate();b.drawMonth=b.selectedMonth=c.getMonth();b.drawYear=b.selectedYear=c.getFullYear()}this._notifyChange(b);this._adjustDate(a)},_selectMonthYear:function(a,b,c){a=d(a);var e=this._getInst(a[0]);e["selected"+(c=="M"? | |
| 520 | +"Month":"Year")]=e["draw"+(c=="M"?"Month":"Year")]=parseInt(b.options[b.selectedIndex].value,10);this._notifyChange(e);this._adjustDate(a)},_selectDay:function(a,b,c,e){var f=d(a);if(!(d(e).hasClass(this._unselectableClass)||this._isDisabledDatepicker(f[0]))){f=this._getInst(f[0]);f.selectedDay=f.currentDay=d("a",e).html();f.selectedMonth=f.currentMonth=b;f.selectedYear=f.currentYear=c;this._selectDate(a,this._formatDate(f,f.currentDay,f.currentMonth,f.currentYear))}},_clearDate:function(a){a=d(a); | |
| 521 | +this._getInst(a[0]);this._selectDate(a,"")},_selectDate:function(a,b){a=this._getInst(d(a)[0]);b=b!=null?b:this._formatDate(a);a.input&&a.input.val(b);this._updateAlternate(a);var c=this._get(a,"onSelect");if(c)c.apply(a.input?a.input[0]:null,[b,a]);else a.input&&a.input.trigger("change");if(a.inline)this._updateDatepicker(a);else{this._hideDatepicker();this._lastInput=a.input[0];typeof a.input[0]!="object"&&a.input.focus();this._lastInput=null}},_updateAlternate:function(a){var b=this._get(a,"altField"); | |
| 522 | +if(b){var c=this._get(a,"altFormat")||this._get(a,"dateFormat"),e=this._getDate(a),f=this.formatDate(c,e,this._getFormatConfig(a));d(b).each(function(){d(this).val(f)})}},noWeekends:function(a){a=a.getDay();return[a>0&&a<6,""]},iso8601Week:function(a){a=new Date(a.getTime());a.setDate(a.getDate()+4-(a.getDay()||7));var b=a.getTime();a.setMonth(0);a.setDate(1);return Math.floor(Math.round((b-a)/864E5)/7)+1},parseDate:function(a,b,c){if(a==null||b==null)throw"Invalid arguments";b=typeof b=="object"? | |
| 523 | +b.toString():b+"";if(b=="")return null;var e=(c?c.shortYearCutoff:null)||this._defaults.shortYearCutoff;e=typeof e!="string"?e:(new Date).getFullYear()%100+parseInt(e,10);for(var f=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,h=(c?c.dayNames:null)||this._defaults.dayNames,i=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort,g=(c?c.monthNames:null)||this._defaults.monthNames,j=c=-1,l=-1,u=-1,k=false,o=function(p){(p=A+1<a.length&&a.charAt(A+1)==p)&&A++;return p},m=function(p){var D= | |
| 524 | +o(p);p=new RegExp("^\\d{1,"+(p=="@"?14:p=="!"?20:p=="y"&&D?4:p=="o"?3:2)+"}");p=b.substring(q).match(p);if(!p)throw"Missing number at position "+q;q+=p[0].length;return parseInt(p[0],10)},n=function(p,D,K){p=d.map(o(p)?K:D,function(w,x){return[[x,w]]}).sort(function(w,x){return-(w[1].length-x[1].length)});var E=-1;d.each(p,function(w,x){w=x[1];if(b.substr(q,w.length).toLowerCase()==w.toLowerCase()){E=x[0];q+=w.length;return false}});if(E!=-1)return E+1;else throw"Unknown name at position "+q;},s= | |
| 525 | +function(){if(b.charAt(q)!=a.charAt(A))throw"Unexpected literal at position "+q;q++},q=0,A=0;A<a.length;A++)if(k)if(a.charAt(A)=="'"&&!o("'"))k=false;else s();else switch(a.charAt(A)){case "d":l=m("d");break;case "D":n("D",f,h);break;case "o":u=m("o");break;case "m":j=m("m");break;case "M":j=n("M",i,g);break;case "y":c=m("y");break;case "@":var v=new Date(m("@"));c=v.getFullYear();j=v.getMonth()+1;l=v.getDate();break;case "!":v=new Date((m("!")-this._ticksTo1970)/1E4);c=v.getFullYear();j=v.getMonth()+ | |
| 526 | +1;l=v.getDate();break;case "'":if(o("'"))s();else k=true;break;default:s()}if(q<b.length)throw"Extra/unparsed characters found in date: "+b.substring(q);if(c==-1)c=(new Date).getFullYear();else if(c<100)c+=(new Date).getFullYear()-(new Date).getFullYear()%100+(c<=e?0:-100);if(u>-1){j=1;l=u;do{e=this._getDaysInMonth(c,j-1);if(l<=e)break;j++;l-=e}while(1)}v=this._daylightSavingAdjust(new Date(c,j-1,l));if(v.getFullYear()!=c||v.getMonth()+1!=j||v.getDate()!=l)throw"Invalid date";return v},ATOM:"yy-mm-dd", | |
| 527 | +COOKIE:"D, dd M yy",ISO_8601:"yy-mm-dd",RFC_822:"D, d M y",RFC_850:"DD, dd-M-y",RFC_1036:"D, d M y",RFC_1123:"D, d M yy",RFC_2822:"D, d M yy",RSS:"D, d M y",TICKS:"!",TIMESTAMP:"@",W3C:"yy-mm-dd",_ticksTo1970:(718685+Math.floor(492.5)-Math.floor(19.7)+Math.floor(4.925))*24*60*60*1E7,formatDate:function(a,b,c){if(!b)return"";var e=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,f=(c?c.dayNames:null)||this._defaults.dayNames,h=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort;c=(c?c.monthNames: | |
| 528 | +null)||this._defaults.monthNames;var i=function(o){(o=k+1<a.length&&a.charAt(k+1)==o)&&k++;return o},g=function(o,m,n){m=""+m;if(i(o))for(;m.length<n;)m="0"+m;return m},j=function(o,m,n,s){return i(o)?s[m]:n[m]},l="",u=false;if(b)for(var k=0;k<a.length;k++)if(u)if(a.charAt(k)=="'"&&!i("'"))u=false;else l+=a.charAt(k);else switch(a.charAt(k)){case "d":l+=g("d",b.getDate(),2);break;case "D":l+=j("D",b.getDay(),e,f);break;case "o":l+=g("o",Math.round(((new Date(b.getFullYear(),b.getMonth(),b.getDate())).getTime()- | |
| 529 | +(new Date(b.getFullYear(),0,0)).getTime())/864E5),3);break;case "m":l+=g("m",b.getMonth()+1,2);break;case "M":l+=j("M",b.getMonth(),h,c);break;case "y":l+=i("y")?b.getFullYear():(b.getYear()%100<10?"0":"")+b.getYear()%100;break;case "@":l+=b.getTime();break;case "!":l+=b.getTime()*1E4+this._ticksTo1970;break;case "'":if(i("'"))l+="'";else u=true;break;default:l+=a.charAt(k)}return l},_possibleChars:function(a){for(var b="",c=false,e=function(h){(h=f+1<a.length&&a.charAt(f+1)==h)&&f++;return h},f= | |
| 530 | +0;f<a.length;f++)if(c)if(a.charAt(f)=="'"&&!e("'"))c=false;else b+=a.charAt(f);else switch(a.charAt(f)){case "d":case "m":case "y":case "@":b+="0123456789";break;case "D":case "M":return null;case "'":if(e("'"))b+="'";else c=true;break;default:b+=a.charAt(f)}return b},_get:function(a,b){return a.settings[b]!==C?a.settings[b]:this._defaults[b]},_setDateFromField:function(a,b){if(a.input.val()!=a.lastVal){var c=this._get(a,"dateFormat"),e=a.lastVal=a.input?a.input.val():null,f,h;f=h=this._getDefaultDate(a); | |
| 531 | +var i=this._getFormatConfig(a);try{f=this.parseDate(c,e,i)||h}catch(g){this.log(g);e=b?"":e}a.selectedDay=f.getDate();a.drawMonth=a.selectedMonth=f.getMonth();a.drawYear=a.selectedYear=f.getFullYear();a.currentDay=e?f.getDate():0;a.currentMonth=e?f.getMonth():0;a.currentYear=e?f.getFullYear():0;this._adjustInstDate(a)}},_getDefaultDate:function(a){return this._restrictMinMax(a,this._determineDate(a,this._get(a,"defaultDate"),new Date))},_determineDate:function(a,b,c){var e=function(h){var i=new Date; | |
| 532 | +i.setDate(i.getDate()+h);return i},f=function(h){try{return d.datepicker.parseDate(d.datepicker._get(a,"dateFormat"),h,d.datepicker._getFormatConfig(a))}catch(i){}var g=(h.toLowerCase().match(/^c/)?d.datepicker._getDate(a):null)||new Date,j=g.getFullYear(),l=g.getMonth();g=g.getDate();for(var u=/([+-]?[0-9]+)\s*(d|D|w|W|m|M|y|Y)?/g,k=u.exec(h);k;){switch(k[2]||"d"){case "d":case "D":g+=parseInt(k[1],10);break;case "w":case "W":g+=parseInt(k[1],10)*7;break;case "m":case "M":l+=parseInt(k[1],10);g= | |
| 533 | +Math.min(g,d.datepicker._getDaysInMonth(j,l));break;case "y":case "Y":j+=parseInt(k[1],10);g=Math.min(g,d.datepicker._getDaysInMonth(j,l));break}k=u.exec(h)}return new Date(j,l,g)};if(b=(b=b==null||b===""?c:typeof b=="string"?f(b):typeof b=="number"?isNaN(b)?c:e(b):new Date(b.getTime()))&&b.toString()=="Invalid Date"?c:b){b.setHours(0);b.setMinutes(0);b.setSeconds(0);b.setMilliseconds(0)}return this._daylightSavingAdjust(b)},_daylightSavingAdjust:function(a){if(!a)return null;a.setHours(a.getHours()> | |
| 534 | +12?a.getHours()+2:0);return a},_setDate:function(a,b,c){var e=!b,f=a.selectedMonth,h=a.selectedYear;b=this._restrictMinMax(a,this._determineDate(a,b,new Date));a.selectedDay=a.currentDay=b.getDate();a.drawMonth=a.selectedMonth=a.currentMonth=b.getMonth();a.drawYear=a.selectedYear=a.currentYear=b.getFullYear();if((f!=a.selectedMonth||h!=a.selectedYear)&&!c)this._notifyChange(a);this._adjustInstDate(a);if(a.input)a.input.val(e?"":this._formatDate(a))},_getDate:function(a){return!a.currentYear||a.input&& | |
| 535 | +a.input.val()==""?null:this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay))},_generateHTML:function(a){var b=new Date;b=this._daylightSavingAdjust(new Date(b.getFullYear(),b.getMonth(),b.getDate()));var c=this._get(a,"isRTL"),e=this._get(a,"showButtonPanel"),f=this._get(a,"hideIfNoPrevNext"),h=this._get(a,"navigationAsDateFormat"),i=this._getNumberOfMonths(a),g=this._get(a,"showCurrentAtPos"),j=this._get(a,"stepMonths"),l=i[0]!=1||i[1]!=1,u=this._daylightSavingAdjust(!a.currentDay? | |
| 536 | +new Date(9999,9,9):new Date(a.currentYear,a.currentMonth,a.currentDay)),k=this._getMinMaxDate(a,"min"),o=this._getMinMaxDate(a,"max");g=a.drawMonth-g;var m=a.drawYear;if(g<0){g+=12;m--}if(o){var n=this._daylightSavingAdjust(new Date(o.getFullYear(),o.getMonth()-i[0]*i[1]+1,o.getDate()));for(n=k&&n<k?k:n;this._daylightSavingAdjust(new Date(m,g,1))>n;){g--;if(g<0){g=11;m--}}}a.drawMonth=g;a.drawYear=m;n=this._get(a,"prevText");n=!h?n:this.formatDate(n,this._daylightSavingAdjust(new Date(m,g-j,1)),this._getFormatConfig(a)); | |
| 537 | +n=this._canAdjustMonth(a,-1,m,g)?'<a class="ui-datepicker-prev ui-corner-all" onclick="DP_jQuery_'+B+".datepicker._adjustDate('#"+a.id+"', -"+j+", 'M');\" title=\""+n+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"e":"w")+'">'+n+"</span></a>":f?"":'<a class="ui-datepicker-prev ui-corner-all ui-state-disabled" title="'+n+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"e":"w")+'">'+n+"</span></a>";var s=this._get(a,"nextText");s=!h?s:this.formatDate(s,this._daylightSavingAdjust(new Date(m, | |
| 538 | +g+j,1)),this._getFormatConfig(a));f=this._canAdjustMonth(a,+1,m,g)?'<a class="ui-datepicker-next ui-corner-all" onclick="DP_jQuery_'+B+".datepicker._adjustDate('#"+a.id+"', +"+j+", 'M');\" title=\""+s+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"w":"e")+'">'+s+"</span></a>":f?"":'<a class="ui-datepicker-next ui-corner-all ui-state-disabled" title="'+s+'"><span class="ui-icon ui-icon-circle-triangle-'+(c?"w":"e")+'">'+s+"</span></a>";j=this._get(a,"currentText");s=this._get(a,"gotoCurrent")&& | |
| 539 | +a.currentDay?u:b;j=!h?j:this.formatDate(j,s,this._getFormatConfig(a));h=!a.inline?'<button type="button" class="ui-datepicker-close ui-state-default ui-priority-primary ui-corner-all" onclick="DP_jQuery_'+B+'.datepicker._hideDatepicker();">'+this._get(a,"closeText")+"</button>":"";e=e?'<div class="ui-datepicker-buttonpane ui-widget-content">'+(c?h:"")+(this._isInRange(a,s)?'<button type="button" class="ui-datepicker-current ui-state-default ui-priority-secondary ui-corner-all" onclick="DP_jQuery_'+ | |
| 540 | +B+".datepicker._gotoToday('#"+a.id+"');\">"+j+"</button>":"")+(c?"":h)+"</div>":"";h=parseInt(this._get(a,"firstDay"),10);h=isNaN(h)?0:h;j=this._get(a,"showWeek");s=this._get(a,"dayNames");this._get(a,"dayNamesShort");var q=this._get(a,"dayNamesMin"),A=this._get(a,"monthNames"),v=this._get(a,"monthNamesShort"),p=this._get(a,"beforeShowDay"),D=this._get(a,"showOtherMonths"),K=this._get(a,"selectOtherMonths");this._get(a,"calculateWeek");for(var E=this._getDefaultDate(a),w="",x=0;x<i[0];x++){var O= | |
| 541 | +"";this.maxRows=4;for(var G=0;G<i[1];G++){var P=this._daylightSavingAdjust(new Date(m,g,a.selectedDay)),t=" ui-corner-all",y="";if(l){y+='<div class="ui-datepicker-group';if(i[1]>1)switch(G){case 0:y+=" ui-datepicker-group-first";t=" ui-corner-"+(c?"right":"left");break;case i[1]-1:y+=" ui-datepicker-group-last";t=" ui-corner-"+(c?"left":"right");break;default:y+=" ui-datepicker-group-middle";t="";break}y+='">'}y+='<div class="ui-datepicker-header ui-widget-header ui-helper-clearfix'+t+'">'+(/all|left/.test(t)&& | |
| 542 | +x==0?c?f:n:"")+(/all|right/.test(t)&&x==0?c?n:f:"")+this._generateMonthYearHeader(a,g,m,k,o,x>0||G>0,A,v)+'</div><table class="ui-datepicker-calendar"><thead><tr>';var z=j?'<th class="ui-datepicker-week-col">'+this._get(a,"weekHeader")+"</th>":"";for(t=0;t<7;t++){var r=(t+h)%7;z+="<th"+((t+h+6)%7>=5?' class="ui-datepicker-week-end"':"")+'><span title="'+s[r]+'">'+q[r]+"</span></th>"}y+=z+"</tr></thead><tbody>";z=this._getDaysInMonth(m,g);if(m==a.selectedYear&&g==a.selectedMonth)a.selectedDay=Math.min(a.selectedDay, | |
| 543 | +z);t=(this._getFirstDayOfMonth(m,g)-h+7)%7;z=Math.ceil((t+z)/7);this.maxRows=z=l?this.maxRows>z?this.maxRows:z:z;r=this._daylightSavingAdjust(new Date(m,g,1-t));for(var Q=0;Q<z;Q++){y+="<tr>";var R=!j?"":'<td class="ui-datepicker-week-col">'+this._get(a,"calculateWeek")(r)+"</td>";for(t=0;t<7;t++){var I=p?p.apply(a.input?a.input[0]:null,[r]):[true,""],F=r.getMonth()!=g,L=F&&!K||!I[0]||k&&r<k||o&&r>o;R+='<td class="'+((t+h+6)%7>=5?" ui-datepicker-week-end":"")+(F?" ui-datepicker-other-month":"")+(r.getTime()== | |
| 544 | +P.getTime()&&g==a.selectedMonth&&a._keyEvent||E.getTime()==r.getTime()&&E.getTime()==P.getTime()?" "+this._dayOverClass:"")+(L?" "+this._unselectableClass+" ui-state-disabled":"")+(F&&!D?"":" "+I[1]+(r.getTime()==u.getTime()?" "+this._currentClass:"")+(r.getTime()==b.getTime()?" ui-datepicker-today":""))+'"'+((!F||D)&&I[2]?' title="'+I[2]+'"':"")+(L?"":' onclick="DP_jQuery_'+B+".datepicker._selectDay('#"+a.id+"',"+r.getMonth()+","+r.getFullYear()+', this);return false;"')+">"+(F&&!D?" ":L?'<span class="ui-state-default">'+ | |
| 545 | +r.getDate()+"</span>":'<a class="ui-state-default'+(r.getTime()==b.getTime()?" ui-state-highlight":"")+(r.getTime()==u.getTime()?" ui-state-active":"")+(F?" ui-priority-secondary":"")+'" href="#">'+r.getDate()+"</a>")+"</td>";r.setDate(r.getDate()+1);r=this._daylightSavingAdjust(r)}y+=R+"</tr>"}g++;if(g>11){g=0;m++}y+="</tbody></table>"+(l?"</div>"+(i[0]>0&&G==i[1]-1?'<div class="ui-datepicker-row-break"></div>':""):"");O+=y}w+=O}w+=e+(d.browser.msie&&parseInt(d.browser.version,10)<7&&!a.inline?'<iframe src="javascript:false;" class="ui-datepicker-cover" frameborder="0"></iframe>': | |
| 546 | +"");a._keyEvent=false;return w},_generateMonthYearHeader:function(a,b,c,e,f,h,i,g){var j=this._get(a,"changeMonth"),l=this._get(a,"changeYear"),u=this._get(a,"showMonthAfterYear"),k='<div class="ui-datepicker-title">',o="";if(h||!j)o+='<span class="ui-datepicker-month">'+i[b]+"</span>";else{i=e&&e.getFullYear()==c;var m=f&&f.getFullYear()==c;o+='<select class="ui-datepicker-month" onchange="DP_jQuery_'+B+".datepicker._selectMonthYear('#"+a.id+"', this, 'M');\" >";for(var n=0;n<12;n++)if((!i||n>=e.getMonth())&& | |
| 547 | +(!m||n<=f.getMonth()))o+='<option value="'+n+'"'+(n==b?' selected="selected"':"")+">"+g[n]+"</option>";o+="</select>"}u||(k+=o+(h||!(j&&l)?" ":""));if(!a.yearshtml){a.yearshtml="";if(h||!l)k+='<span class="ui-datepicker-year">'+c+"</span>";else{g=this._get(a,"yearRange").split(":");var s=(new Date).getFullYear();i=function(q){q=q.match(/c[+-].*/)?c+parseInt(q.substring(1),10):q.match(/[+-].*/)?s+parseInt(q,10):parseInt(q,10);return isNaN(q)?s:q};b=i(g[0]);g=Math.max(b,i(g[1]||""));b=e?Math.max(b, | |
| 548 | +e.getFullYear()):b;g=f?Math.min(g,f.getFullYear()):g;for(a.yearshtml+='<select class="ui-datepicker-year" onchange="DP_jQuery_'+B+".datepicker._selectMonthYear('#"+a.id+"', this, 'Y');\" >";b<=g;b++)a.yearshtml+='<option value="'+b+'"'+(b==c?' selected="selected"':"")+">"+b+"</option>";a.yearshtml+="</select>";k+=a.yearshtml;a.yearshtml=null}}k+=this._get(a,"yearSuffix");if(u)k+=(h||!(j&&l)?" ":"")+o;k+="</div>";return k},_adjustInstDate:function(a,b,c){var e=a.drawYear+(c=="Y"?b:0),f=a.drawMonth+ | |
| 549 | +(c=="M"?b:0);b=Math.min(a.selectedDay,this._getDaysInMonth(e,f))+(c=="D"?b:0);e=this._restrictMinMax(a,this._daylightSavingAdjust(new Date(e,f,b)));a.selectedDay=e.getDate();a.drawMonth=a.selectedMonth=e.getMonth();a.drawYear=a.selectedYear=e.getFullYear();if(c=="M"||c=="Y")this._notifyChange(a)},_restrictMinMax:function(a,b){var c=this._getMinMaxDate(a,"min");a=this._getMinMaxDate(a,"max");b=c&&b<c?c:b;return b=a&&b>a?a:b},_notifyChange:function(a){var b=this._get(a,"onChangeMonthYear");if(b)b.apply(a.input? | |
| 550 | +a.input[0]:null,[a.selectedYear,a.selectedMonth+1,a])},_getNumberOfMonths:function(a){a=this._get(a,"numberOfMonths");return a==null?[1,1]:typeof a=="number"?[1,a]:a},_getMinMaxDate:function(a,b){return this._determineDate(a,this._get(a,b+"Date"),null)},_getDaysInMonth:function(a,b){return 32-this._daylightSavingAdjust(new Date(a,b,32)).getDate()},_getFirstDayOfMonth:function(a,b){return(new Date(a,b,1)).getDay()},_canAdjustMonth:function(a,b,c,e){var f=this._getNumberOfMonths(a);c=this._daylightSavingAdjust(new Date(c, | |
| 551 | +e+(b<0?b:f[0]*f[1]),1));b<0&&c.setDate(this._getDaysInMonth(c.getFullYear(),c.getMonth()));return this._isInRange(a,c)},_isInRange:function(a,b){var c=this._getMinMaxDate(a,"min");a=this._getMinMaxDate(a,"max");return(!c||b.getTime()>=c.getTime())&&(!a||b.getTime()<=a.getTime())},_getFormatConfig:function(a){var b=this._get(a,"shortYearCutoff");b=typeof b!="string"?b:(new Date).getFullYear()%100+parseInt(b,10);return{shortYearCutoff:b,dayNamesShort:this._get(a,"dayNamesShort"),dayNames:this._get(a, | |
| 552 | +"dayNames"),monthNamesShort:this._get(a,"monthNamesShort"),monthNames:this._get(a,"monthNames")}},_formatDate:function(a,b,c,e){if(!b){a.currentDay=a.selectedDay;a.currentMonth=a.selectedMonth;a.currentYear=a.selectedYear}b=b?typeof b=="object"?b:this._daylightSavingAdjust(new Date(e,c,b)):this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay));return this.formatDate(this._get(a,"dateFormat"),b,this._getFormatConfig(a))}});d.fn.datepicker=function(a){if(!this.length)return this; | |
| 553 | +if(!d.datepicker.initialized){d(document).mousedown(d.datepicker._checkExternalClick).find("body").append(d.datepicker.dpDiv);d.datepicker.initialized=true}var b=Array.prototype.slice.call(arguments,1);if(typeof a=="string"&&(a=="isDisabled"||a=="getDate"||a=="widget"))return d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,[this[0]].concat(b));if(a=="option"&&arguments.length==2&&typeof arguments[1]=="string")return d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,[this[0]].concat(b));return this.each(function(){typeof a== | |
| 554 | +"string"?d.datepicker["_"+a+"Datepicker"].apply(d.datepicker,[this].concat(b)):d.datepicker._attachDatepicker(this,a)})};d.datepicker=new M;d.datepicker.initialized=false;d.datepicker.uuid=(new Date).getTime();d.datepicker.version="1.8.16";window["DP_jQuery_"+B]=d})(jQuery); | |
| 555 | +;/* | |
| 556 | + * jQuery UI Progressbar 1.8.16 | |
| 557 | + * | |
| 558 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 559 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 560 | + * http://jquery.org/license | |
| 561 | + * | |
| 562 | + * http://docs.jquery.com/UI/Progressbar | |
| 563 | + * | |
| 564 | + * Depends: | |
| 565 | + * jquery.ui.core.js | |
| 566 | + * jquery.ui.widget.js | |
| 567 | + */ | |
| 568 | +(function(b,d){b.widget("ui.progressbar",{options:{value:0,max:100},min:0,_create:function(){this.element.addClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").attr({role:"progressbar","aria-valuemin":this.min,"aria-valuemax":this.options.max,"aria-valuenow":this._value()});this.valueDiv=b("<div class='ui-progressbar-value ui-widget-header ui-corner-left'></div>").appendTo(this.element);this.oldValue=this._value();this._refreshValue()},destroy:function(){this.element.removeClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").removeAttr("role").removeAttr("aria-valuemin").removeAttr("aria-valuemax").removeAttr("aria-valuenow"); | |
| 569 | +this.valueDiv.remove();b.Widget.prototype.destroy.apply(this,arguments)},value:function(a){if(a===d)return this._value();this._setOption("value",a);return this},_setOption:function(a,c){if(a==="value"){this.options.value=c;this._refreshValue();this._value()===this.options.max&&this._trigger("complete")}b.Widget.prototype._setOption.apply(this,arguments)},_value:function(){var a=this.options.value;if(typeof a!=="number")a=0;return Math.min(this.options.max,Math.max(this.min,a))},_percentage:function(){return 100* | |
| 570 | +this._value()/this.options.max},_refreshValue:function(){var a=this.value(),c=this._percentage();if(this.oldValue!==a){this.oldValue=a;this._trigger("change")}this.valueDiv.toggle(a>this.min).toggleClass("ui-corner-right",a===this.options.max).width(c.toFixed(0)+"%");this.element.attr("aria-valuenow",a)}});b.extend(b.ui.progressbar,{version:"1.8.16"})})(jQuery); | |
| 571 | +;/* | |
| 572 | + * jQuery UI Effects 1.8.16 | |
| 573 | + * | |
| 574 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 575 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 576 | + * http://jquery.org/license | |
| 577 | + * | |
| 578 | + * http://docs.jquery.com/UI/Effects/ | |
| 579 | + */ | |
| 580 | +jQuery.effects||function(f,j){function m(c){var a;if(c&&c.constructor==Array&&c.length==3)return c;if(a=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(c))return[parseInt(a[1],10),parseInt(a[2],10),parseInt(a[3],10)];if(a=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(c))return[parseFloat(a[1])*2.55,parseFloat(a[2])*2.55,parseFloat(a[3])*2.55];if(a=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(c))return[parseInt(a[1], | |
| 581 | +16),parseInt(a[2],16),parseInt(a[3],16)];if(a=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(c))return[parseInt(a[1]+a[1],16),parseInt(a[2]+a[2],16),parseInt(a[3]+a[3],16)];if(/rgba\(0, 0, 0, 0\)/.exec(c))return n.transparent;return n[f.trim(c).toLowerCase()]}function s(c,a){var b;do{b=f.curCSS(c,a);if(b!=""&&b!="transparent"||f.nodeName(c,"body"))break;a="backgroundColor"}while(c=c.parentNode);return m(b)}function o(){var c=document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle, | |
| 582 | +a={},b,d;if(c&&c.length&&c[0]&&c[c[0]])for(var e=c.length;e--;){b=c[e];if(typeof c[b]=="string"){d=b.replace(/\-(\w)/g,function(g,h){return h.toUpperCase()});a[d]=c[b]}}else for(b in c)if(typeof c[b]==="string")a[b]=c[b];return a}function p(c){var a,b;for(a in c){b=c[a];if(b==null||f.isFunction(b)||a in t||/scrollbar/.test(a)||!/color/i.test(a)&&isNaN(parseFloat(b)))delete c[a]}return c}function u(c,a){var b={_:0},d;for(d in a)if(c[d]!=a[d])b[d]=a[d];return b}function k(c,a,b,d){if(typeof c=="object"){d= | |
| 583 | +a;b=null;a=c;c=a.effect}if(f.isFunction(a)){d=a;b=null;a={}}if(typeof a=="number"||f.fx.speeds[a]){d=b;b=a;a={}}if(f.isFunction(b)){d=b;b=null}a=a||{};b=b||a.duration;b=f.fx.off?0:typeof b=="number"?b:b in f.fx.speeds?f.fx.speeds[b]:f.fx.speeds._default;d=d||a.complete;return[c,a,b,d]}function l(c){if(!c||typeof c==="number"||f.fx.speeds[c])return true;if(typeof c==="string"&&!f.effects[c])return true;return false}f.effects={};f.each(["backgroundColor","borderBottomColor","borderLeftColor","borderRightColor", | |
| 584 | +"borderTopColor","borderColor","color","outlineColor"],function(c,a){f.fx.step[a]=function(b){if(!b.colorInit){b.start=s(b.elem,a);b.end=m(b.end);b.colorInit=true}b.elem.style[a]="rgb("+Math.max(Math.min(parseInt(b.pos*(b.end[0]-b.start[0])+b.start[0],10),255),0)+","+Math.max(Math.min(parseInt(b.pos*(b.end[1]-b.start[1])+b.start[1],10),255),0)+","+Math.max(Math.min(parseInt(b.pos*(b.end[2]-b.start[2])+b.start[2],10),255),0)+")"}});var n={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0, | |
| 585 | +0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211, | |
| 586 | +211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0],transparent:[255,255,255]},q=["add","remove","toggle"],t={border:1,borderBottom:1,borderColor:1,borderLeft:1,borderRight:1,borderTop:1,borderWidth:1,margin:1,padding:1};f.effects.animateClass=function(c,a,b, | |
| 587 | +d){if(f.isFunction(b)){d=b;b=null}return this.queue(function(){var e=f(this),g=e.attr("style")||" ",h=p(o.call(this)),r,v=e.attr("class");f.each(q,function(w,i){c[i]&&e[i+"Class"](c[i])});r=p(o.call(this));e.attr("class",v);e.animate(u(h,r),{queue:false,duration:a,easing:b,complete:function(){f.each(q,function(w,i){c[i]&&e[i+"Class"](c[i])});if(typeof e.attr("style")=="object"){e.attr("style").cssText="";e.attr("style").cssText=g}else e.attr("style",g);d&&d.apply(this,arguments);f.dequeue(this)}})})}; | |
| 588 | +f.fn.extend({_addClass:f.fn.addClass,addClass:function(c,a,b,d){return a?f.effects.animateClass.apply(this,[{add:c},a,b,d]):this._addClass(c)},_removeClass:f.fn.removeClass,removeClass:function(c,a,b,d){return a?f.effects.animateClass.apply(this,[{remove:c},a,b,d]):this._removeClass(c)},_toggleClass:f.fn.toggleClass,toggleClass:function(c,a,b,d,e){return typeof a=="boolean"||a===j?b?f.effects.animateClass.apply(this,[a?{add:c}:{remove:c},b,d,e]):this._toggleClass(c,a):f.effects.animateClass.apply(this, | |
| 589 | +[{toggle:c},a,b,d])},switchClass:function(c,a,b,d,e){return f.effects.animateClass.apply(this,[{add:a,remove:c},b,d,e])}});f.extend(f.effects,{version:"1.8.16",save:function(c,a){for(var b=0;b<a.length;b++)a[b]!==null&&c.data("ec.storage."+a[b],c[0].style[a[b]])},restore:function(c,a){for(var b=0;b<a.length;b++)a[b]!==null&&c.css(a[b],c.data("ec.storage."+a[b]))},setMode:function(c,a){if(a=="toggle")a=c.is(":hidden")?"show":"hide";return a},getBaseline:function(c,a){var b;switch(c[0]){case "top":b= | |
| 590 | +0;break;case "middle":b=0.5;break;case "bottom":b=1;break;default:b=c[0]/a.height}switch(c[1]){case "left":c=0;break;case "center":c=0.5;break;case "right":c=1;break;default:c=c[1]/a.width}return{x:c,y:b}},createWrapper:function(c){if(c.parent().is(".ui-effects-wrapper"))return c.parent();var a={width:c.outerWidth(true),height:c.outerHeight(true),"float":c.css("float")},b=f("<div></div>").addClass("ui-effects-wrapper").css({fontSize:"100%",background:"transparent",border:"none",margin:0,padding:0}), | |
| 591 | +d=document.activeElement;c.wrap(b);if(c[0]===d||f.contains(c[0],d))f(d).focus();b=c.parent();if(c.css("position")=="static"){b.css({position:"relative"});c.css({position:"relative"})}else{f.extend(a,{position:c.css("position"),zIndex:c.css("z-index")});f.each(["top","left","bottom","right"],function(e,g){a[g]=c.css(g);if(isNaN(parseInt(a[g],10)))a[g]="auto"});c.css({position:"relative",top:0,left:0,right:"auto",bottom:"auto"})}return b.css(a).show()},removeWrapper:function(c){var a,b=document.activeElement; | |
| 592 | +if(c.parent().is(".ui-effects-wrapper")){a=c.parent().replaceWith(c);if(c[0]===b||f.contains(c[0],b))f(b).focus();return a}return c},setTransition:function(c,a,b,d){d=d||{};f.each(a,function(e,g){unit=c.cssUnit(g);if(unit[0]>0)d[g]=unit[0]*b+unit[1]});return d}});f.fn.extend({effect:function(c){var a=k.apply(this,arguments),b={options:a[1],duration:a[2],callback:a[3]};a=b.options.mode;var d=f.effects[c];if(f.fx.off||!d)return a?this[a](b.duration,b.callback):this.each(function(){b.callback&&b.callback.call(this)}); | |
| 593 | +return d.call(this,b)},_show:f.fn.show,show:function(c){if(l(c))return this._show.apply(this,arguments);else{var a=k.apply(this,arguments);a[1].mode="show";return this.effect.apply(this,a)}},_hide:f.fn.hide,hide:function(c){if(l(c))return this._hide.apply(this,arguments);else{var a=k.apply(this,arguments);a[1].mode="hide";return this.effect.apply(this,a)}},__toggle:f.fn.toggle,toggle:function(c){if(l(c)||typeof c==="boolean"||f.isFunction(c))return this.__toggle.apply(this,arguments);else{var a=k.apply(this, | |
| 594 | +arguments);a[1].mode="toggle";return this.effect.apply(this,a)}},cssUnit:function(c){var a=this.css(c),b=[];f.each(["em","px","%","pt"],function(d,e){if(a.indexOf(e)>0)b=[parseFloat(a),e]});return b}});f.easing.jswing=f.easing.swing;f.extend(f.easing,{def:"easeOutQuad",swing:function(c,a,b,d,e){return f.easing[f.easing.def](c,a,b,d,e)},easeInQuad:function(c,a,b,d,e){return d*(a/=e)*a+b},easeOutQuad:function(c,a,b,d,e){return-d*(a/=e)*(a-2)+b},easeInOutQuad:function(c,a,b,d,e){if((a/=e/2)<1)return d/ | |
| 595 | +2*a*a+b;return-d/2*(--a*(a-2)-1)+b},easeInCubic:function(c,a,b,d,e){return d*(a/=e)*a*a+b},easeOutCubic:function(c,a,b,d,e){return d*((a=a/e-1)*a*a+1)+b},easeInOutCubic:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a+b;return d/2*((a-=2)*a*a+2)+b},easeInQuart:function(c,a,b,d,e){return d*(a/=e)*a*a*a+b},easeOutQuart:function(c,a,b,d,e){return-d*((a=a/e-1)*a*a*a-1)+b},easeInOutQuart:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a*a+b;return-d/2*((a-=2)*a*a*a-2)+b},easeInQuint:function(c,a,b, | |
| 596 | +d,e){return d*(a/=e)*a*a*a*a+b},easeOutQuint:function(c,a,b,d,e){return d*((a=a/e-1)*a*a*a*a+1)+b},easeInOutQuint:function(c,a,b,d,e){if((a/=e/2)<1)return d/2*a*a*a*a*a+b;return d/2*((a-=2)*a*a*a*a+2)+b},easeInSine:function(c,a,b,d,e){return-d*Math.cos(a/e*(Math.PI/2))+d+b},easeOutSine:function(c,a,b,d,e){return d*Math.sin(a/e*(Math.PI/2))+b},easeInOutSine:function(c,a,b,d,e){return-d/2*(Math.cos(Math.PI*a/e)-1)+b},easeInExpo:function(c,a,b,d,e){return a==0?b:d*Math.pow(2,10*(a/e-1))+b},easeOutExpo:function(c, | |
| 597 | +a,b,d,e){return a==e?b+d:d*(-Math.pow(2,-10*a/e)+1)+b},easeInOutExpo:function(c,a,b,d,e){if(a==0)return b;if(a==e)return b+d;if((a/=e/2)<1)return d/2*Math.pow(2,10*(a-1))+b;return d/2*(-Math.pow(2,-10*--a)+2)+b},easeInCirc:function(c,a,b,d,e){return-d*(Math.sqrt(1-(a/=e)*a)-1)+b},easeOutCirc:function(c,a,b,d,e){return d*Math.sqrt(1-(a=a/e-1)*a)+b},easeInOutCirc:function(c,a,b,d,e){if((a/=e/2)<1)return-d/2*(Math.sqrt(1-a*a)-1)+b;return d/2*(Math.sqrt(1-(a-=2)*a)+1)+b},easeInElastic:function(c,a,b, | |
| 598 | +d,e){c=1.70158;var g=0,h=d;if(a==0)return b;if((a/=e)==1)return b+d;g||(g=e*0.3);if(h<Math.abs(d)){h=d;c=g/4}else c=g/(2*Math.PI)*Math.asin(d/h);return-(h*Math.pow(2,10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g))+b},easeOutElastic:function(c,a,b,d,e){c=1.70158;var g=0,h=d;if(a==0)return b;if((a/=e)==1)return b+d;g||(g=e*0.3);if(h<Math.abs(d)){h=d;c=g/4}else c=g/(2*Math.PI)*Math.asin(d/h);return h*Math.pow(2,-10*a)*Math.sin((a*e-c)*2*Math.PI/g)+d+b},easeInOutElastic:function(c,a,b,d,e){c=1.70158;var g= | |
| 599 | +0,h=d;if(a==0)return b;if((a/=e/2)==2)return b+d;g||(g=e*0.3*1.5);if(h<Math.abs(d)){h=d;c=g/4}else c=g/(2*Math.PI)*Math.asin(d/h);if(a<1)return-0.5*h*Math.pow(2,10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g)+b;return h*Math.pow(2,-10*(a-=1))*Math.sin((a*e-c)*2*Math.PI/g)*0.5+d+b},easeInBack:function(c,a,b,d,e,g){if(g==j)g=1.70158;return d*(a/=e)*a*((g+1)*a-g)+b},easeOutBack:function(c,a,b,d,e,g){if(g==j)g=1.70158;return d*((a=a/e-1)*a*((g+1)*a+g)+1)+b},easeInOutBack:function(c,a,b,d,e,g){if(g==j)g=1.70158; | |
| 600 | +if((a/=e/2)<1)return d/2*a*a*(((g*=1.525)+1)*a-g)+b;return d/2*((a-=2)*a*(((g*=1.525)+1)*a+g)+2)+b},easeInBounce:function(c,a,b,d,e){return d-f.easing.easeOutBounce(c,e-a,0,d,e)+b},easeOutBounce:function(c,a,b,d,e){return(a/=e)<1/2.75?d*7.5625*a*a+b:a<2/2.75?d*(7.5625*(a-=1.5/2.75)*a+0.75)+b:a<2.5/2.75?d*(7.5625*(a-=2.25/2.75)*a+0.9375)+b:d*(7.5625*(a-=2.625/2.75)*a+0.984375)+b},easeInOutBounce:function(c,a,b,d,e){if(a<e/2)return f.easing.easeInBounce(c,a*2,0,d,e)*0.5+b;return f.easing.easeOutBounce(c, | |
| 601 | +a*2-e,0,d,e)*0.5+d*0.5+b}})}(jQuery); | |
| 602 | +;/* | |
| 603 | + * jQuery UI Effects Blind 1.8.16 | |
| 604 | + * | |
| 605 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 606 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 607 | + * http://jquery.org/license | |
| 608 | + * | |
| 609 | + * http://docs.jquery.com/UI/Effects/Blind | |
| 610 | + * | |
| 611 | + * Depends: | |
| 612 | + * jquery.effects.core.js | |
| 613 | + */ | |
| 614 | +(function(b){b.effects.blind=function(c){return this.queue(function(){var a=b(this),g=["position","top","bottom","left","right"],f=b.effects.setMode(a,c.options.mode||"hide"),d=c.options.direction||"vertical";b.effects.save(a,g);a.show();var e=b.effects.createWrapper(a).css({overflow:"hidden"}),h=d=="vertical"?"height":"width";d=d=="vertical"?e.height():e.width();f=="show"&&e.css(h,0);var i={};i[h]=f=="show"?d:0;e.animate(i,c.duration,c.options.easing,function(){f=="hide"&&a.hide();b.effects.restore(a, | |
| 615 | +g);b.effects.removeWrapper(a);c.callback&&c.callback.apply(a[0],arguments);a.dequeue()})})}})(jQuery); | |
| 616 | +;/* | |
| 617 | + * jQuery UI Effects Bounce 1.8.16 | |
| 618 | + * | |
| 619 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 620 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 621 | + * http://jquery.org/license | |
| 622 | + * | |
| 623 | + * http://docs.jquery.com/UI/Effects/Bounce | |
| 624 | + * | |
| 625 | + * Depends: | |
| 626 | + * jquery.effects.core.js | |
| 627 | + */ | |
| 628 | +(function(e){e.effects.bounce=function(b){return this.queue(function(){var a=e(this),l=["position","top","bottom","left","right"],h=e.effects.setMode(a,b.options.mode||"effect"),d=b.options.direction||"up",c=b.options.distance||20,m=b.options.times||5,i=b.duration||250;/show|hide/.test(h)&&l.push("opacity");e.effects.save(a,l);a.show();e.effects.createWrapper(a);var f=d=="up"||d=="down"?"top":"left";d=d=="up"||d=="left"?"pos":"neg";c=b.options.distance||(f=="top"?a.outerHeight({margin:true})/3:a.outerWidth({margin:true})/ | |
| 629 | +3);if(h=="show")a.css("opacity",0).css(f,d=="pos"?-c:c);if(h=="hide")c/=m*2;h!="hide"&&m--;if(h=="show"){var g={opacity:1};g[f]=(d=="pos"?"+=":"-=")+c;a.animate(g,i/2,b.options.easing);c/=2;m--}for(g=0;g<m;g++){var j={},k={};j[f]=(d=="pos"?"-=":"+=")+c;k[f]=(d=="pos"?"+=":"-=")+c;a.animate(j,i/2,b.options.easing).animate(k,i/2,b.options.easing);c=h=="hide"?c*2:c/2}if(h=="hide"){g={opacity:0};g[f]=(d=="pos"?"-=":"+=")+c;a.animate(g,i/2,b.options.easing,function(){a.hide();e.effects.restore(a,l);e.effects.removeWrapper(a); | |
| 630 | +b.callback&&b.callback.apply(this,arguments)})}else{j={};k={};j[f]=(d=="pos"?"-=":"+=")+c;k[f]=(d=="pos"?"+=":"-=")+c;a.animate(j,i/2,b.options.easing).animate(k,i/2,b.options.easing,function(){e.effects.restore(a,l);e.effects.removeWrapper(a);b.callback&&b.callback.apply(this,arguments)})}a.queue("fx",function(){a.dequeue()});a.dequeue()})}})(jQuery); | |
| 631 | +;/* | |
| 632 | + * jQuery UI Effects Clip 1.8.16 | |
| 633 | + * | |
| 634 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 635 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 636 | + * http://jquery.org/license | |
| 637 | + * | |
| 638 | + * http://docs.jquery.com/UI/Effects/Clip | |
| 639 | + * | |
| 640 | + * Depends: | |
| 641 | + * jquery.effects.core.js | |
| 642 | + */ | |
| 643 | +(function(b){b.effects.clip=function(e){return this.queue(function(){var a=b(this),i=["position","top","bottom","left","right","height","width"],f=b.effects.setMode(a,e.options.mode||"hide"),c=e.options.direction||"vertical";b.effects.save(a,i);a.show();var d=b.effects.createWrapper(a).css({overflow:"hidden"});d=a[0].tagName=="IMG"?d:a;var g={size:c=="vertical"?"height":"width",position:c=="vertical"?"top":"left"};c=c=="vertical"?d.height():d.width();if(f=="show"){d.css(g.size,0);d.css(g.position, | |
| 644 | +c/2)}var h={};h[g.size]=f=="show"?c:0;h[g.position]=f=="show"?0:c/2;d.animate(h,{queue:false,duration:e.duration,easing:e.options.easing,complete:function(){f=="hide"&&a.hide();b.effects.restore(a,i);b.effects.removeWrapper(a);e.callback&&e.callback.apply(a[0],arguments);a.dequeue()}})})}})(jQuery); | |
| 645 | +;/* | |
| 646 | + * jQuery UI Effects Drop 1.8.16 | |
| 647 | + * | |
| 648 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 649 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 650 | + * http://jquery.org/license | |
| 651 | + * | |
| 652 | + * http://docs.jquery.com/UI/Effects/Drop | |
| 653 | + * | |
| 654 | + * Depends: | |
| 655 | + * jquery.effects.core.js | |
| 656 | + */ | |
| 657 | +(function(c){c.effects.drop=function(d){return this.queue(function(){var a=c(this),h=["position","top","bottom","left","right","opacity"],e=c.effects.setMode(a,d.options.mode||"hide"),b=d.options.direction||"left";c.effects.save(a,h);a.show();c.effects.createWrapper(a);var f=b=="up"||b=="down"?"top":"left";b=b=="up"||b=="left"?"pos":"neg";var g=d.options.distance||(f=="top"?a.outerHeight({margin:true})/2:a.outerWidth({margin:true})/2);if(e=="show")a.css("opacity",0).css(f,b=="pos"?-g:g);var i={opacity:e== | |
| 658 | +"show"?1:0};i[f]=(e=="show"?b=="pos"?"+=":"-=":b=="pos"?"-=":"+=")+g;a.animate(i,{queue:false,duration:d.duration,easing:d.options.easing,complete:function(){e=="hide"&&a.hide();c.effects.restore(a,h);c.effects.removeWrapper(a);d.callback&&d.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery); | |
| 659 | +;/* | |
| 660 | + * jQuery UI Effects Explode 1.8.16 | |
| 661 | + * | |
| 662 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 663 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 664 | + * http://jquery.org/license | |
| 665 | + * | |
| 666 | + * http://docs.jquery.com/UI/Effects/Explode | |
| 667 | + * | |
| 668 | + * Depends: | |
| 669 | + * jquery.effects.core.js | |
| 670 | + */ | |
| 671 | +(function(j){j.effects.explode=function(a){return this.queue(function(){var c=a.options.pieces?Math.round(Math.sqrt(a.options.pieces)):3,d=a.options.pieces?Math.round(Math.sqrt(a.options.pieces)):3;a.options.mode=a.options.mode=="toggle"?j(this).is(":visible")?"hide":"show":a.options.mode;var b=j(this).show().css("visibility","hidden"),g=b.offset();g.top-=parseInt(b.css("marginTop"),10)||0;g.left-=parseInt(b.css("marginLeft"),10)||0;for(var h=b.outerWidth(true),i=b.outerHeight(true),e=0;e<c;e++)for(var f= | |
| 672 | +0;f<d;f++)b.clone().appendTo("body").wrap("<div></div>").css({position:"absolute",visibility:"visible",left:-f*(h/d),top:-e*(i/c)}).parent().addClass("ui-effects-explode").css({position:"absolute",overflow:"hidden",width:h/d,height:i/c,left:g.left+f*(h/d)+(a.options.mode=="show"?(f-Math.floor(d/2))*(h/d):0),top:g.top+e*(i/c)+(a.options.mode=="show"?(e-Math.floor(c/2))*(i/c):0),opacity:a.options.mode=="show"?0:1}).animate({left:g.left+f*(h/d)+(a.options.mode=="show"?0:(f-Math.floor(d/2))*(h/d)),top:g.top+ | |
| 673 | +e*(i/c)+(a.options.mode=="show"?0:(e-Math.floor(c/2))*(i/c)),opacity:a.options.mode=="show"?1:0},a.duration||500);setTimeout(function(){a.options.mode=="show"?b.css({visibility:"visible"}):b.css({visibility:"visible"}).hide();a.callback&&a.callback.apply(b[0]);b.dequeue();j("div.ui-effects-explode").remove()},a.duration||500)})}})(jQuery); | |
| 674 | +;/* | |
| 675 | + * jQuery UI Effects Fade 1.8.16 | |
| 676 | + * | |
| 677 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 678 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 679 | + * http://jquery.org/license | |
| 680 | + * | |
| 681 | + * http://docs.jquery.com/UI/Effects/Fade | |
| 682 | + * | |
| 683 | + * Depends: | |
| 684 | + * jquery.effects.core.js | |
| 685 | + */ | |
| 686 | +(function(b){b.effects.fade=function(a){return this.queue(function(){var c=b(this),d=b.effects.setMode(c,a.options.mode||"hide");c.animate({opacity:d},{queue:false,duration:a.duration,easing:a.options.easing,complete:function(){a.callback&&a.callback.apply(this,arguments);c.dequeue()}})})}})(jQuery); | |
| 687 | +;/* | |
| 688 | + * jQuery UI Effects Fold 1.8.16 | |
| 689 | + * | |
| 690 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 691 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 692 | + * http://jquery.org/license | |
| 693 | + * | |
| 694 | + * http://docs.jquery.com/UI/Effects/Fold | |
| 695 | + * | |
| 696 | + * Depends: | |
| 697 | + * jquery.effects.core.js | |
| 698 | + */ | |
| 699 | +(function(c){c.effects.fold=function(a){return this.queue(function(){var b=c(this),j=["position","top","bottom","left","right"],d=c.effects.setMode(b,a.options.mode||"hide"),g=a.options.size||15,h=!!a.options.horizFirst,k=a.duration?a.duration/2:c.fx.speeds._default/2;c.effects.save(b,j);b.show();var e=c.effects.createWrapper(b).css({overflow:"hidden"}),f=d=="show"!=h,l=f?["width","height"]:["height","width"];f=f?[e.width(),e.height()]:[e.height(),e.width()];var i=/([0-9]+)%/.exec(g);if(i)g=parseInt(i[1], | |
| 700 | +10)/100*f[d=="hide"?0:1];if(d=="show")e.css(h?{height:0,width:g}:{height:g,width:0});h={};i={};h[l[0]]=d=="show"?f[0]:g;i[l[1]]=d=="show"?f[1]:0;e.animate(h,k,a.options.easing).animate(i,k,a.options.easing,function(){d=="hide"&&b.hide();c.effects.restore(b,j);c.effects.removeWrapper(b);a.callback&&a.callback.apply(b[0],arguments);b.dequeue()})})}})(jQuery); | |
| 701 | +;/* | |
| 702 | + * jQuery UI Effects Highlight 1.8.16 | |
| 703 | + * | |
| 704 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 705 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 706 | + * http://jquery.org/license | |
| 707 | + * | |
| 708 | + * http://docs.jquery.com/UI/Effects/Highlight | |
| 709 | + * | |
| 710 | + * Depends: | |
| 711 | + * jquery.effects.core.js | |
| 712 | + */ | |
| 713 | +(function(b){b.effects.highlight=function(c){return this.queue(function(){var a=b(this),e=["backgroundImage","backgroundColor","opacity"],d=b.effects.setMode(a,c.options.mode||"show"),f={backgroundColor:a.css("backgroundColor")};if(d=="hide")f.opacity=0;b.effects.save(a,e);a.show().css({backgroundImage:"none",backgroundColor:c.options.color||"#ffff99"}).animate(f,{queue:false,duration:c.duration,easing:c.options.easing,complete:function(){d=="hide"&&a.hide();b.effects.restore(a,e);d=="show"&&!b.support.opacity&& | |
| 714 | +this.style.removeAttribute("filter");c.callback&&c.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery); | |
| 715 | +;/* | |
| 716 | + * jQuery UI Effects Pulsate 1.8.16 | |
| 717 | + * | |
| 718 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 719 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 720 | + * http://jquery.org/license | |
| 721 | + * | |
| 722 | + * http://docs.jquery.com/UI/Effects/Pulsate | |
| 723 | + * | |
| 724 | + * Depends: | |
| 725 | + * jquery.effects.core.js | |
| 726 | + */ | |
| 727 | +(function(d){d.effects.pulsate=function(a){return this.queue(function(){var b=d(this),c=d.effects.setMode(b,a.options.mode||"show");times=(a.options.times||5)*2-1;duration=a.duration?a.duration/2:d.fx.speeds._default/2;isVisible=b.is(":visible");animateTo=0;if(!isVisible){b.css("opacity",0).show();animateTo=1}if(c=="hide"&&isVisible||c=="show"&&!isVisible)times--;for(c=0;c<times;c++){b.animate({opacity:animateTo},duration,a.options.easing);animateTo=(animateTo+1)%2}b.animate({opacity:animateTo},duration, | |
| 728 | +a.options.easing,function(){animateTo==0&&b.hide();a.callback&&a.callback.apply(this,arguments)});b.queue("fx",function(){b.dequeue()}).dequeue()})}})(jQuery); | |
| 729 | +;/* | |
| 730 | + * jQuery UI Effects Scale 1.8.16 | |
| 731 | + * | |
| 732 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 733 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 734 | + * http://jquery.org/license | |
| 735 | + * | |
| 736 | + * http://docs.jquery.com/UI/Effects/Scale | |
| 737 | + * | |
| 738 | + * Depends: | |
| 739 | + * jquery.effects.core.js | |
| 740 | + */ | |
| 741 | +(function(c){c.effects.puff=function(b){return this.queue(function(){var a=c(this),e=c.effects.setMode(a,b.options.mode||"hide"),g=parseInt(b.options.percent,10)||150,h=g/100,i={height:a.height(),width:a.width()};c.extend(b.options,{fade:true,mode:e,percent:e=="hide"?g:100,from:e=="hide"?i:{height:i.height*h,width:i.width*h}});a.effect("scale",b.options,b.duration,b.callback);a.dequeue()})};c.effects.scale=function(b){return this.queue(function(){var a=c(this),e=c.extend(true,{},b.options),g=c.effects.setMode(a, | |
| 742 | +b.options.mode||"effect"),h=parseInt(b.options.percent,10)||(parseInt(b.options.percent,10)==0?0:g=="hide"?0:100),i=b.options.direction||"both",f=b.options.origin;if(g!="effect"){e.origin=f||["middle","center"];e.restore=true}f={height:a.height(),width:a.width()};a.from=b.options.from||(g=="show"?{height:0,width:0}:f);h={y:i!="horizontal"?h/100:1,x:i!="vertical"?h/100:1};a.to={height:f.height*h.y,width:f.width*h.x};if(b.options.fade){if(g=="show"){a.from.opacity=0;a.to.opacity=1}if(g=="hide"){a.from.opacity= | |
| 743 | +1;a.to.opacity=0}}e.from=a.from;e.to=a.to;e.mode=g;a.effect("size",e,b.duration,b.callback);a.dequeue()})};c.effects.size=function(b){return this.queue(function(){var a=c(this),e=["position","top","bottom","left","right","width","height","overflow","opacity"],g=["position","top","bottom","left","right","overflow","opacity"],h=["width","height","overflow"],i=["fontSize"],f=["borderTopWidth","borderBottomWidth","paddingTop","paddingBottom"],k=["borderLeftWidth","borderRightWidth","paddingLeft","paddingRight"], | |
| 744 | +p=c.effects.setMode(a,b.options.mode||"effect"),n=b.options.restore||false,m=b.options.scale||"both",l=b.options.origin,j={height:a.height(),width:a.width()};a.from=b.options.from||j;a.to=b.options.to||j;if(l){l=c.effects.getBaseline(l,j);a.from.top=(j.height-a.from.height)*l.y;a.from.left=(j.width-a.from.width)*l.x;a.to.top=(j.height-a.to.height)*l.y;a.to.left=(j.width-a.to.width)*l.x}var d={from:{y:a.from.height/j.height,x:a.from.width/j.width},to:{y:a.to.height/j.height,x:a.to.width/j.width}}; | |
| 745 | +if(m=="box"||m=="both"){if(d.from.y!=d.to.y){e=e.concat(f);a.from=c.effects.setTransition(a,f,d.from.y,a.from);a.to=c.effects.setTransition(a,f,d.to.y,a.to)}if(d.from.x!=d.to.x){e=e.concat(k);a.from=c.effects.setTransition(a,k,d.from.x,a.from);a.to=c.effects.setTransition(a,k,d.to.x,a.to)}}if(m=="content"||m=="both")if(d.from.y!=d.to.y){e=e.concat(i);a.from=c.effects.setTransition(a,i,d.from.y,a.from);a.to=c.effects.setTransition(a,i,d.to.y,a.to)}c.effects.save(a,n?e:g);a.show();c.effects.createWrapper(a); | |
| 746 | +a.css("overflow","hidden").css(a.from);if(m=="content"||m=="both"){f=f.concat(["marginTop","marginBottom"]).concat(i);k=k.concat(["marginLeft","marginRight"]);h=e.concat(f).concat(k);a.find("*[width]").each(function(){child=c(this);n&&c.effects.save(child,h);var o={height:child.height(),width:child.width()};child.from={height:o.height*d.from.y,width:o.width*d.from.x};child.to={height:o.height*d.to.y,width:o.width*d.to.x};if(d.from.y!=d.to.y){child.from=c.effects.setTransition(child,f,d.from.y,child.from); | |
| 747 | +child.to=c.effects.setTransition(child,f,d.to.y,child.to)}if(d.from.x!=d.to.x){child.from=c.effects.setTransition(child,k,d.from.x,child.from);child.to=c.effects.setTransition(child,k,d.to.x,child.to)}child.css(child.from);child.animate(child.to,b.duration,b.options.easing,function(){n&&c.effects.restore(child,h)})})}a.animate(a.to,{queue:false,duration:b.duration,easing:b.options.easing,complete:function(){a.to.opacity===0&&a.css("opacity",a.from.opacity);p=="hide"&&a.hide();c.effects.restore(a, | |
| 748 | +n?e:g);c.effects.removeWrapper(a);b.callback&&b.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery); | |
| 749 | +;/* | |
| 750 | + * jQuery UI Effects Shake 1.8.16 | |
| 751 | + * | |
| 752 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 753 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 754 | + * http://jquery.org/license | |
| 755 | + * | |
| 756 | + * http://docs.jquery.com/UI/Effects/Shake | |
| 757 | + * | |
| 758 | + * Depends: | |
| 759 | + * jquery.effects.core.js | |
| 760 | + */ | |
| 761 | +(function(d){d.effects.shake=function(a){return this.queue(function(){var b=d(this),j=["position","top","bottom","left","right"];d.effects.setMode(b,a.options.mode||"effect");var c=a.options.direction||"left",e=a.options.distance||20,l=a.options.times||3,f=a.duration||a.options.duration||140;d.effects.save(b,j);b.show();d.effects.createWrapper(b);var g=c=="up"||c=="down"?"top":"left",h=c=="up"||c=="left"?"pos":"neg";c={};var i={},k={};c[g]=(h=="pos"?"-=":"+=")+e;i[g]=(h=="pos"?"+=":"-=")+e*2;k[g]= | |
| 762 | +(h=="pos"?"-=":"+=")+e*2;b.animate(c,f,a.options.easing);for(e=1;e<l;e++)b.animate(i,f,a.options.easing).animate(k,f,a.options.easing);b.animate(i,f,a.options.easing).animate(c,f/2,a.options.easing,function(){d.effects.restore(b,j);d.effects.removeWrapper(b);a.callback&&a.callback.apply(this,arguments)});b.queue("fx",function(){b.dequeue()});b.dequeue()})}})(jQuery); | |
| 763 | +;/* | |
| 764 | + * jQuery UI Effects Slide 1.8.16 | |
| 765 | + * | |
| 766 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 767 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 768 | + * http://jquery.org/license | |
| 769 | + * | |
| 770 | + * http://docs.jquery.com/UI/Effects/Slide | |
| 771 | + * | |
| 772 | + * Depends: | |
| 773 | + * jquery.effects.core.js | |
| 774 | + */ | |
| 775 | +(function(c){c.effects.slide=function(d){return this.queue(function(){var a=c(this),h=["position","top","bottom","left","right"],f=c.effects.setMode(a,d.options.mode||"show"),b=d.options.direction||"left";c.effects.save(a,h);a.show();c.effects.createWrapper(a).css({overflow:"hidden"});var g=b=="up"||b=="down"?"top":"left";b=b=="up"||b=="left"?"pos":"neg";var e=d.options.distance||(g=="top"?a.outerHeight({margin:true}):a.outerWidth({margin:true}));if(f=="show")a.css(g,b=="pos"?isNaN(e)?"-"+e:-e:e); | |
| 776 | +var i={};i[g]=(f=="show"?b=="pos"?"+=":"-=":b=="pos"?"-=":"+=")+e;a.animate(i,{queue:false,duration:d.duration,easing:d.options.easing,complete:function(){f=="hide"&&a.hide();c.effects.restore(a,h);c.effects.removeWrapper(a);d.callback&&d.callback.apply(this,arguments);a.dequeue()}})})}})(jQuery); | |
| 777 | +;/* | |
| 778 | + * jQuery UI Effects Transfer 1.8.16 | |
| 779 | + * | |
| 780 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 781 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 782 | + * http://jquery.org/license | |
| 783 | + * | |
| 784 | + * http://docs.jquery.com/UI/Effects/Transfer | |
| 785 | + * | |
| 786 | + * Depends: | |
| 787 | + * jquery.effects.core.js | |
| 788 | + */ | |
| 789 | +(function(e){e.effects.transfer=function(a){return this.queue(function(){var b=e(this),c=e(a.options.to),d=c.offset();c={top:d.top,left:d.left,height:c.innerHeight(),width:c.innerWidth()};d=b.offset();var f=e('<div class="ui-effects-transfer"></div>').appendTo(document.body).addClass(a.options.className).css({top:d.top,left:d.left,height:b.innerHeight(),width:b.innerWidth(),position:"absolute"}).animate(c,a.duration,a.options.easing,function(){f.remove();a.callback&&a.callback.apply(b[0],arguments); | |
| 790 | +b.dequeue()})})}})(jQuery); | |
| 791 | +; | ... | ... |
| ... | ... | @@ -0,0 +1,41 @@ |
| 1 | +/** | |
| 2 | + * jQuery Cookie plugin | |
| 3 | + * | |
| 4 | + * Copyright (c) 2010 Klaus Hartl (stilbuero.de) | |
| 5 | + * Dual licensed under the MIT and GPL licenses: | |
| 6 | + * http://www.opensource.org/licenses/mit-license.php | |
| 7 | + * http://www.gnu.org/licenses/gpl.html | |
| 8 | + * | |
| 9 | + */ | |
| 10 | +jQuery.cookie = function (key, value, options) { | |
| 11 | + | |
| 12 | + // key and at least value given, set cookie... | |
| 13 | + if (arguments.length > 1 && String(value) !== "[object Object]") { | |
| 14 | + options = jQuery.extend({}, options); | |
| 15 | + | |
| 16 | + if (value === null || value === undefined) { | |
| 17 | + options.expires = -1; | |
| 18 | + } | |
| 19 | + | |
| 20 | + if (typeof options.expires === 'number') { | |
| 21 | + var days = options.expires, t = options.expires = new Date(); | |
| 22 | + t.setDate(t.getDate() + days); | |
| 23 | + } | |
| 24 | + | |
| 25 | + value = String(value); | |
| 26 | + | |
| 27 | + return (document.cookie = [ | |
| 28 | + encodeURIComponent(key), '=', | |
| 29 | + options.raw ? value : encodeURIComponent(value), | |
| 30 | + options.expires ? '; expires=' + options.expires.toUTCString() : '', // use expires attribute, max-age is not supported by IE | |
| 31 | + options.path ? '; path=' + options.path : '', | |
| 32 | + options.domain ? '; domain=' + options.domain : '', | |
| 33 | + options.secure ? '; secure' : '' | |
| 34 | + ].join('')); | |
| 35 | + } | |
| 36 | + | |
| 37 | + // key and possibly options given, get cookie... | |
| 38 | + options = value || {}; | |
| 39 | + var result, decode = options.raw ? function (s) { return s; } : decodeURIComponent; | |
| 40 | + return (result = new RegExp('(?:^|; )' + encodeURIComponent(key) + '=([^;]*)').exec(document.cookie)) ? decode(result[1]) : null; | |
| 41 | +}; | ... | ... |
| ... | ... | @@ -0,0 +1,143 @@ |
| 1 | +/* Author: Alicia Liu */ | |
| 2 | + | |
| 3 | +(function ($) { | |
| 4 | + | |
| 5 | + $.widget("ui.tagify", { | |
| 6 | + options: { | |
| 7 | + delimiters: [13, 188], // what user can type to complete a tag in char codes: [enter], [comma] | |
| 8 | + outputDelimiter: ',', // delimiter for tags in original input field | |
| 9 | + cssClass: 'tagify-container', // CSS class to style the tagify div and tags, see stylesheet | |
| 10 | + addTagPrompt: 'add tags' // placeholder text | |
| 11 | + }, | |
| 12 | + | |
| 13 | + _create: function() { | |
| 14 | + var self = this, | |
| 15 | + el = self.element, | |
| 16 | + opts = self.options; | |
| 17 | + | |
| 18 | + this.tags = []; | |
| 19 | + | |
| 20 | + // hide text field and replace with a div that contains it's own input field for entering tags | |
| 21 | + this.tagInput = $("<input type='text'>") | |
| 22 | + .attr( 'placeholder', opts.addTagPrompt ) | |
| 23 | + .keypress( function(e) { | |
| 24 | + var $this = $(this), | |
| 25 | + pressed = e.which; | |
| 26 | + | |
| 27 | + for ( i in opts.delimiters ) { | |
| 28 | + | |
| 29 | + if (pressed == opts.delimiters[i]) { | |
| 30 | + self.add( $this.val() ); | |
| 31 | + e.preventDefault(); | |
| 32 | + return false; | |
| 33 | + } | |
| 34 | + } | |
| 35 | + }) | |
| 36 | + // for some reason, in Safari, backspace is only recognized on keyup | |
| 37 | + .keyup( function(e) { | |
| 38 | + var $this = $(this), | |
| 39 | + pressed = e.which; | |
| 40 | + | |
| 41 | + // if backspace is hit with no input, remove the last tag | |
| 42 | + if (pressed == 8) { // backspace | |
| 43 | + if ( $this.val() == "" ) { | |
| 44 | + self.remove(); | |
| 45 | + return false; | |
| 46 | + } | |
| 47 | + return; | |
| 48 | + } | |
| 49 | + }); | |
| 50 | + | |
| 51 | + this.tagDiv = $("<div></div>") | |
| 52 | + .addClass( opts.cssClass ) | |
| 53 | + .click( function() { | |
| 54 | + $(this).children('input').focus(); | |
| 55 | + }) | |
| 56 | + .append( this.tagInput ) | |
| 57 | + .insertAfter( el.hide() ); | |
| 58 | + | |
| 59 | + // if the field isn't empty, parse the field for tags, and prepopulate existing tags | |
| 60 | + var initVal = $.trim( el.val() ); | |
| 61 | + | |
| 62 | + if ( initVal ) { | |
| 63 | + var initTags = initVal.split( opts.outputDelimiter ); | |
| 64 | + $.each( initTags, function(i, tag) { | |
| 65 | + self.add( tag ); | |
| 66 | + }); | |
| 67 | + } | |
| 68 | + }, | |
| 69 | + | |
| 70 | + _setOption: function( key, value ) { | |
| 71 | + options.key = value; | |
| 72 | + }, | |
| 73 | + | |
| 74 | + // add a tag, public function | |
| 75 | + add: function(text) { | |
| 76 | + var self = this; | |
| 77 | + text = text || self.tagInput.val(); | |
| 78 | + if (text) { | |
| 79 | + var tagIndex = self.tags.length; | |
| 80 | + | |
| 81 | + var removeButton = $("<a href='#'>x</a>") | |
| 82 | + .click( function() { | |
| 83 | + self.remove( tagIndex ); | |
| 84 | + return false; | |
| 85 | + }); | |
| 86 | + var newTag = $("<span></span>") | |
| 87 | + .text( text ) | |
| 88 | + .append( removeButton ); | |
| 89 | + | |
| 90 | + self.tagInput.before( newTag ); | |
| 91 | + self.tags.push( text ); | |
| 92 | + self.tagInput.val(''); | |
| 93 | + } | |
| 94 | + }, | |
| 95 | + | |
| 96 | + // remove a tag by index, public function | |
| 97 | + // if index is blank, remove the last tag | |
| 98 | + remove: function( tagIndex ) { | |
| 99 | + var self = this; | |
| 100 | + if ( tagIndex == null || tagIndex === (self.tags.length - 1) ) { | |
| 101 | + this.tagDiv.children("span").last().remove(); | |
| 102 | + self.tags.pop(); | |
| 103 | + } | |
| 104 | + if ( typeof(tagIndex) == 'number' ) { | |
| 105 | + // otherwise just hide this tag, and we don't mess up the index | |
| 106 | + this.tagDiv.children( "span:eq(" + tagIndex + ")" ).hide(); | |
| 107 | + // we rely on the serialize function to remove null values | |
| 108 | + delete( self.tags[tagIndex] ); | |
| 109 | + } | |
| 110 | + }, | |
| 111 | + | |
| 112 | + // serialize the tags with the given delimiter, and write it back into the tagified field | |
| 113 | + serialize: function() { | |
| 114 | + var self = this; | |
| 115 | + var delim = self.options.outputDelimiter; | |
| 116 | + var tagsStr = self.tags.join( delim ); | |
| 117 | + | |
| 118 | + // our tags might have deleted entries, remove them here | |
| 119 | + var dupes = new RegExp(delim + delim + '+', 'g'); // regex: /,,+/g | |
| 120 | + var ends = new RegExp('^' + delim + '|' + delim + '$', 'g'); // regex: /^,|,$/g | |
| 121 | + var outputStr = tagsStr.replace( dupes, delim ).replace(ends, ''); | |
| 122 | + | |
| 123 | + self.element.val(outputStr); | |
| 124 | + return outputStr; | |
| 125 | + }, | |
| 126 | + | |
| 127 | + inputField: function() { | |
| 128 | + return this.tagInput; | |
| 129 | + }, | |
| 130 | + | |
| 131 | + containerDiv: function() { | |
| 132 | + return this.tagDiv; | |
| 133 | + }, | |
| 134 | + | |
| 135 | + // remove the div, and show original input | |
| 136 | + destroy: function() { | |
| 137 | + $.Widget.prototype.destroy.apply(this); | |
| 138 | + this.tagDiv.remove(); | |
| 139 | + this.element.show(); | |
| 140 | + } | |
| 141 | + }); | |
| 142 | + | |
| 143 | +})(jQuery); | |
| 0 | 144 | \ No newline at end of file | ... | ... |
| ... | ... | @@ -0,0 +1,844 @@ |
| 1 | + /* | |
| 2 | + * jQuery UI selectmenu dev version | |
| 3 | + * | |
| 4 | + * Copyright (c) 2009 AUTHORS.txt (http://jqueryui.com/about) | |
| 5 | + * Dual licensed under the MIT (MIT-LICENSE.txt) | |
| 6 | + * and GPL (GPL-LICENSE.txt) licenses. | |
| 7 | + * | |
| 8 | + * http://docs.jquery.com/UI | |
| 9 | + * https://github.com/fnagel/jquery-ui/wiki/Selectmenu | |
| 10 | + */ | |
| 11 | + | |
| 12 | +(function($) { | |
| 13 | + | |
| 14 | +$.widget("ui.selectmenu", { | |
| 15 | + getter: "value", | |
| 16 | + version: "1.8", | |
| 17 | + eventPrefix: "selectmenu", | |
| 18 | + options: { | |
| 19 | + transferClasses: true, | |
| 20 | + typeAhead: "sequential", | |
| 21 | + style: 'dropdown', | |
| 22 | + positionOptions: { | |
| 23 | + my: "left top", | |
| 24 | + at: "left bottom", | |
| 25 | + offset: null | |
| 26 | + }, | |
| 27 | + width: null, | |
| 28 | + menuWidth: null, | |
| 29 | + handleWidth: 26, | |
| 30 | + maxHeight: null, | |
| 31 | + icons: null, | |
| 32 | + format: null, | |
| 33 | + bgImage: function() {}, | |
| 34 | + wrapperElement: "<div />" | |
| 35 | + }, | |
| 36 | + | |
| 37 | + _create: function() { | |
| 38 | + var self = this, o = this.options; | |
| 39 | + | |
| 40 | + // set a default id value, generate a new random one if not set by developer | |
| 41 | + var selectmenuId = this.element.attr( 'id' ) || 'ui-selectmenu-' + Math.random().toString( 16 ).slice( 2, 10 ); | |
| 42 | + | |
| 43 | + // quick array of button and menu id's | |
| 44 | + this.ids = [ selectmenuId + '-button', selectmenuId + '-menu' ]; | |
| 45 | + | |
| 46 | + // define safe mouseup for future toggling | |
| 47 | + this._safemouseup = true; | |
| 48 | + | |
| 49 | + // create menu button wrapper | |
| 50 | + this.newelement = $( '<a />', { | |
| 51 | + 'class': this.widgetBaseClass + ' ui-widget ui-state-default ui-corner-all', | |
| 52 | + 'id' : this.ids[ 0 ], | |
| 53 | + 'role': 'button', | |
| 54 | + 'href': '#nogo', | |
| 55 | + 'tabindex': this.element.attr( 'disabled' ) ? 1 : 0, | |
| 56 | + 'aria-haspopup': true, | |
| 57 | + 'aria-owns': this.ids[ 1 ] | |
| 58 | + }); | |
| 59 | + this.newelementWrap = $( o.wrapperElement ) | |
| 60 | + .append( this.newelement ) | |
| 61 | + .insertAfter( this.element ); | |
| 62 | + | |
| 63 | + // transfer tabindex | |
| 64 | + var tabindex = this.element.attr( 'tabindex' ); | |
| 65 | + if ( tabindex ) { | |
| 66 | + this.newelement.attr( 'tabindex', tabindex ); | |
| 67 | + } | |
| 68 | + | |
| 69 | + // save reference to select in data for ease in calling methods | |
| 70 | + this.newelement.data( 'selectelement', this.element ); | |
| 71 | + | |
| 72 | + // menu icon | |
| 73 | + this.selectmenuIcon = $( '<span class="' + this.widgetBaseClass + '-icon ui-icon"></span>' ) | |
| 74 | + .prependTo( this.newelement ); | |
| 75 | + | |
| 76 | + // append status span to button | |
| 77 | + this.newelement.prepend( '<span class="' + self.widgetBaseClass + '-status" />' ); | |
| 78 | + | |
| 79 | + // make associated form label trigger focus | |
| 80 | + $( 'label[for="' + selectmenuId + '"]' ) | |
| 81 | + .attr( 'for', this.ids[0] ) | |
| 82 | + .bind( 'click.selectmenu', function() { | |
| 83 | + self.newelement[0].focus(); | |
| 84 | + return false; | |
| 85 | + }); | |
| 86 | + | |
| 87 | + // click toggle for menu visibility | |
| 88 | + this.newelement | |
| 89 | + .bind('mousedown.selectmenu', function(event) { | |
| 90 | + self._toggle(event, true); | |
| 91 | + // make sure a click won't open/close instantly | |
| 92 | + if (o.style == "popup") { | |
| 93 | + self._safemouseup = false; | |
| 94 | + setTimeout(function() { self._safemouseup = true; }, 300); | |
| 95 | + } | |
| 96 | + return false; | |
| 97 | + }) | |
| 98 | + .bind('click.selectmenu', function() { | |
| 99 | + return false; | |
| 100 | + }) | |
| 101 | + .bind("keydown.selectmenu", function(event) { | |
| 102 | + var ret = false; | |
| 103 | + switch (event.keyCode) { | |
| 104 | + case $.ui.keyCode.ENTER: | |
| 105 | + ret = true; | |
| 106 | + break; | |
| 107 | + case $.ui.keyCode.SPACE: | |
| 108 | + self._toggle(event); | |
| 109 | + break; | |
| 110 | + case $.ui.keyCode.UP: | |
| 111 | + if (event.altKey) { | |
| 112 | + self.open(event); | |
| 113 | + } else { | |
| 114 | + self._moveSelection(-1); | |
| 115 | + } | |
| 116 | + break; | |
| 117 | + case $.ui.keyCode.DOWN: | |
| 118 | + if (event.altKey) { | |
| 119 | + self.open(event); | |
| 120 | + } else { | |
| 121 | + self._moveSelection(1); | |
| 122 | + } | |
| 123 | + break; | |
| 124 | + case $.ui.keyCode.LEFT: | |
| 125 | + self._moveSelection(-1); | |
| 126 | + break; | |
| 127 | + case $.ui.keyCode.RIGHT: | |
| 128 | + self._moveSelection(1); | |
| 129 | + break; | |
| 130 | + case $.ui.keyCode.TAB: | |
| 131 | + ret = true; | |
| 132 | + break; | |
| 133 | + default: | |
| 134 | + ret = true; | |
| 135 | + } | |
| 136 | + return ret; | |
| 137 | + }) | |
| 138 | + .bind('keypress.selectmenu', function(event) { | |
| 139 | + self._typeAhead(event.which, 'mouseup'); | |
| 140 | + return true; | |
| 141 | + }) | |
| 142 | + .bind('mouseover.selectmenu focus.selectmenu', function() { | |
| 143 | + if (!o.disabled) { | |
| 144 | + $(this).addClass(self.widgetBaseClass + '-focus ui-state-hover'); | |
| 145 | + } | |
| 146 | + }) | |
| 147 | + .bind('mouseout.selectmenu blur.selectmenu', function() { | |
| 148 | + if (!o.disabled) { | |
| 149 | + $(this).removeClass(self.widgetBaseClass + '-focus ui-state-hover'); | |
| 150 | + } | |
| 151 | + }); | |
| 152 | + | |
| 153 | + // document click closes menu | |
| 154 | + $(document).bind("mousedown.selectmenu", function(event) { | |
| 155 | + self.close(event); | |
| 156 | + }); | |
| 157 | + | |
| 158 | + // change event on original selectmenu | |
| 159 | + this.element | |
| 160 | + .bind("click.selectmenu", function() { | |
| 161 | + self._refreshValue(); | |
| 162 | + }) | |
| 163 | + // FIXME: newelement can be null under unclear circumstances in IE8 | |
| 164 | + // TODO not sure if this is still a problem (fnagel 20.03.11) | |
| 165 | + .bind("focus.selectmenu", function() { | |
| 166 | + if (self.newelement) { | |
| 167 | + self.newelement[0].focus(); | |
| 168 | + } | |
| 169 | + }); | |
| 170 | + | |
| 171 | + // set width when not set via options | |
| 172 | + if (!o.width) { | |
| 173 | + o.width = this.element.outerWidth(); | |
| 174 | + } | |
| 175 | + // set menu button width | |
| 176 | + this.newelement.width(o.width); | |
| 177 | + | |
| 178 | + // hide original selectmenu element | |
| 179 | + this.element.hide(); | |
| 180 | + | |
| 181 | + // create menu portion, append to body | |
| 182 | + this.list = $( '<ul />', { | |
| 183 | + 'class': 'ui-widget ui-widget-content', | |
| 184 | + 'aria-hidden': true, | |
| 185 | + 'role': 'listbox', | |
| 186 | + 'aria-labelledby': this.ids[0], | |
| 187 | + 'id': this.ids[1] | |
| 188 | + }); | |
| 189 | + this.listWrap = $( o.wrapperElement ) | |
| 190 | + .addClass( self.widgetBaseClass + '-menu' ) | |
| 191 | + .append( this.list ) | |
| 192 | + .appendTo( 'body' ); | |
| 193 | + | |
| 194 | + // transfer menu click to menu button | |
| 195 | + this.list | |
| 196 | + .bind("keydown.selectmenu", function(event) { | |
| 197 | + var ret = false; | |
| 198 | + switch (event.keyCode) { | |
| 199 | + case $.ui.keyCode.UP: | |
| 200 | + if (event.altKey) { | |
| 201 | + self.close(event, true); | |
| 202 | + } else { | |
| 203 | + self._moveFocus(-1); | |
| 204 | + } | |
| 205 | + break; | |
| 206 | + case $.ui.keyCode.DOWN: | |
| 207 | + if (event.altKey) { | |
| 208 | + self.close(event, true); | |
| 209 | + } else { | |
| 210 | + self._moveFocus(1); | |
| 211 | + } | |
| 212 | + break; | |
| 213 | + case $.ui.keyCode.LEFT: | |
| 214 | + self._moveFocus(-1); | |
| 215 | + break; | |
| 216 | + case $.ui.keyCode.RIGHT: | |
| 217 | + self._moveFocus(1); | |
| 218 | + break; | |
| 219 | + case $.ui.keyCode.HOME: | |
| 220 | + self._moveFocus(':first'); | |
| 221 | + break; | |
| 222 | + case $.ui.keyCode.PAGE_UP: | |
| 223 | + self._scrollPage('up'); | |
| 224 | + break; | |
| 225 | + case $.ui.keyCode.PAGE_DOWN: | |
| 226 | + self._scrollPage('down'); | |
| 227 | + break; | |
| 228 | + case $.ui.keyCode.END: | |
| 229 | + self._moveFocus(':last'); | |
| 230 | + break; | |
| 231 | + case $.ui.keyCode.ENTER: | |
| 232 | + case $.ui.keyCode.SPACE: | |
| 233 | + self.close(event, true); | |
| 234 | + $(event.target).parents('li:eq(0)').trigger('mouseup'); | |
| 235 | + break; | |
| 236 | + case $.ui.keyCode.TAB: | |
| 237 | + ret = true; | |
| 238 | + self.close(event, true); | |
| 239 | + $(event.target).parents('li:eq(0)').trigger('mouseup'); | |
| 240 | + break; | |
| 241 | + case $.ui.keyCode.ESCAPE: | |
| 242 | + self.close(event, true); | |
| 243 | + break; | |
| 244 | + default: | |
| 245 | + ret = true; | |
| 246 | + } | |
| 247 | + return ret; | |
| 248 | + }) | |
| 249 | + .bind('keypress.selectmenu', function(event) { | |
| 250 | + self._typeAhead(event.which, 'focus'); | |
| 251 | + return true; | |
| 252 | + }) | |
| 253 | + // this allows for using the scrollbar in an overflowed list | |
| 254 | + .bind( 'mousedown.selectmenu mouseup.selectmenu', function() { return false; }); | |
| 255 | + | |
| 256 | + // needed when window is resized | |
| 257 | + // TODO seems to be useless, but causes errors (fnagel 01.08.11) | |
| 258 | + // see: https://github.com/fnagel/jquery-ui/issues/147 | |
| 259 | + // $(window).bind( "resize.selectmenu", $.proxy( self._refreshPosition, this ) ); | |
| 260 | + }, | |
| 261 | + | |
| 262 | + _init: function() { | |
| 263 | + var self = this, o = this.options; | |
| 264 | + | |
| 265 | + // serialize selectmenu element options | |
| 266 | + var selectOptionData = []; | |
| 267 | + this.element | |
| 268 | + .find('option') | |
| 269 | + .each(function() { | |
| 270 | + var opt = $(this); | |
| 271 | + selectOptionData.push({ | |
| 272 | + value: opt.attr('value'), | |
| 273 | + text: self._formatText(opt.text()), | |
| 274 | + selected: opt.attr('selected'), | |
| 275 | + disabled: opt.attr('disabled'), | |
| 276 | + classes: opt.attr('class'), | |
| 277 | + typeahead: opt.attr('typeahead'), | |
| 278 | + parentOptGroup: opt.parent('optgroup'), | |
| 279 | + bgImage: o.bgImage.call(opt) | |
| 280 | + }); | |
| 281 | + }); | |
| 282 | + | |
| 283 | + // active state class is only used in popup style | |
| 284 | + var activeClass = (self.options.style == "popup") ? " ui-state-active" : ""; | |
| 285 | + | |
| 286 | + // empty list so we can refresh the selectmenu via selectmenu() | |
| 287 | + this.list.html(""); | |
| 288 | + | |
| 289 | + // write li's | |
| 290 | + if (selectOptionData.length) { | |
| 291 | + for (var i = 0; i < selectOptionData.length; i++) { | |
| 292 | + var thisLiAttr = { role : 'presentation' }; | |
| 293 | + if ( selectOptionData[ i ].disabled ) { | |
| 294 | + thisLiAttr[ 'class' ] = this.namespace + '-state-disabled'; | |
| 295 | + } | |
| 296 | + var thisAAttr = { | |
| 297 | + html: selectOptionData[i].text, | |
| 298 | + href : '#nogo', | |
| 299 | + tabindex : -1, | |
| 300 | + role : 'option', | |
| 301 | + 'aria-selected' : false | |
| 302 | + }; | |
| 303 | + if ( selectOptionData[ i ].disabled ) { | |
| 304 | + thisAAttr[ 'aria-disabled' ] = selectOptionData[ i ].disabled; | |
| 305 | + } | |
| 306 | + if ( selectOptionData[ i ].typeahead ) { | |
| 307 | + thisAAttr[ 'typeahead' ] = selectOptionData[ i ].typeahead; | |
| 308 | + } | |
| 309 | + var thisA = $('<a/>', thisAAttr); | |
| 310 | + var thisLi = $('<li/>', thisLiAttr) | |
| 311 | + .append(thisA) | |
| 312 | + .data('index', i) | |
| 313 | + .addClass(selectOptionData[i].classes) | |
| 314 | + .data('optionClasses', selectOptionData[i].classes || '') | |
| 315 | + .bind("mouseup.selectmenu", function(event) { | |
| 316 | + if (self._safemouseup && !self._disabled(event.currentTarget) && !self._disabled($( event.currentTarget ).parents( "ul>li." + self.widgetBaseClass + "-group " )) ) { | |
| 317 | + var changed = $(this).data('index') != self._selectedIndex(); | |
| 318 | + self.index($(this).data('index')); | |
| 319 | + self.select(event); | |
| 320 | + if (changed) { | |
| 321 | + self.change(event); | |
| 322 | + } | |
| 323 | + self.close(event, true); | |
| 324 | + } | |
| 325 | + return false; | |
| 326 | + }) | |
| 327 | + .bind("click.selectmenu", function() { | |
| 328 | + return false; | |
| 329 | + }) | |
| 330 | + .bind('mouseover.selectmenu focus.selectmenu', function(e) { | |
| 331 | + // no hover if diabled | |
| 332 | + if (!$(e.currentTarget).hasClass(self.namespace + '-state-disabled') && !$(e.currentTarget).parent("ul").parent("li").hasClass(self.namespace + '-state-disabled')) { | |
| 333 | + self._selectedOptionLi().addClass(activeClass); | |
| 334 | + self._focusedOptionLi().removeClass(self.widgetBaseClass + '-item-focus ui-state-hover'); | |
| 335 | + $(this).removeClass('ui-state-active').addClass(self.widgetBaseClass + '-item-focus ui-state-hover'); | |
| 336 | + } | |
| 337 | + }) | |
| 338 | + .bind('mouseout.selectmenu blur.selectmenu', function() { | |
| 339 | + if ($(this).is(self._selectedOptionLi().selector)) { | |
| 340 | + $(this).addClass(activeClass); | |
| 341 | + } | |
| 342 | + $(this).removeClass(self.widgetBaseClass + '-item-focus ui-state-hover'); | |
| 343 | + }); | |
| 344 | + | |
| 345 | + // optgroup or not... | |
| 346 | + if ( selectOptionData[i].parentOptGroup.length ) { | |
| 347 | + var optGroupName = self.widgetBaseClass + '-group-' + this.element.find( 'optgroup' ).index( selectOptionData[i].parentOptGroup ); | |
| 348 | + if (this.list.find( 'li.' + optGroupName ).length ) { | |
| 349 | + this.list.find( 'li.' + optGroupName + ':last ul' ).append( thisLi ); | |
| 350 | + } else { | |
| 351 | + $(' <li role="presentation" class="' + self.widgetBaseClass + '-group ' + optGroupName + (selectOptionData[i].parentOptGroup.attr("disabled") ? ' ' + this.namespace + '-state-disabled" aria-disabled="true"' : '"' ) + '><span class="' + self.widgetBaseClass + '-group-label">' + selectOptionData[i].parentOptGroup.attr('label') + '</span><ul></ul></li> ') | |
| 352 | + .appendTo( this.list ) | |
| 353 | + .find( 'ul' ) | |
| 354 | + .append( thisLi ); | |
| 355 | + } | |
| 356 | + } else { | |
| 357 | + thisLi.appendTo(this.list); | |
| 358 | + } | |
| 359 | + | |
| 360 | + // append icon if option is specified | |
| 361 | + if (o.icons) { | |
| 362 | + for (var j in o.icons) { | |
| 363 | + if (thisLi.is(o.icons[j].find)) { | |
| 364 | + thisLi | |
| 365 | + .data('optionClasses', selectOptionData[i].classes + ' ' + self.widgetBaseClass + '-hasIcon') | |
| 366 | + .addClass(self.widgetBaseClass + '-hasIcon'); | |
| 367 | + var iconClass = o.icons[j].icon || ""; | |
| 368 | + thisLi | |
| 369 | + .find('a:eq(0)') | |
| 370 | + .prepend('<span class="' + self.widgetBaseClass + '-item-icon ui-icon ' + iconClass + '"></span>'); | |
| 371 | + if (selectOptionData[i].bgImage) { | |
| 372 | + thisLi.find('span').css('background-image', selectOptionData[i].bgImage); | |
| 373 | + } | |
| 374 | + } | |
| 375 | + } | |
| 376 | + } | |
| 377 | + } | |
| 378 | + } else { | |
| 379 | + $('<li role="presentation"><a href="#nogo" tabindex="-1" role="option"></a></li>').appendTo(this.list); | |
| 380 | + } | |
| 381 | + // we need to set and unset the CSS classes for dropdown and popup style | |
| 382 | + var isDropDown = ( o.style == 'dropdown' ); | |
| 383 | + this.newelement | |
| 384 | + .toggleClass( self.widgetBaseClass + '-dropdown', isDropDown ) | |
| 385 | + .toggleClass( self.widgetBaseClass + '-popup', !isDropDown ); | |
| 386 | + this.list | |
| 387 | + .toggleClass( self.widgetBaseClass + '-menu-dropdown ui-corner-bottom', isDropDown ) | |
| 388 | + .toggleClass( self.widgetBaseClass + '-menu-popup ui-corner-all', !isDropDown ) | |
| 389 | + // add corners to top and bottom menu items | |
| 390 | + .find( 'li:first' ) | |
| 391 | + .toggleClass( 'ui-corner-top', !isDropDown ) | |
| 392 | + .end().find( 'li:last' ) | |
| 393 | + .addClass( 'ui-corner-bottom' ); | |
| 394 | + this.selectmenuIcon | |
| 395 | + .toggleClass( 'ui-icon-triangle-1-s', isDropDown ) | |
| 396 | + .toggleClass( 'ui-icon-triangle-2-n-s', !isDropDown ); | |
| 397 | + | |
| 398 | + // transfer classes to selectmenu and list | |
| 399 | + if ( o.transferClasses ) { | |
| 400 | + var transferClasses = this.element.attr( 'class' ) || ''; | |
| 401 | + this.newelement.add( this.list ).addClass( transferClasses ); | |
| 402 | + } | |
| 403 | + | |
| 404 | + // set menu width to either menuWidth option value, width option value, or select width | |
| 405 | + if ( o.style == 'dropdown' ) { | |
| 406 | + this.list.width( o.menuWidth ? o.menuWidth : o.width ); | |
| 407 | + } else { | |
| 408 | + this.list.width( o.menuWidth ? o.menuWidth : o.width - o.handleWidth ); | |
| 409 | + } | |
| 410 | + | |
| 411 | + // reset height to auto | |
| 412 | + this.list.css( 'height', 'auto' ); | |
| 413 | + var listH = this.listWrap.height(); | |
| 414 | + // calculate default max height | |
| 415 | + if ( o.maxHeight && o.maxHeight < listH ) { | |
| 416 | + this.list.height( o.maxHeight ); | |
| 417 | + } else { | |
| 418 | + var winH = $( window ).height() / 3; | |
| 419 | + if ( winH < listH ) this.list.height( winH ); | |
| 420 | + } | |
| 421 | + | |
| 422 | + // save reference to actionable li's (not group label li's) | |
| 423 | + this._optionLis = this.list.find( 'li:not(.' + self.widgetBaseClass + '-group)' ); | |
| 424 | + | |
| 425 | + // transfer disabled state | |
| 426 | + if ( this.element.attr( 'disabled' ) ) { | |
| 427 | + this.disable(); | |
| 428 | + } else { | |
| 429 | + this.enable() | |
| 430 | + } | |
| 431 | + | |
| 432 | + // update value | |
| 433 | + this.index( this._selectedIndex() ); | |
| 434 | + | |
| 435 | + // needed when selectmenu is placed at the very bottom / top of the page | |
| 436 | + window.setTimeout( function() { | |
| 437 | + self._refreshPosition(); | |
| 438 | + }, 200 ); | |
| 439 | + }, | |
| 440 | + | |
| 441 | + destroy: function() { | |
| 442 | + this.element.removeData( this.widgetName ) | |
| 443 | + .removeClass( this.widgetBaseClass + '-disabled' + ' ' + this.namespace + '-state-disabled' ) | |
| 444 | + .removeAttr( 'aria-disabled' ) | |
| 445 | + .unbind( ".selectmenu" ); | |
| 446 | + | |
| 447 | + // TODO unneded as event binding has been disabled | |
| 448 | + // $( window ).unbind( ".selectmenu" ); | |
| 449 | + $( document ).unbind( ".selectmenu" ); | |
| 450 | + | |
| 451 | + // unbind click on label, reset its for attr | |
| 452 | + $( 'label[for=' + this.newelement.attr('id') + ']' ) | |
| 453 | + .attr( 'for', this.element.attr( 'id' ) ) | |
| 454 | + .unbind( '.selectmenu' ); | |
| 455 | + | |
| 456 | + this.newelementWrap.remove(); | |
| 457 | + this.listWrap.remove(); | |
| 458 | + | |
| 459 | + this.element.show(); | |
| 460 | + | |
| 461 | + // call widget destroy function | |
| 462 | + $.Widget.prototype.destroy.apply(this, arguments); | |
| 463 | + }, | |
| 464 | + | |
| 465 | + _typeAhead: function( code, eventType ){ | |
| 466 | + var self = this, focusFound = false, C = String.fromCharCode(code).toUpperCase(); | |
| 467 | + c = C.toLowerCase(); | |
| 468 | + | |
| 469 | + if ( self.options.typeAhead == 'sequential' ) { | |
| 470 | + // clear the timeout so we can use _prevChar | |
| 471 | + window.clearTimeout('ui.selectmenu-' + self.selectmenuId); | |
| 472 | + | |
| 473 | + // define our find var | |
| 474 | + var find = typeof( self._prevChar ) == 'undefined' ? '' : self._prevChar.join( '' ); | |
| 475 | + | |
| 476 | + function focusOptSeq( elem, ind, c ){ | |
| 477 | + focusFound = true; | |
| 478 | + $( elem ).trigger( eventType ); | |
| 479 | + typeof( self._prevChar ) == 'undefined' ? self._prevChar = [ c ] : self._prevChar[ self._prevChar.length ] = c; | |
| 480 | + } | |
| 481 | + this.list.find( 'li a' ).each( function( i ) { | |
| 482 | + if ( !focusFound ) { | |
| 483 | + // allow the typeahead attribute on the option tag for a more specific lookup | |
| 484 | + var thisText = $( this ).attr( 'typeahead' ) || $(this).text(); | |
| 485 | + if ( thisText.indexOf( find + C ) === 0 ) { | |
| 486 | + focusOptSeq( this, i, C ); | |
| 487 | + } else if (thisText.indexOf(find+c) === 0 ) { | |
| 488 | + focusOptSeq( this, i, c ); | |
| 489 | + } | |
| 490 | + } | |
| 491 | + }); | |
| 492 | + // set a 1 second timeout for sequenctial typeahead | |
| 493 | + // keep this set even if we have no matches so it doesnt typeahead somewhere else | |
| 494 | + window.setTimeout( function( el ) { | |
| 495 | + self._prevChar = undefined; | |
| 496 | + }, 1000, self ); | |
| 497 | + | |
| 498 | + } else { | |
| 499 | + // define self._prevChar if needed | |
| 500 | + if ( !self._prevChar ) { self._prevChar = [ '' , 0 ]; } | |
| 501 | + | |
| 502 | + focusFound = false; | |
| 503 | + function focusOpt( elem, ind ){ | |
| 504 | + focusFound = true; | |
| 505 | + $( elem ).trigger( eventType ); | |
| 506 | + self._prevChar[ 1 ] = ind; | |
| 507 | + } | |
| 508 | + this.list.find( 'li a' ).each(function( i ){ | |
| 509 | + if (!focusFound){ | |
| 510 | + var thisText = $(this).text(); | |
| 511 | + if ( thisText.indexOf( C ) === 0 || thisText.indexOf( c ) === 0 ) { | |
| 512 | + if (self._prevChar[0] == C){ | |
| 513 | + if ( self._prevChar[ 1 ] < i ){ focusOpt( this, i ); } | |
| 514 | + } else{ | |
| 515 | + focusOpt( this, i ); | |
| 516 | + } | |
| 517 | + } | |
| 518 | + } | |
| 519 | + }); | |
| 520 | + this._prevChar[ 0 ] = C; | |
| 521 | + } | |
| 522 | + }, | |
| 523 | + | |
| 524 | + // returns some usefull information, called by callbacks only | |
| 525 | + _uiHash: function() { | |
| 526 | + var index = this.index(); | |
| 527 | + return { | |
| 528 | + index: index, | |
| 529 | + option: $("option", this.element).get(index), | |
| 530 | + value: this.element[0].value | |
| 531 | + }; | |
| 532 | + }, | |
| 533 | + | |
| 534 | + open: function(event) { | |
| 535 | + var self = this, o = this.options; | |
| 536 | + if ( self.newelement.attr("aria-disabled") != 'true' ) { | |
| 537 | + self._closeOthers(event); | |
| 538 | + self.newelement.addClass('ui-state-active'); | |
| 539 | + | |
| 540 | + self.listWrap.appendTo( o.appendTo ); | |
| 541 | + self.list.attr('aria-hidden', false); | |
| 542 | + | |
| 543 | + if ( o.style == "dropdown" ) { | |
| 544 | + self.newelement.removeClass('ui-corner-all').addClass('ui-corner-top'); | |
| 545 | + } | |
| 546 | + | |
| 547 | + self.listWrap.addClass( self.widgetBaseClass + '-open' ); | |
| 548 | + // positioning needed for IE7 (tested 01.08.11 on MS VPC Image) | |
| 549 | + // see https://github.com/fnagel/jquery-ui/issues/147 | |
| 550 | + if ( $.browser.msie && $.browser.version.substr( 0,1 ) == 7 ) { | |
| 551 | + self._refreshPosition(); | |
| 552 | + } | |
| 553 | + var selected = self.list.attr('aria-hidden', false).find('li:not(.' + self.widgetBaseClass + '-group):eq(' + self._selectedIndex() + '):visible a'); | |
| 554 | + if (selected.length) selected[0].focus(); | |
| 555 | + // positioning needed for FF, Chrome, IE8, IE7, IE6 (tested 01.08.11 on MS VPC Image) | |
| 556 | + self._refreshPosition(); | |
| 557 | + | |
| 558 | + self._trigger("open", event, self._uiHash()); | |
| 559 | + } | |
| 560 | + }, | |
| 561 | + | |
| 562 | + close: function(event, retainFocus) { | |
| 563 | + if ( this.newelement.is('.ui-state-active') ) { | |
| 564 | + this.newelement | |
| 565 | + .removeClass('ui-state-active'); | |
| 566 | + this.listWrap.removeClass(this.widgetBaseClass + '-open'); | |
| 567 | + this.list.attr('aria-hidden', true); | |
| 568 | + if ( this.options.style == "dropdown" ) { | |
| 569 | + this.newelement.removeClass('ui-corner-top').addClass('ui-corner-all'); | |
| 570 | + } | |
| 571 | + if ( retainFocus ) { | |
| 572 | + this.newelement.focus(); | |
| 573 | + } | |
| 574 | + this._trigger("close", event, this._uiHash()); | |
| 575 | + } | |
| 576 | + }, | |
| 577 | + | |
| 578 | + change: function(event) { | |
| 579 | + this.element.trigger("change"); | |
| 580 | + this._trigger("change", event, this._uiHash()); | |
| 581 | + }, | |
| 582 | + | |
| 583 | + select: function(event) { | |
| 584 | + if (this._disabled(event.currentTarget)) { return false; } | |
| 585 | + this._trigger("select", event, this._uiHash()); | |
| 586 | + }, | |
| 587 | + | |
| 588 | + _closeOthers: function(event) { | |
| 589 | + $('.' + this.widgetBaseClass + '.ui-state-active').not(this.newelement).each(function() { | |
| 590 | + $(this).data('selectelement').selectmenu('close', event); | |
| 591 | + }); | |
| 592 | + $('.' + this.widgetBaseClass + '.ui-state-hover').trigger('mouseout'); | |
| 593 | + }, | |
| 594 | + | |
| 595 | + _toggle: function(event, retainFocus) { | |
| 596 | + if ( this.list.parent().is('.' + this.widgetBaseClass + '-open') ) { | |
| 597 | + this.close(event, retainFocus); | |
| 598 | + } else { | |
| 599 | + this.open(event); | |
| 600 | + } | |
| 601 | + }, | |
| 602 | + | |
| 603 | + _formatText: function(text) { | |
| 604 | + return (this.options.format ? this.options.format(text) : text); | |
| 605 | + }, | |
| 606 | + | |
| 607 | + _selectedIndex: function() { | |
| 608 | + return this.element[0].selectedIndex; | |
| 609 | + }, | |
| 610 | + | |
| 611 | + _selectedOptionLi: function() { | |
| 612 | + return this._optionLis.eq(this._selectedIndex()); | |
| 613 | + }, | |
| 614 | + | |
| 615 | + _focusedOptionLi: function() { | |
| 616 | + return this.list.find('.' + this.widgetBaseClass + '-item-focus'); | |
| 617 | + }, | |
| 618 | + | |
| 619 | + _moveSelection: function(amt, recIndex) { | |
| 620 | + // do nothing if disabled | |
| 621 | + if (!this.options.disabled) { | |
| 622 | + var currIndex = parseInt(this._selectedOptionLi().data('index') || 0, 10); | |
| 623 | + var newIndex = currIndex + amt; | |
| 624 | + // do not loop when using up key | |
| 625 | + | |
| 626 | + if (newIndex < 0) { | |
| 627 | + newIndex = 0; | |
| 628 | + } | |
| 629 | + if (newIndex > this._optionLis.size() - 1) { | |
| 630 | + newIndex = this._optionLis.size() - 1; | |
| 631 | + } | |
| 632 | + // Occurs when a full loop has been made | |
| 633 | + if (newIndex === recIndex) { return false; } | |
| 634 | + | |
| 635 | + if (this._optionLis.eq(newIndex).hasClass( this.namespace + '-state-disabled' )) { | |
| 636 | + // if option at newIndex is disabled, call _moveFocus, incrementing amt by one | |
| 637 | + (amt > 0) ? ++amt : --amt; | |
| 638 | + this._moveSelection(amt, newIndex); | |
| 639 | + } else { | |
| 640 | + return this._optionLis.eq(newIndex).trigger('mouseup'); | |
| 641 | + } | |
| 642 | + } | |
| 643 | + }, | |
| 644 | + | |
| 645 | + _moveFocus: function(amt, recIndex) { | |
| 646 | + if (!isNaN(amt)) { | |
| 647 | + var currIndex = parseInt(this._focusedOptionLi().data('index') || 0, 10); | |
| 648 | + var newIndex = currIndex + amt; | |
| 649 | + } else { | |
| 650 | + var newIndex = parseInt(this._optionLis.filter(amt).data('index'), 10); | |
| 651 | + } | |
| 652 | + | |
| 653 | + if (newIndex < 0) { | |
| 654 | + newIndex = 0; | |
| 655 | + } | |
| 656 | + if (newIndex > this._optionLis.size() - 1) { | |
| 657 | + newIndex = this._optionLis.size() - 1; | |
| 658 | + } | |
| 659 | + | |
| 660 | + //Occurs when a full loop has been made | |
| 661 | + if (newIndex === recIndex) { return false; } | |
| 662 | + | |
| 663 | + var activeID = this.widgetBaseClass + '-item-' + Math.round(Math.random() * 1000); | |
| 664 | + | |
| 665 | + this._focusedOptionLi().find('a:eq(0)').attr('id', ''); | |
| 666 | + | |
| 667 | + if (this._optionLis.eq(newIndex).hasClass( this.namespace + '-state-disabled' )) { | |
| 668 | + // if option at newIndex is disabled, call _moveFocus, incrementing amt by one | |
| 669 | + (amt > 0) ? ++amt : --amt; | |
| 670 | + this._moveFocus(amt, newIndex); | |
| 671 | + } else { | |
| 672 | + this._optionLis.eq(newIndex).find('a:eq(0)').attr('id',activeID).focus(); | |
| 673 | + } | |
| 674 | + | |
| 675 | + this.list.attr('aria-activedescendant', activeID); | |
| 676 | + }, | |
| 677 | + | |
| 678 | + _scrollPage: function(direction) { | |
| 679 | + var numPerPage = Math.floor(this.list.outerHeight() / this.list.find('li:first').outerHeight()); | |
| 680 | + numPerPage = (direction == 'up' ? -numPerPage : numPerPage); | |
| 681 | + this._moveFocus(numPerPage); | |
| 682 | + }, | |
| 683 | + | |
| 684 | + _setOption: function(key, value) { | |
| 685 | + this.options[key] = value; | |
| 686 | + // set | |
| 687 | + if (key == 'disabled') { | |
| 688 | + this.close(); | |
| 689 | + this.element | |
| 690 | + .add(this.newelement) | |
| 691 | + .add(this.list)[value ? 'addClass' : 'removeClass']( | |
| 692 | + this.widgetBaseClass + '-disabled' + ' ' + | |
| 693 | + this.namespace + '-state-disabled') | |
| 694 | + .attr("aria-disabled", value); | |
| 695 | + } | |
| 696 | + }, | |
| 697 | + | |
| 698 | + disable: function(index, type){ | |
| 699 | + // if options is not provided, call the parents disable function | |
| 700 | + if ( typeof( index ) == 'undefined' ) { | |
| 701 | + this._setOption( 'disabled', true ); | |
| 702 | + } else { | |
| 703 | + if ( type == "optgroup" ) { | |
| 704 | + this._disableOptgroup(index); | |
| 705 | + } else { | |
| 706 | + this._disableOption(index); | |
| 707 | + } | |
| 708 | + } | |
| 709 | + }, | |
| 710 | + | |
| 711 | + enable: function(index, type) { | |
| 712 | + // if options is not provided, call the parents enable function | |
| 713 | + if ( typeof( index ) == 'undefined' ) { | |
| 714 | + this._setOption('disabled', false); | |
| 715 | + } else { | |
| 716 | + if ( type == "optgroup" ) { | |
| 717 | + this._enableOptgroup(index); | |
| 718 | + } else { | |
| 719 | + this._enableOption(index); | |
| 720 | + } | |
| 721 | + } | |
| 722 | + }, | |
| 723 | + | |
| 724 | + _disabled: function(elem) { | |
| 725 | + return $(elem).hasClass( this.namespace + '-state-disabled' ); | |
| 726 | + }, | |
| 727 | + | |
| 728 | + _disableOption: function(index) { | |
| 729 | + var optionElem = this._optionLis.eq(index); | |
| 730 | + if (optionElem) { | |
| 731 | + optionElem.addClass(this.namespace + '-state-disabled') | |
| 732 | + .find("a").attr("aria-disabled", true); | |
| 733 | + this.element.find("option").eq(index).attr("disabled", "disabled"); | |
| 734 | + } | |
| 735 | + }, | |
| 736 | + | |
| 737 | + _enableOption: function(index) { | |
| 738 | + var optionElem = this._optionLis.eq(index); | |
| 739 | + if (optionElem) { | |
| 740 | + optionElem.removeClass( this.namespace + '-state-disabled' ) | |
| 741 | + .find("a").attr("aria-disabled", false); | |
| 742 | + this.element.find("option").eq(index).removeAttr("disabled"); | |
| 743 | + } | |
| 744 | + }, | |
| 745 | + | |
| 746 | + _disableOptgroup: function(index) { | |
| 747 | + var optGroupElem = this.list.find( 'li.' + this.widgetBaseClass + '-group-' + index ); | |
| 748 | + if (optGroupElem) { | |
| 749 | + optGroupElem.addClass(this.namespace + '-state-disabled') | |
| 750 | + .attr("aria-disabled", true); | |
| 751 | + this.element.find("optgroup").eq(index).attr("disabled", "disabled"); | |
| 752 | + } | |
| 753 | + }, | |
| 754 | + | |
| 755 | + _enableOptgroup: function(index) { | |
| 756 | + var optGroupElem = this.list.find( 'li.' + this.widgetBaseClass + '-group-' + index ); | |
| 757 | + if (optGroupElem) { | |
| 758 | + optGroupElem.removeClass(this.namespace + '-state-disabled') | |
| 759 | + .attr("aria-disabled", false); | |
| 760 | + this.element.find("optgroup").eq(index).removeAttr("disabled"); | |
| 761 | + } | |
| 762 | + }, | |
| 763 | + | |
| 764 | + index: function(newValue) { | |
| 765 | + if (arguments.length) { | |
| 766 | + if (!this._disabled($(this._optionLis[newValue]))) { | |
| 767 | + this.element[0].selectedIndex = newValue; | |
| 768 | + this._refreshValue(); | |
| 769 | + } else { | |
| 770 | + return false; | |
| 771 | + } | |
| 772 | + } else { | |
| 773 | + return this._selectedIndex(); | |
| 774 | + } | |
| 775 | + }, | |
| 776 | + | |
| 777 | + value: function(newValue) { | |
| 778 | + if (arguments.length) { | |
| 779 | + this.element[0].value = newValue; | |
| 780 | + this._refreshValue(); | |
| 781 | + } else { | |
| 782 | + return this.element[0].value; | |
| 783 | + } | |
| 784 | + }, | |
| 785 | + | |
| 786 | + _refreshValue: function() { | |
| 787 | + var activeClass = (this.options.style == "popup") ? " ui-state-active" : ""; | |
| 788 | + var activeID = this.widgetBaseClass + '-item-' + Math.round(Math.random() * 1000); | |
| 789 | + // deselect previous | |
| 790 | + this.list | |
| 791 | + .find('.' + this.widgetBaseClass + '-item-selected') | |
| 792 | + .removeClass(this.widgetBaseClass + "-item-selected" + activeClass) | |
| 793 | + .find('a') | |
| 794 | + .attr('aria-selected', 'false') | |
| 795 | + .attr('id', ''); | |
| 796 | + // select new | |
| 797 | + this._selectedOptionLi() | |
| 798 | + .addClass(this.widgetBaseClass + "-item-selected" + activeClass) | |
| 799 | + .find('a') | |
| 800 | + .attr('aria-selected', 'true') | |
| 801 | + .attr('id', activeID); | |
| 802 | + | |
| 803 | + // toggle any class brought in from option | |
| 804 | + var currentOptionClasses = (this.newelement.data('optionClasses') ? this.newelement.data('optionClasses') : ""); | |
| 805 | + var newOptionClasses = (this._selectedOptionLi().data('optionClasses') ? this._selectedOptionLi().data('optionClasses') : ""); | |
| 806 | + this.newelement | |
| 807 | + .removeClass(currentOptionClasses) | |
| 808 | + .data('optionClasses', newOptionClasses) | |
| 809 | + .addClass( newOptionClasses ) | |
| 810 | + .find('.' + this.widgetBaseClass + '-status') | |
| 811 | + .html( | |
| 812 | + this._selectedOptionLi() | |
| 813 | + .find('a:eq(0)') | |
| 814 | + .html() | |
| 815 | + ); | |
| 816 | + | |
| 817 | + this.list.attr('aria-activedescendant', activeID); | |
| 818 | + }, | |
| 819 | + | |
| 820 | + _refreshPosition: function() { | |
| 821 | + var o = this.options; | |
| 822 | + | |
| 823 | + // if its a native pop-up we need to calculate the position of the selected li | |
| 824 | + if ( o.style == "popup" && !o.positionOptions.offset ) { | |
| 825 | + var selected = this._selectedOptionLi(); | |
| 826 | + var _offset = "0 -" + ( selected.outerHeight() + selected.offset().top - this.list.offset().top ); | |
| 827 | + } | |
| 828 | + // update zIndex if jQuery UI is able to process | |
| 829 | + var zIndexElement = this.element.zIndex(); | |
| 830 | + if ( zIndexElement ) { | |
| 831 | + this.listWrap.css( 'zIndex', zIndexElement ); | |
| 832 | + } | |
| 833 | + this.listWrap.position({ | |
| 834 | + // set options for position plugin | |
| 835 | + of: o.positionOptions.of || this.newelement, | |
| 836 | + my: o.positionOptions.my, | |
| 837 | + at: o.positionOptions.at, | |
| 838 | + offset: o.positionOptions.offset || _offset, | |
| 839 | + collision: o.positionOptions.collision || 'flip' | |
| 840 | + }); | |
| 841 | + } | |
| 842 | +}); | |
| 843 | + | |
| 844 | +})(jQuery); | ... | ... |
| ... | ... | @@ -0,0 +1,577 @@ |
| 1 | +/* | |
| 2 | + * jQuery UI CSS Framework 1.8.16 | |
| 3 | + * | |
| 4 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 5 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 6 | + * http://jquery.org/license | |
| 7 | + * | |
| 8 | + * http://docs.jquery.com/UI/Theming/API | |
| 9 | + */ | |
| 10 | + | |
| 11 | +/* Layout helpers | |
| 12 | +----------------------------------*/ | |
| 13 | +.ui-helper-hidden { display: none; } | |
| 14 | +.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } | |
| 15 | +.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } | |
| 16 | +.ui-helper-clearfix:after { content: "."; display: block; height: 0; clear: both; visibility: hidden; } | |
| 17 | +.ui-helper-clearfix { display: inline-block; } | |
| 18 | +/* required comment for clearfix to work in Opera \*/ | |
| 19 | +* html .ui-helper-clearfix { height:1%; } | |
| 20 | +.ui-helper-clearfix { display:block; } | |
| 21 | +/* end clearfix */ | |
| 22 | +.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } | |
| 23 | + | |
| 24 | + | |
| 25 | +/* Interaction Cues | |
| 26 | +----------------------------------*/ | |
| 27 | +.ui-state-disabled { cursor: default !important; } | |
| 28 | + | |
| 29 | + | |
| 30 | +/* Icons | |
| 31 | +----------------------------------*/ | |
| 32 | + | |
| 33 | +/* states and images */ | |
| 34 | +.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } | |
| 35 | + | |
| 36 | + | |
| 37 | +/* Misc visuals | |
| 38 | +----------------------------------*/ | |
| 39 | + | |
| 40 | +/* Overlays */ | |
| 41 | +.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } | |
| 42 | + | |
| 43 | + | |
| 44 | +/* | |
| 45 | + * jQuery UI CSS Framework 1.8.16 | |
| 46 | + * | |
| 47 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 48 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 49 | + * http://jquery.org/license | |
| 50 | + * | |
| 51 | + * http://docs.jquery.com/UI/Theming/API | |
| 52 | + * | |
| 53 | + * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Verdana,Arial,sans-serif&fwDefault=normal&fsDefault=1.1em&cornerRadius=4px&bgColorHeader=cccccc&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=75&borderColorHeader=aaaaaa&fcHeader=222222&iconColorHeader=222222&bgColorContent=ffffff&bgTextureContent=01_flat.png&bgImgOpacityContent=75&borderColorContent=aaaaaa&fcContent=222222&iconColorContent=222222&bgColorDefault=e6e6e6&bgTextureDefault=02_glass.png&bgImgOpacityDefault=75&borderColorDefault=d3d3d3&fcDefault=555555&iconColorDefault=888888&bgColorHover=dadada&bgTextureHover=02_glass.png&bgImgOpacityHover=75&borderColorHover=999999&fcHover=212121&iconColorHover=454545&bgColorActive=ffffff&bgTextureActive=02_glass.png&bgImgOpacityActive=65&borderColorActive=aaaaaa&fcActive=212121&iconColorActive=454545&bgColorHighlight=fbf9ee&bgTextureHighlight=02_glass.png&bgImgOpacityHighlight=55&borderColorHighlight=fcefa1&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=02_glass.png&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=01_flat.png&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px | |
| 54 | + */ | |
| 55 | + | |
| 56 | + | |
| 57 | +/* Component containers | |
| 58 | +----------------------------------*/ | |
| 59 | +.ui-widget { font-family: "Helvetica Neue",Arial,Helvetica,sans-serif; font-size: 1.1em; } | |
| 60 | +.ui-widget .ui-widget { font-size: 1em; } | |
| 61 | +.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Verdana,Arial,sans-serif; font-size: 1em; } | |
| 62 | +.ui-widget-content { border: 1px solid #dddddd; background: #ffffff url(ui-bg_flat_75_ffffff_40x100.png) 50% 50% repeat-x; color: #222222; } | |
| 63 | +.ui-widget-content a { color: #222222; } | |
| 64 | +.ui-widget-header { color: #222222; font-weight: bold; } | |
| 65 | +.ui-widget-header a { color: #222222; } | |
| 66 | + | |
| 67 | +/* Interaction states | |
| 68 | +----------------------------------*/ | |
| 69 | +.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #d3d3d3; background: #e6e6e6 url(ui-bg_glass_75_e6e6e6_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #555555; } | |
| 70 | +.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #555555; text-decoration: none; } | |
| 71 | +.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999; background: #dadada url(ui-bg_glass_75_dadada_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #212121; } | |
| 72 | +.ui-state-hover a, .ui-state-hover a:hover { color: #212121; text-decoration: none; } | |
| 73 | +.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa; background: #ffffff url(ui-bg_glass_65_ffffff_1x400.png) 50% 50% repeat-x; font-weight: normal; color: #212121; } | |
| 74 | +.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121; text-decoration: none; } | |
| 75 | +.ui-widget :active { outline: none; } | |
| 76 | + | |
| 77 | +/* Interaction Cues | |
| 78 | +----------------------------------*/ | |
| 79 | +.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fcefa1; background: #fbf9ee url(ui-bg_glass_55_fbf9ee_1x400.png) 50% 50% repeat-x; color: #363636; } | |
| 80 | +.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } | |
| 81 | +.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #fef1ec url(ui-bg_glass_95_fef1ec_1x400.png) 50% 50% repeat-x; color: #cd0a0a; } | |
| 82 | +.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; } | |
| 83 | +.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; } | |
| 84 | +.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } | |
| 85 | +.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } | |
| 86 | +.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } | |
| 87 | + | |
| 88 | +/* Icons | |
| 89 | +----------------------------------*/ | |
| 90 | + | |
| 91 | +/* states and images */ | |
| 92 | +.ui-icon { width: 16px; height: 16px; background-image: url(ui-icons_222222_256x240.png); } | |
| 93 | +.ui-widget-content .ui-icon {background-image: url(ui-icons_222222_256x240.png); } | |
| 94 | +.ui-widget-header .ui-icon {background-image: url(ui-icons_222222_256x240.png); } | |
| 95 | +.ui-state-default .ui-icon { background-image: url(ui-icons_888888_256x240.png); } | |
| 96 | +.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(ui-icons_454545_256x240.png); } | |
| 97 | +.ui-state-active .ui-icon {background-image: url(ui-icons_454545_256x240.png); } | |
| 98 | +.ui-state-highlight .ui-icon {background-image: url(ui-icons_2e83ff_256x240.png); } | |
| 99 | +.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(ui-icons_cd0a0a_256x240.png); } | |
| 100 | + | |
| 101 | +/* positioning */ | |
| 102 | +.ui-icon-carat-1-n { background-position: 0 0; } | |
| 103 | +.ui-icon-carat-1-ne { background-position: -16px 0; } | |
| 104 | +.ui-icon-carat-1-e { background-position: -32px 0; } | |
| 105 | +.ui-icon-carat-1-se { background-position: -48px 0; } | |
| 106 | +.ui-icon-carat-1-s { background-position: -64px 0; } | |
| 107 | +.ui-icon-carat-1-sw { background-position: -80px 0; } | |
| 108 | +.ui-icon-carat-1-w { background-position: -96px 0; } | |
| 109 | +.ui-icon-carat-1-nw { background-position: -112px 0; } | |
| 110 | +.ui-icon-carat-2-n-s { background-position: -128px 0; } | |
| 111 | +.ui-icon-carat-2-e-w { background-position: -144px 0; } | |
| 112 | +.ui-icon-triangle-1-n { background-position: 0 -16px; } | |
| 113 | +.ui-icon-triangle-1-ne { background-position: -16px -16px; } | |
| 114 | +.ui-icon-triangle-1-e { background-position: -32px -16px; } | |
| 115 | +.ui-icon-triangle-1-se { background-position: -48px -16px; } | |
| 116 | +.ui-icon-triangle-1-s { background-position: -64px -16px; } | |
| 117 | +.ui-icon-triangle-1-sw { background-position: -80px -16px; } | |
| 118 | +.ui-icon-triangle-1-w { background-position: -96px -16px; } | |
| 119 | +.ui-icon-triangle-1-nw { background-position: -112px -16px; } | |
| 120 | +.ui-icon-triangle-2-n-s { background-position: -128px -16px; } | |
| 121 | +.ui-icon-triangle-2-e-w { background-position: -144px -16px; } | |
| 122 | +.ui-icon-arrow-1-n { background-position: 0 -32px; } | |
| 123 | +.ui-icon-arrow-1-ne { background-position: -16px -32px; } | |
| 124 | +.ui-icon-arrow-1-e { background-position: -32px -32px; } | |
| 125 | +.ui-icon-arrow-1-se { background-position: -48px -32px; } | |
| 126 | +.ui-icon-arrow-1-s { background-position: -64px -32px; } | |
| 127 | +.ui-icon-arrow-1-sw { background-position: -80px -32px; } | |
| 128 | +.ui-icon-arrow-1-w { background-position: -96px -32px; } | |
| 129 | +.ui-icon-arrow-1-nw { background-position: -112px -32px; } | |
| 130 | +.ui-icon-arrow-2-n-s { background-position: -128px -32px; } | |
| 131 | +.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } | |
| 132 | +.ui-icon-arrow-2-e-w { background-position: -160px -32px; } | |
| 133 | +.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } | |
| 134 | +.ui-icon-arrowstop-1-n { background-position: -192px -32px; } | |
| 135 | +.ui-icon-arrowstop-1-e { background-position: -208px -32px; } | |
| 136 | +.ui-icon-arrowstop-1-s { background-position: -224px -32px; } | |
| 137 | +.ui-icon-arrowstop-1-w { background-position: -240px -32px; } | |
| 138 | +.ui-icon-arrowthick-1-n { background-position: 0 -48px; } | |
| 139 | +.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } | |
| 140 | +.ui-icon-arrowthick-1-e { background-position: -32px -48px; } | |
| 141 | +.ui-icon-arrowthick-1-se { background-position: -48px -48px; } | |
| 142 | +.ui-icon-arrowthick-1-s { background-position: -64px -48px; } | |
| 143 | +.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } | |
| 144 | +.ui-icon-arrowthick-1-w { background-position: -96px -48px; } | |
| 145 | +.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } | |
| 146 | +.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } | |
| 147 | +.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } | |
| 148 | +.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } | |
| 149 | +.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } | |
| 150 | +.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } | |
| 151 | +.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } | |
| 152 | +.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } | |
| 153 | +.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } | |
| 154 | +.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } | |
| 155 | +.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } | |
| 156 | +.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } | |
| 157 | +.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } | |
| 158 | +.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } | |
| 159 | +.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } | |
| 160 | +.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } | |
| 161 | +.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } | |
| 162 | +.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } | |
| 163 | +.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } | |
| 164 | +.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } | |
| 165 | +.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } | |
| 166 | +.ui-icon-arrow-4 { background-position: 0 -80px; } | |
| 167 | +.ui-icon-arrow-4-diag { background-position: -16px -80px; } | |
| 168 | +.ui-icon-extlink { background-position: -32px -80px; } | |
| 169 | +.ui-icon-newwin { background-position: -48px -80px; } | |
| 170 | +.ui-icon-refresh { background-position: -64px -80px; } | |
| 171 | +.ui-icon-shuffle { background-position: -80px -80px; } | |
| 172 | +.ui-icon-transfer-e-w { background-position: -96px -80px; } | |
| 173 | +.ui-icon-transferthick-e-w { background-position: -112px -80px; } | |
| 174 | +.ui-icon-folder-collapsed { background-position: 0 -96px; } | |
| 175 | +.ui-icon-folder-open { background-position: -16px -96px; } | |
| 176 | +.ui-icon-document { background-position: -32px -96px; } | |
| 177 | +.ui-icon-document-b { background-position: -48px -96px; } | |
| 178 | +.ui-icon-note { background-position: -64px -96px; } | |
| 179 | +.ui-icon-mail-closed { background-position: -80px -96px; } | |
| 180 | +.ui-icon-mail-open { background-position: -96px -96px; } | |
| 181 | +.ui-icon-suitcase { background-position: -112px -96px; } | |
| 182 | +.ui-icon-comment { background-position: -128px -96px; } | |
| 183 | +.ui-icon-person { background-position: -144px -96px; } | |
| 184 | +.ui-icon-print { background-position: -160px -96px; } | |
| 185 | +.ui-icon-trash { background-position: -176px -96px; } | |
| 186 | +.ui-icon-locked { background-position: -192px -96px; } | |
| 187 | +.ui-icon-unlocked { background-position: -208px -96px; } | |
| 188 | +.ui-icon-bookmark { background-position: -224px -96px; } | |
| 189 | +.ui-icon-tag { background-position: -240px -96px; } | |
| 190 | +.ui-icon-home { background-position: 0 -112px; } | |
| 191 | +.ui-icon-flag { background-position: -16px -112px; } | |
| 192 | +.ui-icon-calendar { background-position: -32px -112px; } | |
| 193 | +.ui-icon-cart { background-position: -48px -112px; } | |
| 194 | +.ui-icon-pencil { background-position: -64px -112px; } | |
| 195 | +.ui-icon-clock { background-position: -80px -112px; } | |
| 196 | +.ui-icon-disk { background-position: -96px -112px; } | |
| 197 | +.ui-icon-calculator { background-position: -112px -112px; } | |
| 198 | +.ui-icon-zoomin { background-position: -128px -112px; } | |
| 199 | +.ui-icon-zoomout { background-position: -144px -112px; } | |
| 200 | +.ui-icon-search { background-position: -160px -112px; } | |
| 201 | +.ui-icon-wrench { background-position: -176px -112px; } | |
| 202 | +.ui-icon-gear { background-position: -192px -112px; } | |
| 203 | +.ui-icon-heart { background-position: -208px -112px; } | |
| 204 | +.ui-icon-star { background-position: -224px -112px; } | |
| 205 | +.ui-icon-link { background-position: -240px -112px; } | |
| 206 | +.ui-icon-cancel { background-position: 0 -128px; } | |
| 207 | +.ui-icon-plus { background-position: -16px -128px; } | |
| 208 | +.ui-icon-plusthick { background-position: -32px -128px; } | |
| 209 | +.ui-icon-minus { background-position: -48px -128px; } | |
| 210 | +.ui-icon-minusthick { background-position: -64px -128px; } | |
| 211 | +.ui-icon-close { background-position: -80px -128px; } | |
| 212 | +.ui-icon-closethick { background-position: -96px -128px; } | |
| 213 | +.ui-icon-key { background-position: -112px -128px; } | |
| 214 | +.ui-icon-lightbulb { background-position: -128px -128px; } | |
| 215 | +.ui-icon-scissors { background-position: -144px -128px; } | |
| 216 | +.ui-icon-clipboard { background-position: -160px -128px; } | |
| 217 | +.ui-icon-copy { background-position: -176px -128px; } | |
| 218 | +.ui-icon-contact { background-position: -192px -128px; } | |
| 219 | +.ui-icon-image { background-position: -208px -128px; } | |
| 220 | +.ui-icon-video { background-position: -224px -128px; } | |
| 221 | +.ui-icon-script { background-position: -240px -128px; } | |
| 222 | +.ui-icon-alert { background-position: 0 -144px; } | |
| 223 | +.ui-icon-info { background-position: -16px -144px; } | |
| 224 | +.ui-icon-notice { background-position: -32px -144px; } | |
| 225 | +.ui-icon-help { background-position: -48px -144px; } | |
| 226 | +.ui-icon-check { background-position: -64px -144px; } | |
| 227 | +.ui-icon-bullet { background-position: -80px -144px; } | |
| 228 | +.ui-icon-radio-off { background-position: -96px -144px; } | |
| 229 | +.ui-icon-radio-on { background-position: -112px -144px; } | |
| 230 | +.ui-icon-pin-w { background-position: -128px -144px; } | |
| 231 | +.ui-icon-pin-s { background-position: -144px -144px; } | |
| 232 | +.ui-icon-play { background-position: 0 -160px; } | |
| 233 | +.ui-icon-pause { background-position: -16px -160px; } | |
| 234 | +.ui-icon-seek-next { background-position: -32px -160px; } | |
| 235 | +.ui-icon-seek-prev { background-position: -48px -160px; } | |
| 236 | +.ui-icon-seek-end { background-position: -64px -160px; } | |
| 237 | +.ui-icon-seek-start { background-position: -80px -160px; } | |
| 238 | +/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ | |
| 239 | +.ui-icon-seek-first { background-position: -80px -160px; } | |
| 240 | +.ui-icon-stop { background-position: -96px -160px; } | |
| 241 | +.ui-icon-eject { background-position: -112px -160px; } | |
| 242 | +.ui-icon-volume-off { background-position: -128px -160px; } | |
| 243 | +.ui-icon-volume-on { background-position: -144px -160px; } | |
| 244 | +.ui-icon-power { background-position: 0 -176px; } | |
| 245 | +.ui-icon-signal-diag { background-position: -16px -176px; } | |
| 246 | +.ui-icon-signal { background-position: -32px -176px; } | |
| 247 | +.ui-icon-battery-0 { background-position: -48px -176px; } | |
| 248 | +.ui-icon-battery-1 { background-position: -64px -176px; } | |
| 249 | +.ui-icon-battery-2 { background-position: -80px -176px; } | |
| 250 | +.ui-icon-battery-3 { background-position: -96px -176px; } | |
| 251 | +.ui-icon-circle-plus { background-position: 0 -192px; } | |
| 252 | +.ui-icon-circle-minus { background-position: -16px -192px; } | |
| 253 | +.ui-icon-circle-close { background-position: -32px -192px; } | |
| 254 | +.ui-icon-circle-triangle-e { background-position: -48px -192px; } | |
| 255 | +.ui-icon-circle-triangle-s { background-position: -64px -192px; } | |
| 256 | +.ui-icon-circle-triangle-w { background-position: -80px -192px; } | |
| 257 | +.ui-icon-circle-triangle-n { background-position: -96px -192px; } | |
| 258 | +.ui-icon-circle-arrow-e { background-position: -112px -192px; } | |
| 259 | +.ui-icon-circle-arrow-s { background-position: -128px -192px; } | |
| 260 | +.ui-icon-circle-arrow-w { background-position: -144px -192px; } | |
| 261 | +.ui-icon-circle-arrow-n { background-position: -160px -192px; } | |
| 262 | +.ui-icon-circle-zoomin { background-position: -176px -192px; } | |
| 263 | +.ui-icon-circle-zoomout { background-position: -192px -192px; } | |
| 264 | +.ui-icon-circle-check { background-position: -208px -192px; } | |
| 265 | +.ui-icon-circlesmall-plus { background-position: 0 -208px; } | |
| 266 | +.ui-icon-circlesmall-minus { background-position: -16px -208px; } | |
| 267 | +.ui-icon-circlesmall-close { background-position: -32px -208px; } | |
| 268 | +.ui-icon-squaresmall-plus { background-position: -48px -208px; } | |
| 269 | +.ui-icon-squaresmall-minus { background-position: -64px -208px; } | |
| 270 | +.ui-icon-squaresmall-close { background-position: -80px -208px; } | |
| 271 | +.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } | |
| 272 | +.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } | |
| 273 | +.ui-icon-grip-solid-vertical { background-position: -32px -224px; } | |
| 274 | +.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } | |
| 275 | +.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } | |
| 276 | +.ui-icon-grip-diagonal-se { background-position: -80px -224px; } | |
| 277 | + | |
| 278 | + | |
| 279 | +/* Misc visuals | |
| 280 | +----------------------------------*/ | |
| 281 | + | |
| 282 | +/* Corner radius */ | |
| 283 | +/*.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 4px; -webkit-border-top-left-radius: 4px; -khtml-border-top-left-radius: 4px; border-top-left-radius: 4px; }*/ | |
| 284 | +/*.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 4px; -webkit-border-top-right-radius: 4px; -khtml-border-top-right-radius: 4px; border-top-right-radius: 4px; }*/ | |
| 285 | +/*.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 4px; -webkit-border-bottom-left-radius: 4px; -khtml-border-bottom-left-radius: 4px; border-bottom-left-radius: 4px; }*/ | |
| 286 | +/*.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 4px; -khtml-border-bottom-right-radius: 4px; border-bottom-right-radius: 4px; }*/ | |
| 287 | + | |
| 288 | +/* Overlays */ | |
| 289 | +.ui-widget-overlay { background: #aaaaaa url(ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); } | |
| 290 | +.ui-widget-shadow { margin: -8px 0 0 -8px; padding: 8px; background: #aaaaaa url(ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -khtml-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }/* | |
| 291 | + * jQuery UI Resizable 1.8.16 | |
| 292 | + * | |
| 293 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 294 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 295 | + * http://jquery.org/license | |
| 296 | + * | |
| 297 | + * http://docs.jquery.com/UI/Resizable#theming | |
| 298 | + */ | |
| 299 | +.ui-resizable { position: relative;} | |
| 300 | +.ui-resizable-handle { position: absolute;font-size: 0.1px;z-index: 99999; display: block; } | |
| 301 | +.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } | |
| 302 | +.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } | |
| 303 | +.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } | |
| 304 | +.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } | |
| 305 | +.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } | |
| 306 | +.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } | |
| 307 | +.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } | |
| 308 | +.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } | |
| 309 | +.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/* | |
| 310 | + * jQuery UI Selectable 1.8.16 | |
| 311 | + * | |
| 312 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 313 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 314 | + * http://jquery.org/license | |
| 315 | + * | |
| 316 | + * http://docs.jquery.com/UI/Selectable#theming | |
| 317 | + */ | |
| 318 | +.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } | |
| 319 | +/* | |
| 320 | + * jQuery UI Accordion 1.8.16 | |
| 321 | + * | |
| 322 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 323 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 324 | + * http://jquery.org/license | |
| 325 | + * | |
| 326 | + * http://docs.jquery.com/UI/Accordion#theming | |
| 327 | + */ | |
| 328 | +/* IE/Win - Fix animation bug - #4615 */ | |
| 329 | +.ui-accordion { width: 100%; } | |
| 330 | +.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; border:1px solid #ddd} | |
| 331 | +.ui-accordion .ui-accordion-li-fix { display: inline; } | |
| 332 | +.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } | |
| 333 | +.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } | |
| 334 | +.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } | |
| 335 | +.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } | |
| 336 | +.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } | |
| 337 | +.ui-accordion .ui-accordion-content-active { display: block; } | |
| 338 | +/* | |
| 339 | + * jQuery UI Autocomplete 1.8.16 | |
| 340 | + * | |
| 341 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 342 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 343 | + * http://jquery.org/license | |
| 344 | + * | |
| 345 | + * http://docs.jquery.com/UI/Autocomplete#theming | |
| 346 | + */ | |
| 347 | +.ui-autocomplete { position: absolute; cursor: default; } | |
| 348 | + | |
| 349 | +/* workarounds */ | |
| 350 | +* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ | |
| 351 | + | |
| 352 | +/* | |
| 353 | + * jQuery UI Menu 1.8.16 | |
| 354 | + * | |
| 355 | + * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) | |
| 356 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 357 | + * http://jquery.org/license | |
| 358 | + * | |
| 359 | + * http://docs.jquery.com/UI/Menu#theming | |
| 360 | + */ | |
| 361 | +.ui-menu { | |
| 362 | + list-style:none; | |
| 363 | + padding: 2px; | |
| 364 | + margin: 0; | |
| 365 | + display:block; | |
| 366 | + float: left; | |
| 367 | +} | |
| 368 | +.ui-menu .ui-menu { | |
| 369 | + margin-top: -3px; | |
| 370 | +} | |
| 371 | +.ui-menu .ui-menu-item { | |
| 372 | + margin:0; | |
| 373 | + padding: 0; | |
| 374 | + zoom: 1; | |
| 375 | + float: left; | |
| 376 | + clear: left; | |
| 377 | + width: 100%; | |
| 378 | +} | |
| 379 | +.ui-menu .ui-menu-item a { | |
| 380 | + text-decoration:none; | |
| 381 | + display:block; | |
| 382 | + padding:.2em .4em; | |
| 383 | + line-height:1.5; | |
| 384 | + zoom:1; | |
| 385 | +} | |
| 386 | +.ui-menu .ui-menu-item a.ui-state-hover, | |
| 387 | +.ui-menu .ui-menu-item a.ui-state-active { | |
| 388 | + font-weight: normal; | |
| 389 | + margin: -1px; | |
| 390 | + background: #fff !important; | |
| 391 | + background: -webkit-gradient(linear,left top,left bottom,from(#fff),to(#FFF6BF)) !important; | |
| 392 | + background: -moz-linear-gradient(top,#fff,#FFF6BF) !important; | |
| 393 | + background: transparent 9 !important; | |
| 394 | + border-radius:0px; | |
| 395 | + border-color:white; | |
| 396 | + border-bottom: 1px solid #E2EAEE; | |
| 397 | + border-top: 1px solid #E2EAEE; | |
| 398 | + | |
| 399 | +} | |
| 400 | +/* | |
| 401 | + * jQuery UI Button 1.8.16 | |
| 402 | + * | |
| 403 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 404 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 405 | + * http://jquery.org/license | |
| 406 | + * | |
| 407 | + * http://docs.jquery.com/UI/Button#theming | |
| 408 | + */ | |
| 409 | +.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ | |
| 410 | +.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ | |
| 411 | +button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ | |
| 412 | +.ui-button-icons-only { width: 3.4em; } | |
| 413 | +button.ui-button-icons-only { width: 3.7em; } | |
| 414 | + | |
| 415 | +/*button text element */ | |
| 416 | +.ui-button .ui-button-text { display: block; line-height: 1.4; } | |
| 417 | +.ui-button-text-only .ui-button-text { padding: .4em 1em; } | |
| 418 | +.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } | |
| 419 | +.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } | |
| 420 | +.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } | |
| 421 | +.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } | |
| 422 | +/* no icon support for input elements, provide padding by default */ | |
| 423 | +input.ui-button { padding: .4em 1em; } | |
| 424 | + | |
| 425 | +/*button icon element(s) */ | |
| 426 | +.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } | |
| 427 | +.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } | |
| 428 | +.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } | |
| 429 | +.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } | |
| 430 | +.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } | |
| 431 | + | |
| 432 | +/*button sets*/ | |
| 433 | +.ui-buttonset { margin-right: 7px; } | |
| 434 | +.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } | |
| 435 | + | |
| 436 | +/* workarounds */ | |
| 437 | +button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ | |
| 438 | +/* | |
| 439 | + * jQuery UI Dialog 1.8.16 | |
| 440 | + * | |
| 441 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 442 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 443 | + * http://jquery.org/license | |
| 444 | + * | |
| 445 | + * http://docs.jquery.com/UI/Dialog#theming | |
| 446 | + */ | |
| 447 | +.ui-dialog { position: absolute; padding: 0; width: 300px; overflow: hidden; } | |
| 448 | +.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; background: #F7F7F7; color:#555; } | |
| 449 | +.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0;} | |
| 450 | +.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; background:#eaeaea} | |
| 451 | +.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } | |
| 452 | +.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } | |
| 453 | +.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } | |
| 454 | +.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } | |
| 455 | +.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } | |
| 456 | +.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } | |
| 457 | +.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } | |
| 458 | +.ui-draggable .ui-dialog-titlebar { cursor: move; } | |
| 459 | +/* | |
| 460 | + * jQuery UI Slider 1.8.16 | |
| 461 | + * | |
| 462 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 463 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 464 | + * http://jquery.org/license | |
| 465 | + * | |
| 466 | + * http://docs.jquery.com/UI/Slider#theming | |
| 467 | + */ | |
| 468 | +.ui-slider { position: relative; text-align: left; } | |
| 469 | +.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } | |
| 470 | +.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } | |
| 471 | + | |
| 472 | +.ui-slider-horizontal { height: .8em; } | |
| 473 | +.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } | |
| 474 | +.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } | |
| 475 | +.ui-slider-horizontal .ui-slider-range-min { left: 0; } | |
| 476 | +.ui-slider-horizontal .ui-slider-range-max { right: 0; } | |
| 477 | + | |
| 478 | +.ui-slider-vertical { width: .8em; height: 100px; } | |
| 479 | +.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } | |
| 480 | +.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } | |
| 481 | +.ui-slider-vertical .ui-slider-range-min { bottom: 0; } | |
| 482 | +.ui-slider-vertical .ui-slider-range-max { top: 0; }/* | |
| 483 | + * jQuery UI Tabs 1.8.16 | |
| 484 | + * | |
| 485 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 486 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 487 | + * http://jquery.org/license | |
| 488 | + * | |
| 489 | + * http://docs.jquery.com/UI/Tabs#theming | |
| 490 | + */ | |
| 491 | +.ui-tabs { position: relative; padding: 0; border:none; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ | |
| 492 | +.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } | |
| 493 | +.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap;} | |
| 494 | +.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; width:200px} | |
| 495 | +.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } | |
| 496 | +.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } | |
| 497 | +.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ | |
| 498 | +.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 0; background: none; } | |
| 499 | +.ui-tabs .ui-tabs-hide { display: none !important; } | |
| 500 | +/* | |
| 501 | + * jQuery UI Datepicker 1.8.16 | |
| 502 | + * | |
| 503 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 504 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 505 | + * http://jquery.org/license | |
| 506 | + * | |
| 507 | + * http://docs.jquery.com/UI/Datepicker#theming | |
| 508 | + */ | |
| 509 | +.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } | |
| 510 | +.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } | |
| 511 | +.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } | |
| 512 | +.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } | |
| 513 | +.ui-datepicker .ui-datepicker-prev { left:2px; } | |
| 514 | +.ui-datepicker .ui-datepicker-next { right:2px; } | |
| 515 | +.ui-datepicker .ui-datepicker-prev-hover { left:1px; } | |
| 516 | +.ui-datepicker .ui-datepicker-next-hover { right:1px; } | |
| 517 | +.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } | |
| 518 | +.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } | |
| 519 | +.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } | |
| 520 | +.ui-datepicker select.ui-datepicker-month-year {width: 100%;} | |
| 521 | +.ui-datepicker select.ui-datepicker-month, | |
| 522 | +.ui-datepicker select.ui-datepicker-year { width: 49%;} | |
| 523 | +.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } | |
| 524 | +.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } | |
| 525 | +.ui-datepicker td { border: 0; padding: 1px; } | |
| 526 | +.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } | |
| 527 | +.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } | |
| 528 | +.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } | |
| 529 | +.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } | |
| 530 | + | |
| 531 | +/* with multiple calendars */ | |
| 532 | +.ui-datepicker.ui-datepicker-multi { width:auto; } | |
| 533 | +.ui-datepicker-multi .ui-datepicker-group { float:left; } | |
| 534 | +.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } | |
| 535 | +.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } | |
| 536 | +.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } | |
| 537 | +.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } | |
| 538 | +.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } | |
| 539 | +.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } | |
| 540 | +.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } | |
| 541 | +.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; } | |
| 542 | + | |
| 543 | +/* RTL support */ | |
| 544 | +.ui-datepicker-rtl { direction: rtl; } | |
| 545 | +.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } | |
| 546 | +.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } | |
| 547 | +.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } | |
| 548 | +.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } | |
| 549 | +.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } | |
| 550 | +.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } | |
| 551 | +.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } | |
| 552 | +.ui-datepicker-rtl .ui-datepicker-group { float:right; } | |
| 553 | +.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } | |
| 554 | +.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } | |
| 555 | + | |
| 556 | +/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ | |
| 557 | +.ui-datepicker-cover { | |
| 558 | + display: none; /*sorry for IE5*/ | |
| 559 | + display/**/: block; /*sorry for IE5*/ | |
| 560 | + position: absolute; /*must have*/ | |
| 561 | + z-index: -1; /*must have*/ | |
| 562 | + filter: mask(); /*must have*/ | |
| 563 | + top: -4px; /*must have*/ | |
| 564 | + left: -4px; /*must have*/ | |
| 565 | + width: 200px; /*must have*/ | |
| 566 | + height: 200px; /*must have*/ | |
| 567 | +}/* | |
| 568 | + * jQuery UI Progressbar 1.8.16 | |
| 569 | + * | |
| 570 | + * Copyright 2011, AUTHORS.txt (http://jqueryui.com/about) | |
| 571 | + * Dual licensed under the MIT or GPL Version 2 licenses. | |
| 572 | + * http://jquery.org/license | |
| 573 | + * | |
| 574 | + * http://docs.jquery.com/UI/Progressbar#theming | |
| 575 | + */ | |
| 576 | +.ui-progressbar { height:2em; text-align: left; } | |
| 577 | +.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } | ... | ... |
| ... | ... | @@ -0,0 +1,34 @@ |
| 1 | +/* Tagify styles | |
| 2 | +Author: Alicia Liu test | |
| 3 | +*/ | |
| 4 | + | |
| 5 | +.tagify-container { | |
| 6 | +} | |
| 7 | + | |
| 8 | +.tagify-container > span { | |
| 9 | + display: inline-block; | |
| 10 | + padding: 8px 11px 8px 11px; | |
| 11 | + margin: 1px 5px 0px 0px; | |
| 12 | + border-radius: 4px; | |
| 13 | + border: 1px solid #d0e1ff; | |
| 14 | + background-color: #d0e1ff; | |
| 15 | + color: #0f326d; | |
| 16 | + font-weight: bold; | |
| 17 | + font-size: 14px; | |
| 18 | +} | |
| 19 | + | |
| 20 | +.tagify-container > span > a { | |
| 21 | + padding-left: 5px !important; | |
| 22 | + color: #83a5e1; | |
| 23 | + text-decoration: none; | |
| 24 | + font-weight: bold; | |
| 25 | +} | |
| 26 | + | |
| 27 | +.tagify-container > input { | |
| 28 | + border: 0 none; | |
| 29 | + width: 100px !important; | |
| 30 | +} | |
| 31 | + | |
| 32 | +.tagify-container > input:focus { | |
| 33 | + outline: none; | |
| 34 | +} | |
| 0 | 35 | \ No newline at end of file | ... | ... |
vendor/assets/stylesheets/jquery-ui/jquery.ui.selectmenu.css
0 → 100644
| ... | ... | @@ -0,0 +1,33 @@ |
| 1 | +/* Selectmenu | |
| 2 | +----------------------------------*/ | |
| 3 | +.ui-selectmenu { background:none; font-size:12px;display: block; display: inline-block; position: relative; height: 2.2em; vertical-align: middle; text-decoration: none; overflow: hidden; zoom: 1; } | |
| 4 | +.ui-selectmenu-icon { position:absolute; right:6px; margin-top:-8px; top: 50%; } | |
| 5 | +.ui-selectmenu-menu { padding:0; margin:0; position:absolute; top: 0; display: none; z-index: 1005;} /* z-index: 1005 to make selectmenu work with dialog */ | |
| 6 | +.ui-selectmenu-menu ul { padding:0; margin:0; list-style:none; position: relative; overflow: auto; overflow-y: auto ; overflow-x: hidden; } | |
| 7 | +.ui-selectmenu-open { display: block; } | |
| 8 | +.ui-selectmenu.ui-widget { background:none; } | |
| 9 | +.ui-selectmenu-menu-popup { margin-top: -1px; } | |
| 10 | +.ui-selectmenu-menu-dropdown { } | |
| 11 | +.ui-selectmenu-menu li.ui-state-active { background:#F7FBFC; border:none; padding:1px 0;} | |
| 12 | +.ui-selectmenu-menu li { padding:0; margin:0; display: block; border-top: 1px dotted transparent; border-bottom: 1px dotted transparent; border-right-width: 0 !important; border-left-width: 0 !important; font-weight: normal !important; } | |
| 13 | +.ui-selectmenu-menu li a,.ui-selectmenu-status { line-height: 1.4em; display: block; padding: .405em 2.1em .405em 1em; outline:none; text-decoration:none; } | |
| 14 | +.ui-selectmenu-menu li.ui-state-disabled a, .ui-state-disabled { cursor: default; } | |
| 15 | +.ui-selectmenu-menu li.ui-selectmenu-hasIcon a, | |
| 16 | +.ui-selectmenu-hasIcon .ui-selectmenu-status { padding-left: 20px; position: relative; margin-left: 5px; } | |
| 17 | +.ui-selectmenu-menu li .ui-icon, .ui-selectmenu-status .ui-icon { position: absolute; top: 1em; margin-top: -8px; left: 0; } | |
| 18 | +.ui-selectmenu-status { line-height: 1.4em; } | |
| 19 | +.ui-selectmenu-open li.ui-selectmenu-item-focus { background: none repeat scroll 0 0 #FFF6BF; border:1px solid #eaeaea;} | |
| 20 | +.ui-selectmenu-open li.ui-selectmenu-item-selected { } | |
| 21 | +.ui-selectmenu-menu li span,.ui-selectmenu-status span { display:block; margin-bottom: .2em; } | |
| 22 | +.ui-selectmenu-menu li .ui-selectmenu-item-header { font-weight: bold; } | |
| 23 | +.ui-selectmenu-menu li .ui-selectmenu-item-content { } | |
| 24 | +.ui-selectmenu-menu li .ui-selectmenu-item-footer { opacity: .8; } | |
| 25 | +/* for optgroups */ | |
| 26 | +.ui-selectmenu-menu .ui-selectmenu-group { font-size: 1em; } | |
| 27 | +.ui-selectmenu-menu .ui-selectmenu-group .ui-selectmenu-group-label { line-height: 1.4em; display:block; padding: .6em .5em 0; font-weight: bold; } | |
| 28 | +.ui-selectmenu-menu .ui-selectmenu-group ul { margin: 0; padding: 0; } | |
| 29 | +/* IE6 workaround (dotted transparent borders) */ | |
| 30 | +* html .ui-selectmenu-menu li { border-color: pink; filter:chroma(color=pink); width:100%; } | |
| 31 | +* html .ui-selectmenu-menu li a { position: relative } | |
| 32 | +/* IE7 workaround (opacity disabled) */ | |
| 33 | +*+html .ui-state-disabled, *+html .ui-state-disabled a { color: silver; } | ... | ... |