Commit b8ca1d62c453fcdb8cb7f65ee793fcd159b4c336

Authored by Dmitriy Zaporozhets
2 parents 23187d60 1d1b5186

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
1 1 [Dolphin]
2 2 ShowPreview=true
3   -Timestamp=2011,9,14,20,34,18
  3 +Timestamp=2011,10,28,13,16,25
4 4 Version=2
... ...
app/assets/images/bg-header.png 0 → 100644

212 Bytes

app/assets/images/chosen-sprite.png 0 → 100644

396 Bytes

app/assets/images/icon-search.png 0 → 100644

422 Bytes

app/assets/images/images.png 0 → 100644

8.49 KB

app/assets/images/login-logo.png 0 → 100644

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 }
... ...
app/assets/javascripts/chosen.jquery.js 0 → 100644
... ... @@ -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 +}
... ...
app/assets/javascripts/modernizr-2.0.6.min.js 0 → 100755
... ... @@ -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=["&shy;","<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
... ...
app/assets/javascripts/note.js 0 → 100644
... ... @@ -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
... ... @@ -8,7 +8,7 @@ $(document).ready(function(){
8 8 e.stopPropagation();
9 9 $(this).find("td.tree-item-file-name a").click();
10 10 return false;
11   - }
  11 + }
12 12 });
13 13  
14 14 $("#projects-list .project").live('click', function(e){
... ...
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 */
... ...
app/assets/stylesheets/chosen.css 0 → 100644
... ... @@ -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;}
... ...
app/assets/stylesheets/style.scss 0 → 100755
... ... @@ -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 +}
... ...
app/assets/stylesheets/tags.css.css 0 → 100644
... ... @@ -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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &quot;base64&quot;
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 &lt; 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 &lt; 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
1 1 class DashboardController < ApplicationController
2 2 def index
3 3 @projects = current_user.projects.all
  4 + @active_projects = @projects.select(&:last_activity_date).sort_by(&:last_activity_date).reverse
4 5 end
5 6 end
... ...
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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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  
... ...
app/controllers/tags_controller.rb 0 → 100644
... ... @@ -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 &lt; 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 &lt; 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\">&nbsp;</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\">&nbsp;</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
... ... @@ -12,7 +12,7 @@ module ProjectsHelper
12 12 else
13 13 true
14 14 end
15   - rescue
  15 + rescue
16 16 nil
17 17 end
18 18 end
... ...
app/helpers/snippets_helper.rb
1 1 module SnippetsHelper
  2 + def lifetime_select_options
  3 + options = [
  4 + ['forever', nil],
  5 + ['1 day', "#{Date.current + 1.day}"],
  6 + ['1 week', "#{Date.current + 1.week}"],
  7 + ['1 month', "#{Date.current + 1.month}"]
  8 + ]
  9 + options_for_select(options)
  10 + end
2 11 end
... ...
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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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 &lt; 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
1 1 %table
2   - %tr
  2 + %thead
3 3 %th Name
4 4 %th Code
5 5 %th Path
... ...
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
... ... @@ -11,7 +11,6 @@
11 11 %b Since:
12 12 = @admin_team_member.updated_at
13 13  
14   -
15 14 .span-10
16 15 .span-6
17 16 %b Access:
... ...
app/views/admin/users/_form.html.haml
... ... @@ -44,7 +44,7 @@
44 44 .field
45 45 = f.label :twitter
46 46 %br
47   - = f.text_field :twitter
  47 + = f.text_field :twitter
48 48 .clear
49 49 %br
50 50 .actions
... ...
app/views/admin/users/index.html.haml
1 1 %table
2   - %tr
  2 + %thead
3 3 %th Admin
4 4 %th Name
5 5 %th Email
... ...
app/views/admin/users/new.html.haml
... ... @@ -2,5 +2,4 @@
2 2  
3 3 = render 'form'
4 4  
5   -
6 5 = link_to 'Back', admin_users_path, :class => "right lbutton"
... ...
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
... ... @@ -6,4 +6,4 @@
6 6 %h1 Listing commits
7 7 %div{:id => dom_id(@project)}
8 8 = render "commits"
9   -%br/
10 9 \ No newline at end of file
  10 +%br/
... ...
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   - &nbsp;
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/index.js.haml 0 → 100644
... ... @@ -0,0 +1,3 @@
  1 +:plain
  2 + CommitsList.append(#{@commits.count}, "#{escape_javascript(render(:partial => 'commits/commits'))}");
  3 +
... ...
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
... ... @@ -9,4 +9,4 @@
9 9 <div><%= f.submit "Resend confirmation instructions" %></div>
10 10 <% end %>
11 11  
12   -<%= render :partial => "devise/shared/links" %>
13 12 \ No newline at end of file
  13 +<%= render :partial => "devise/shared/links" %>
... ...
app/views/devise/passwords/edit.html.erb
... ... @@ -13,4 +13,4 @@
13 13 <div><%= f.submit "Change my password" %></div>
14 14 <% end %>
15 15  
16   -<%= render :partial => "devise/shared/links" %>
17 16 \ No newline at end of file
  17 +<%= render :partial => "devise/shared/links" %>
... ...
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
... ... @@ -22,4 +22,4 @@
22 22 <%- resource_class.omniauth_providers.each do |provider| %>
23 23 <%= link_to "Sign in with #{provider.to_s.titleize}", omniauth_authorize_path(resource_name, provider) %><br />
24 24 <% end -%>
25   -<% end -%>
26 25 \ No newline at end of file
  26 +<% end -%>
... ...
app/views/devise/unlocks/new.html.erb
... ... @@ -9,4 +9,4 @@
9 9 <div><%= f.submit "Resend unlock instructions" %></div>
10 10 <% end %>
11 11  
12   -<%= render :partial => "devise/shared/links" %>
13 12 \ No newline at end of file
  13 +<%= render :partial => "devise/shared/links" %>
... ...
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 + &nbsp;
  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 + &ndash;
  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
1   -:plain
2   - $("#notes-list").html("#{escape_javascript(render(:partial => 'notes/notes_list'))}");
  1 += render "notes/load"
... ...
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 %>
... ...
app/views/layouts/_page_title.html.haml 0 → 100644
... ... @@ -0,0 +1,2 @@
  1 +- if content_for?(:page_title)
  2 + = yield :page_title
... ...
app/views/layouts/admin.html.haml 0 → 100644
... ... @@ -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
... ...
app/views/layouts/devise.html.haml 0 → 100644
... ... @@ -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
... ...
app/views/layouts/profile.html.haml 0 → 100644
... ... @@ -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
... ...
app/views/layouts/project.html.haml 0 → 100644
... ... @@ -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"
... ...
app/views/notes/_load.js.haml 0 → 100644
... ... @@ -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 &amp; repository. Please wait for few minutes
42   - - else
  47 + - else
43 48 %h3.prepend-top Updating project &amp; 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
... ... @@ -11,7 +11,7 @@
11 11 $(".list").toggle();
12 12 if($(".tile").is(":visible")){
13 13 $.cookie('project_view', 'tile', { expires: 14 });
14   - } else {
  14 + } else {
15 15 $.cookie('project_view', 'list', { expires: 14 });
16 16 }
17 17 }
... ...
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:
... ...
app/views/projects/_refs.html.haml 0 → 100644
... ... @@ -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 &ndash;
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   - &nbsp;
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 + &nbsp;
  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
1   -:plain
2   - $("#notes-list").html("#{escape_javascript(render(:partial => 'notes/notes_list'))}");
  1 += render "notes/load"
... ...
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/tags/index.html.haml 0 → 100644
... ... @@ -0,0 +1,11 @@
  1 +- content_for(:body_class, "projects-page")
  2 +- content_for(:page_title) do
  3 + .grid_4
  4 + %h2
  5 + Tags
  6 +
  7 +
  8 + .tags-list
  9 + - @tags.all.each do |tag|
  10 + = link_to "#{tag.name}(#{tag.count})", "/tags/#{tag.name}"
  11 +
... ...
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
... ... @@ -25,4 +25,3 @@
25 25 %b Twitter:
26 26 = user.twitter
27 27  
28   -
... ...
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
... ... @@ -29,4 +29,5 @@ Gitlab::Application.configure do
29 29 config.assets.debug = true
30 30  
31 31 config.action_mailer.default_url_options = { :host => 'localhost:3000' }
  32 + config.action_mailer.delivery_method = :letter_opener
32 33 end
... ...
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
... ... @@ -7,6 +7,6 @@ Grit::Blob.class_eval do
7 7 include Utils::Colorize
8 8 end
9 9  
10   -Grit::Commit.class_eval do
  10 +Grit::Commit.class_eval do
11 11 include CommitExt
12 12 end
... ...
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
... ... @@ -11,7 +11,6 @@ class DeviseCreateUsers &lt; ActiveRecord::Migration
11 11 # t.lockable :lock_strategy => :failed_attempts, :unlock_strategy => :both
12 12 # t.token_authenticatable
13 13  
14   -
15 14 t.timestamps
16 15 end
17 16  
... ...
db/migrate/20111027051828_add_expires_at_to_snippets.rb 0 → 100644
... ... @@ -0,0 +1,5 @@
  1 +class AddExpiresAtToSnippets < ActiveRecord::Migration
  2 + def change
  3 + add_column :snippets, :expires_at, :datetime
  4 + end
  5 +end
... ...
db/migrate/20111027142641_change_note_note_to_text.rb 0 → 100644
... ... @@ -0,0 +1,8 @@
  1 +class ChangeNoteNoteToText < ActiveRecord::Migration
  2 + def up
  3 + change_column :notes, :note, :text, :limit => false
  4 + end
  5 +
  6 + def down
  7 + end
  8 +end
... ...
db/migrate/20111027152724_issue_conten_to_note.rb 0 → 100644
... ... @@ -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 =&gt; 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 =&gt; 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
... ... @@ -17,7 +17,7 @@ module Color
17 17  
18 18 def command(string)
19 19 `#{string}`
20   - if $?.to_i > 0
  20 + if $?.to_i > 0
21 21 puts red " == #{string} - FAIL"
22 22 puts red " == Error during configure"
23 23 exit
... ...
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 &lt; 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 &lt; 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 1 module Utils
2 2 module FileHelper
3   - def binary?(string)
  3 + def binary?(string)
4 4 string.each_byte do |x|
5   - x.nonzero? or return true
  5 + x.nonzero? or return true
6 6 end
7 7 false
8 8 end
... ...
public/apple-touch-icon-114x114-precomposed.png 0 → 100755

1.01 KB

public/apple-touch-icon-57x57-precomposed.png 0 → 100755

640 Bytes

public/apple-touch-icon-72x72-precomposed.png 0 → 100755

747 Bytes

public/apple-touch-icon-precomposed.png 0 → 100755

640 Bytes

public/apple-touch-icon.png 0 → 100755

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
... ... @@ -32,7 +32,6 @@ end
32 32  
33 33 Factory.add(:issue, Issue) do |obj|
34 34 obj.title = Faker::Lorem.sentence
35   - obj.content = Faker::Lorem.sentences
36 35 end
37 36  
38 37 Factory.add(:snippet, Snippet) do |obj|
... ...
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
... ... @@ -14,7 +14,7 @@ describe Issue do
14 14 it { should validate_presence_of(:assignee_id) }
15 15 end
16 16  
17   - describe "Scope" do
  17 + describe "Scope" do
18 18 it { Issue.should respond_to :closed }
19 19 it { Issue.should respond_to :opened }
20 20 end
... ...
spec/models/key_spec.rb
... ... @@ -10,7 +10,7 @@ describe Key do
10 10 it { should validate_presence_of(:key) }
11 11 end
12 12  
13   - describe "Methods" do
  13 + describe "Methods" do
14 14 it { should respond_to :projects }
15 15 end
16 16  
... ...
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
... ... @@ -26,5 +26,6 @@ end
26 26 # created_at :datetime
27 27 # updated_at :datetime
28 28 # file_name :string(255)
  29 +# expires_at :datetime
29 30 #
30 31  
... ...
spec/models/user_spec.rb
... ... @@ -14,7 +14,7 @@ describe User do
14 14 it { should respond_to(:name) }
15 15 end
16 16  
17   - it "should return valid identifier" do
  17 + it "should return valid identifier" do
18 18 user = User.new(:email => "test@mail.com")
19 19 user.identifier.should == "test_mail.com"
20 20 end
... ...
spec/models/users_project_spec.rb
... ... @@ -11,7 +11,7 @@ describe UsersProject do
11 11 it { should validate_presence_of(:project_id) }
12 12 end
13 13  
14   - describe "Delegate methods" do
  14 + describe "Delegate methods" do
15 15 it { should respond_to(:user_name) }
16 16 it { should respond_to(:user_email) }
17 17 end
... ...
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 &quot;Admin::Projects&quot; 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 &quot;Admin::Projects&quot; 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 &quot;Admin::Projects&quot; 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 &quot;Admin::Users&quot; 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 &quot;Admin::Users&quot; 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 &quot;Admin::Users&quot; 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 &quot;Admin::Users&quot; 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 &quot;Issues&quot; 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 &#39;spec_helper&#39;
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 &quot;Commits&quot; 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
... ...
spec/requests/dashboard_spec.rb 0 → 100644
... ... @@ -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 &#39;spec_helper&#39;
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 &quot;Issues&quot; 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 &#39;spec_helper&#39;
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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Issues&quot; 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 &quot;Profile&quot; 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 &quot;Profile&quot; 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 &quot;Profile&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &quot;Projects&quot; 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 &#39;spec_helper&#39;
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 &quot;Projects&quot;, &quot;Wall&quot; 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 &#39;spec_helper&#39;
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 &quot;Snippets&quot; 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 &quot;Snippets&quot; 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 &quot;Snippets&quot; 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 &quot;Snippets&quot; 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 &quot;Snippets&quot; 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 &quot;Snippets&quot; 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)
... ...
spec/requests/tags_spec.rb 0 → 100644
... ... @@ -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 &quot;TeamMembers&quot; 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 &quot;TeamMembers&quot; 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 &quot;TeamMembers&quot; 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 &quot;TeamMembers&quot; 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 &quot;TeamMembers&quot; 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 &quot;Top Panel&quot;, :js =&gt; 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 &quot;Top Panel&quot;, :js =&gt; 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 &quot;Top Panel&quot;, :js =&gt; 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 &#39;spec_helper&#39;
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 &#39;capybara/dsl&#39;
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
... ...
vendor/assets/images/jquery-ui/ui-bg_flat_0_aaaaaa_40x100.png 0 → 100644

180 Bytes

vendor/assets/images/jquery-ui/ui-bg_flat_75_ffffff_40x100.png 0 → 100644

178 Bytes

vendor/assets/images/jquery-ui/ui-bg_glass_55_fbf9ee_1x400.png 0 → 100644

120 Bytes

vendor/assets/images/jquery-ui/ui-bg_glass_65_ffffff_1x400.png 0 → 100644

105 Bytes

vendor/assets/images/jquery-ui/ui-bg_glass_75_dadada_1x400.png 0 → 100644

111 Bytes

vendor/assets/images/jquery-ui/ui-bg_glass_75_e6e6e6_1x400.png 0 → 100644

110 Bytes

vendor/assets/images/jquery-ui/ui-bg_glass_95_fef1ec_1x400.png 0 → 100644

119 Bytes

vendor/assets/images/jquery-ui/ui-bg_highlight-soft_75_cccccc_1x100.png 0 → 100644

101 Bytes

vendor/assets/images/jquery-ui/ui-icons_222222_256x240.png 0 → 100644

4.27 KB

vendor/assets/images/jquery-ui/ui-icons_2e83ff_256x240.png 0 → 100644

5.23 KB

vendor/assets/images/jquery-ui/ui-icons_454545_256x240.png 0 → 100644

4.27 KB

vendor/assets/images/jquery-ui/ui-icons_888888_256x240.png 0 → 100644

4.27 KB

vendor/assets/images/jquery-ui/ui-icons_cd0a0a_256x240.png 0 → 100644

4.27 KB

vendor/assets/javascripts/jquery-ui.js 0 → 100644
... ... @@ -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||"&#160;",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||"&#160;"));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&#8230;</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?"&#xa0;":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)?"&#xa0;":""));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)?"&#xa0;":"")+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 +;
... ...
vendor/assets/javascripts/jquery.cookie.js 0 → 100644
... ... @@ -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 +};
... ...
vendor/assets/javascripts/jquery.tagify.js 0 → 100644
... ... @@ -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
... ...
vendor/assets/javascripts/jquery.ui.selectmenu.js 0 → 100644
... ... @@ -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);
... ...
vendor/assets/stylesheets/jquery-ui/jquery-ui.css 0 → 100644
... ... @@ -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%; }
... ...
vendor/assets/stylesheets/jquery-ui/jquery.tagify.css 0 → 100644
... ... @@ -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; }
... ...