diff --git a/ckan/public/css/boilerplate.css b/ckan/public/css/boilerplate.css deleted file mode 100755 index 14aab14aa3d..00000000000 --- a/ckan/public/css/boilerplate.css +++ /dev/null @@ -1,111 +0,0 @@ -/* HTML5 ✰ Boilerplate */ - -html, body, div, span, object, iframe, -h1, h2, h3, h4, h5, h6, p, blockquote, pre, -abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, -small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, -fieldset, form, label, legend, -table, caption, tbody, tfoot, thead, tr, th, td, -article, aside, canvas, details, figcaption, figure, -footer, header, hgroup, menu, nav, section, summary, -time, mark, audio, video { - margin: 0; - padding: 0; - border: 0; - font-size: 100%; - font: inherit; - vertical-align: baseline; -} - -article, aside, details, figcaption, figure, -footer, header, hgroup, menu, nav, section { - display: block; -} - -blockquote, q { quotes: none; } -blockquote:before, blockquote:after, -q:before, q:after { content: ""; content: none; } -ins { background-color: #ff9; color: #000; text-decoration: none; } -mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; } -del { text-decoration: line-through; } -abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; } -table { border-collapse: collapse; border-spacing: 0; } -hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; } -input, select { vertical-align: middle; } - -body { font:13px/1.231 sans-serif; *font-size:small; } -select, input, textarea, button { font:99% sans-serif; } -pre, code, kbd, samp { font-family: monospace, sans-serif; } - -html { overflow-y: scroll; } -a:hover, a:active { outline: none; } -ul, ol { margin-left: 2em; } -ol { list-style-type: decimal; } -nav ul, nav li { margin: 0; list-style:none; list-style-image: none; } -small { font-size: 85%; } -strong, th { font-weight: bold; } -td { vertical-align: top; } -sub, sup { font-size: 75%; line-height: 0; position: relative; } -sup { top: -0.5em; } -sub { bottom: -0.25em; } - -pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; padding: 15px; } -textarea { overflow: auto; } -.ie6 legend, .ie7 legend { margin-left: -7px; } -input[type="radio"] { vertical-align: text-bottom; } -input[type="checkbox"] { vertical-align: bottom; } -.ie7 input[type="checkbox"] { vertical-align: baseline; } -.ie6 input { vertical-align: text-bottom; } -label, input[type="button"], input[type="submit"], input[type="image"], button { cursor: pointer; } -button, input, select, textarea { margin: 0; } -input:valid, textarea:valid { } -input:invalid, textarea:invalid { border-radius: 1px; -moz-box-shadow: 0px 0px 5px red; -webkit-box-shadow: 0px 0px 5px red; box-shadow: 0px 0px 5px red; } -.no-boxshadow input:invalid, .no-boxshadow textarea:invalid { background-color: #f0dddd; } - - -a:link { -webkit-tap-highlight-color: #FF5E99; } -button { width: auto; overflow: visible; } -.ie7 img { -ms-interpolation-mode: bicubic; } - -body, select, input, textarea { color: #444; } -h1, h2, h3, h4, h5, h6 { font-weight: bold; } -a, a:active, a:visited { color: #607890; } -a:hover { color: #036; } - -.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; } -.hidden { display: none; visibility: hidden; } -.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; } -.visuallyhidden.focusable:active, -.visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; } -.invisible { visibility: hidden; } -.clearfix:before, .clearfix:after { content: "\0020"; display: block; height: 0; overflow: hidden; } -.clearfix:after { clear: both; } -.clearfix { zoom: 1; } - - -@media all and (orientation:portrait) { -} - -@media all and (orientation:landscape) { -} - -@media screen and (max-device-width: 480px) { - /* html { -webkit-text-size-adjust:none; -ms-text-size-adjust:none; } */ -} - - -@media print { - * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; - -ms-filter: none !important; } - a, a:visited { color: #444 !important; text-decoration: underline; } - a[href]:after { content: " (" attr(href) ")"; } - abbr[title]:after { content: " (" attr(title) ")"; } - .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; } - pre, blockquote { border: 1px solid #999; page-break-inside: avoid; } - thead { display: table-header-group; } - tr, img { page-break-inside: avoid; } - @page { margin: 0.5cm; } - p, h2, h3 { orphans: 3; widows: 3; } - h2, h3{ page-break-after: avoid; } -} - diff --git a/ckan/public/css/bootstrap.min.css b/ckan/public/css/bootstrap.min.css deleted file mode 100644 index 1c75d0c07a4..00000000000 --- a/ckan/public/css/bootstrap.min.css +++ /dev/null @@ -1,9 +0,0 @@ -/*! - * Bootstrap v2.0.3 - * - * Copyright 2012 Twitter, Inc - * Licensed under the Apache License v2.0 - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Designed and built with all the love in the world @twitter by @mdo and @fat. - */article,aside,details,figcaption,figure,footer,header,hgroup,nav,section{display:block}audio,canvas,video{display:inline-block;*display:inline;*zoom:1}audio:not([controls]){display:none}html{font-size:100%;-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%}a:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}a:hover,a:active{outline:0}sub,sup{position:relative;font-size:75%;line-height:0;vertical-align:baseline}sup{top:-0.5em}sub{bottom:-0.25em}img{max-width:100%;vertical-align:middle;border:0;-ms-interpolation-mode:bicubic}button,input,select,textarea{margin:0;font-size:100%;vertical-align:middle}button,input{*overflow:visible;line-height:normal}button::-moz-focus-inner,input::-moz-focus-inner{padding:0;border:0}button,input[type="button"],input[type="reset"],input[type="submit"]{cursor:pointer;-webkit-appearance:button}input[type="search"]{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;-webkit-appearance:textfield}input[type="search"]::-webkit-search-decoration,input[type="search"]::-webkit-search-cancel-button{-webkit-appearance:none}textarea{overflow:auto;vertical-align:top}.clearfix{*zoom:1}.clearfix:before,.clearfix:after{display:table;content:""}.clearfix:after{clear:both}.hide-text{font:0/0 a;color:transparent;text-shadow:none;background-color:transparent;border:0}.input-block-level{display:block;width:100%;min-height:28px;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box}body{margin:0;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;line-height:18px;color:#333;background-color:#fff}a{color:#08c;text-decoration:none}a:hover{color:#005580;text-decoration:underline}.row{margin-left:-20px;*zoom:1}.row:before,.row:after{display:table;content:""}.row:after{clear:both}[class*="span"]{float:left;margin-left:20px}.container,.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px}.span12{width:940px}.span11{width:860px}.span10{width:780px}.span9{width:700px}.span8{width:620px}.span7{width:540px}.span6{width:460px}.span5{width:380px}.span4{width:300px}.span3{width:220px}.span2{width:140px}.span1{width:60px}.offset12{margin-left:980px}.offset11{margin-left:900px}.offset10{margin-left:820px}.offset9{margin-left:740px}.offset8{margin-left:660px}.offset7{margin-left:580px}.offset6{margin-left:500px}.offset5{margin-left:420px}.offset4{margin-left:340px}.offset3{margin-left:260px}.offset2{margin-left:180px}.offset1{margin-left:100px}.row-fluid{width:100%;*zoom:1}.row-fluid:before,.row-fluid:after{display:table;content:""}.row-fluid:after{clear:both}.row-fluid [class*="span"]{display:block;float:left;width:100%;min-height:28px;margin-left:2.127659574%;*margin-left:2.0744680846382977%;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box}.row-fluid [class*="span"]:first-child{margin-left:0}.row-fluid .span12{width:99.99999998999999%;*width:99.94680850063828%}.row-fluid .span11{width:91.489361693%;*width:91.4361702036383%}.row-fluid .span10{width:82.97872339599999%;*width:82.92553190663828%}.row-fluid .span9{width:74.468085099%;*width:74.4148936096383%}.row-fluid .span8{width:65.95744680199999%;*width:65.90425531263828%}.row-fluid .span7{width:57.446808505%;*width:57.3936170156383%}.row-fluid .span6{width:48.93617020799999%;*width:48.88297871863829%}.row-fluid .span5{width:40.425531911%;*width:40.3723404216383%}.row-fluid .span4{width:31.914893614%;*width:31.8617021246383%}.row-fluid .span3{width:23.404255317%;*width:23.3510638276383%}.row-fluid .span2{width:14.89361702%;*width:14.8404255306383%}.row-fluid .span1{width:6.382978723%;*width:6.329787233638298%}.container{margin-right:auto;margin-left:auto;*zoom:1}.container:before,.container:after{display:table;content:""}.container:after{clear:both}.container-fluid{padding-right:20px;padding-left:20px;*zoom:1}.container-fluid:before,.container-fluid:after{display:table;content:""}.container-fluid:after{clear:both}p{margin:0 0 9px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;line-height:18px}p small{font-size:11px;color:#999}.lead{margin-bottom:18px;font-size:20px;font-weight:200;line-height:27px}h1,h2,h3,h4,h5,h6{margin:0;font-family:inherit;font-weight:bold;color:inherit;text-rendering:optimizelegibility}h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{font-weight:normal;color:#999}h1{font-size:30px;line-height:36px}h1 small{font-size:18px}h2{font-size:24px;line-height:36px}h2 small{font-size:18px}h3{font-size:18px;line-height:27px}h3 small{font-size:14px}h4,h5,h6{line-height:18px}h4{font-size:14px}h4 small{font-size:12px}h5{font-size:12px}h6{font-size:11px;color:#999;text-transform:uppercase}.page-header{padding-bottom:17px;margin:18px 0;border-bottom:1px solid #eee}.page-header h1{line-height:1}ul,ol{padding:0;margin:0 0 9px 25px}ul ul,ul ol,ol ol,ol ul{margin-bottom:0}ul{list-style:disc}ol{list-style:decimal}li{line-height:18px}ul.unstyled,ol.unstyled{margin-left:0;list-style:none}dl{margin-bottom:18px}dt,dd{line-height:18px}dt{font-weight:bold;line-height:17px}dd{margin-left:9px}.dl-horizontal dt{float:left;width:120px;overflow:hidden;clear:left;text-align:right;text-overflow:ellipsis;white-space:nowrap}.dl-horizontal dd{margin-left:130px}hr{margin:18px 0;border:0;border-top:1px solid #eee;border-bottom:1px solid #fff}strong{font-weight:bold}em{font-style:italic}.muted{color:#999}abbr[title]{cursor:help;border-bottom:1px dotted #ddd}abbr.initialism{font-size:90%;text-transform:uppercase}blockquote{padding:0 0 0 15px;margin:0 0 18px;border-left:5px solid #eee}blockquote p{margin-bottom:0;font-size:16px;font-weight:300;line-height:22.5px}blockquote small{display:block;line-height:18px;color:#999}blockquote small:before{content:'\2014 \00A0'}blockquote.pull-right{float:right;padding-right:15px;padding-left:0;border-right:5px solid #eee;border-left:0}blockquote.pull-right p,blockquote.pull-right small{text-align:right}q:before,q:after,blockquote:before,blockquote:after{content:""}address{display:block;margin-bottom:18px;font-style:normal;line-height:18px}small{font-size:100%}cite{font-style:normal}code,pre{padding:0 3px 2px;font-family:Menlo,Monaco,Consolas,"Courier New",monospace;font-size:12px;color:#333;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}code{padding:2px 4px;color:#d14;background-color:#f7f7f9;border:1px solid #e1e1e8}pre{display:block;padding:8.5px;margin:0 0 9px;font-size:12.025px;line-height:18px;word-break:break-all;word-wrap:break-word;white-space:pre;white-space:pre-wrap;background-color:#f5f5f5;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.15);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}pre.prettyprint{margin-bottom:18px}pre code{padding:0;color:inherit;background-color:transparent;border:0}.pre-scrollable{max-height:340px;overflow-y:scroll}form{margin:0 0 18px}fieldset{padding:0;margin:0;border:0}legend{display:block;width:100%;padding:0;margin-bottom:27px;font-size:19.5px;line-height:36px;color:#333;border:0;border-bottom:1px solid #eee}legend small{font-size:13.5px;color:#999}label,input,button,select,textarea{font-size:13px;font-weight:normal;line-height:18px}input,button,select,textarea{font-family:"Helvetica Neue",Helvetica,Arial,sans-serif}label{display:block;margin-bottom:5px;color:#333}input,textarea,select,.uneditable-input{display:inline-block;width:210px;height:18px;padding:4px;margin-bottom:9px;font-size:13px;line-height:18px;color:#555;background-color:#fff;border:1px solid #ccc;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.uneditable-textarea{width:auto;height:auto}label input,label textarea,label select{display:block}input[type="image"],input[type="checkbox"],input[type="radio"]{width:auto;height:auto;padding:0;margin:3px 0;*margin-top:0;line-height:normal;cursor:pointer;background-color:transparent;border:0 \9;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}input[type="image"]{border:0}input[type="file"]{width:auto;padding:initial;line-height:initial;background-color:#fff;background-color:initial;border:initial;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}input[type="button"],input[type="reset"],input[type="submit"]{width:auto;height:auto}select,input[type="file"]{height:28px;*margin-top:4px;line-height:28px}input[type="file"]{line-height:18px \9}select{width:220px;background-color:#fff}select[multiple],select[size]{height:auto}input[type="image"]{-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}textarea{height:auto}input[type="hidden"]{display:none}.radio,.checkbox{min-height:18px;padding-left:18px}.radio input[type="radio"],.checkbox input[type="checkbox"]{float:left;margin-left:-18px}.controls>.radio:first-child,.controls>.checkbox:first-child{padding-top:5px}.radio.inline,.checkbox.inline{display:inline-block;padding-top:5px;margin-bottom:0;vertical-align:middle}.radio.inline+.radio.inline,.checkbox.inline+.checkbox.inline{margin-left:10px}input,textarea{-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075);-webkit-transition:border linear .2s,box-shadow linear .2s;-moz-transition:border linear .2s,box-shadow linear .2s;-ms-transition:border linear .2s,box-shadow linear .2s;-o-transition:border linear .2s,box-shadow linear .2s;transition:border linear .2s,box-shadow linear .2s}input:focus,textarea:focus{border-color:rgba(82,168,236,0.8);outline:0;outline:thin dotted \9;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6);box-shadow:inset 0 1px 1px rgba(0,0,0,0.075),0 0 8px rgba(82,168,236,0.6)}input[type="file"]:focus,input[type="radio"]:focus,input[type="checkbox"]:focus,select:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px;-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.input-mini{width:60px}.input-small{width:90px}.input-medium{width:150px}.input-large{width:210px}.input-xlarge{width:270px}.input-xxlarge{width:530px}input[class*="span"],select[class*="span"],textarea[class*="span"],.uneditable-input[class*="span"],.row-fluid input[class*="span"],.row-fluid select[class*="span"],.row-fluid textarea[class*="span"],.row-fluid .uneditable-input[class*="span"]{float:none;margin-left:0}input,textarea,.uneditable-input{margin-left:0}input.span12,textarea.span12,.uneditable-input.span12{width:930px}input.span11,textarea.span11,.uneditable-input.span11{width:850px}input.span10,textarea.span10,.uneditable-input.span10{width:770px}input.span9,textarea.span9,.uneditable-input.span9{width:690px}input.span8,textarea.span8,.uneditable-input.span8{width:610px}input.span7,textarea.span7,.uneditable-input.span7{width:530px}input.span6,textarea.span6,.uneditable-input.span6{width:450px}input.span5,textarea.span5,.uneditable-input.span5{width:370px}input.span4,textarea.span4,.uneditable-input.span4{width:290px}input.span3,textarea.span3,.uneditable-input.span3{width:210px}input.span2,textarea.span2,.uneditable-input.span2{width:130px}input.span1,textarea.span1,.uneditable-input.span1{width:50px}input[disabled],select[disabled],textarea[disabled],input[readonly],select[readonly],textarea[readonly]{cursor:not-allowed;background-color:#eee;border-color:#ddd}input[type="radio"][disabled],input[type="checkbox"][disabled],input[type="radio"][readonly],input[type="checkbox"][readonly]{background-color:transparent}.control-group.warning>label,.control-group.warning .help-block,.control-group.warning .help-inline{color:#c09853}.control-group.warning input,.control-group.warning select,.control-group.warning textarea{color:#c09853;border-color:#c09853}.control-group.warning input:focus,.control-group.warning select:focus,.control-group.warning textarea:focus{border-color:#a47e3c;-webkit-box-shadow:0 0 6px #dbc59e;-moz-box-shadow:0 0 6px #dbc59e;box-shadow:0 0 6px #dbc59e}.control-group.warning .input-prepend .add-on,.control-group.warning .input-append .add-on{color:#c09853;background-color:#fcf8e3;border-color:#c09853}.control-group.error>label,.control-group.error .help-block,.control-group.error .help-inline{color:#b94a48}.control-group.error input,.control-group.error select,.control-group.error textarea{color:#b94a48;border-color:#b94a48}.control-group.error input:focus,.control-group.error select:focus,.control-group.error textarea:focus{border-color:#953b39;-webkit-box-shadow:0 0 6px #d59392;-moz-box-shadow:0 0 6px #d59392;box-shadow:0 0 6px #d59392}.control-group.error .input-prepend .add-on,.control-group.error .input-append .add-on{color:#b94a48;background-color:#f2dede;border-color:#b94a48}.control-group.success>label,.control-group.success .help-block,.control-group.success .help-inline{color:#468847}.control-group.success input,.control-group.success select,.control-group.success textarea{color:#468847;border-color:#468847}.control-group.success input:focus,.control-group.success select:focus,.control-group.success textarea:focus{border-color:#356635;-webkit-box-shadow:0 0 6px #7aba7b;-moz-box-shadow:0 0 6px #7aba7b;box-shadow:0 0 6px #7aba7b}.control-group.success .input-prepend .add-on,.control-group.success .input-append .add-on{color:#468847;background-color:#dff0d8;border-color:#468847}input:focus:required:invalid,textarea:focus:required:invalid,select:focus:required:invalid{color:#b94a48;border-color:#ee5f5b}input:focus:required:invalid:focus,textarea:focus:required:invalid:focus,select:focus:required:invalid:focus{border-color:#e9322d;-webkit-box-shadow:0 0 6px #f8b9b7;-moz-box-shadow:0 0 6px #f8b9b7;box-shadow:0 0 6px #f8b9b7}.form-actions{padding:17px 20px 18px;margin-top:18px;margin-bottom:18px;background-color:#f5f5f5;border-top:1px solid #ddd;*zoom:1}.form-actions:before,.form-actions:after{display:table;content:""}.form-actions:after{clear:both}.uneditable-input{overflow:hidden;white-space:nowrap;cursor:not-allowed;background-color:#fff;border-color:#eee;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.025);box-shadow:inset 0 1px 2px rgba(0,0,0,0.025)}:-moz-placeholder{color:#999}::-webkit-input-placeholder{color:#999}.help-block,.help-inline{color:#555}.help-block{display:block;margin-bottom:9px}.help-inline{display:inline-block;*display:inline;padding-left:5px;vertical-align:middle;*zoom:1}.input-prepend,.input-append{margin-bottom:5px}.input-prepend input,.input-append input,.input-prepend select,.input-append select,.input-prepend .uneditable-input,.input-append .uneditable-input{position:relative;margin-bottom:0;*margin-left:0;vertical-align:middle;-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0}.input-prepend input:focus,.input-append input:focus,.input-prepend select:focus,.input-append select:focus,.input-prepend .uneditable-input:focus,.input-append .uneditable-input:focus{z-index:2}.input-prepend .uneditable-input,.input-append .uneditable-input{border-left-color:#ccc}.input-prepend .add-on,.input-append .add-on{display:inline-block;width:auto;height:18px;min-width:16px;padding:4px 5px;font-weight:normal;line-height:18px;text-align:center;text-shadow:0 1px 0 #fff;vertical-align:middle;background-color:#eee;border:1px solid #ccc}.input-prepend .add-on,.input-append .add-on,.input-prepend .btn,.input-append .btn{margin-left:-1px;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.input-prepend .active,.input-append .active{background-color:#a9dba9;border-color:#46a546}.input-prepend .add-on,.input-prepend .btn{margin-right:-1px}.input-prepend .add-on:first-child,.input-prepend .btn:first-child{-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px}.input-append input,.input-append select,.input-append .uneditable-input{-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px}.input-append .uneditable-input{border-right-color:#ccc;border-left-color:#eee}.input-append .add-on:last-child,.input-append .btn:last-child{-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0}.input-prepend.input-append input,.input-prepend.input-append select,.input-prepend.input-append .uneditable-input{-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.input-prepend.input-append .add-on:first-child,.input-prepend.input-append .btn:first-child{margin-right:-1px;-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px}.input-prepend.input-append .add-on:last-child,.input-prepend.input-append .btn:last-child{margin-left:-1px;-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0}.search-query{padding-right:14px;padding-right:4px \9;padding-left:14px;padding-left:4px \9;margin-bottom:0;-webkit-border-radius:14px;-moz-border-radius:14px;border-radius:14px}.form-search input,.form-inline input,.form-horizontal input,.form-search textarea,.form-inline textarea,.form-horizontal textarea,.form-search select,.form-inline select,.form-horizontal select,.form-search .help-inline,.form-inline .help-inline,.form-horizontal .help-inline,.form-search .uneditable-input,.form-inline .uneditable-input,.form-horizontal .uneditable-input,.form-search .input-prepend,.form-inline .input-prepend,.form-horizontal .input-prepend,.form-search .input-append,.form-inline .input-append,.form-horizontal .input-append{display:inline-block;*display:inline;margin-bottom:0;*zoom:1}.form-search .hide,.form-inline .hide,.form-horizontal .hide{display:none}.form-search label,.form-inline label{display:inline-block}.form-search .input-append,.form-inline .input-append,.form-search .input-prepend,.form-inline .input-prepend{margin-bottom:0}.form-search .radio,.form-search .checkbox,.form-inline .radio,.form-inline .checkbox{padding-left:0;margin-bottom:0;vertical-align:middle}.form-search .radio input[type="radio"],.form-search .checkbox input[type="checkbox"],.form-inline .radio input[type="radio"],.form-inline .checkbox input[type="checkbox"]{float:left;margin-right:3px;margin-left:0}.control-group{margin-bottom:9px}legend+.control-group{margin-top:18px;-webkit-margin-top-collapse:separate}.form-horizontal .control-group{margin-bottom:18px;*zoom:1}.form-horizontal .control-group:before,.form-horizontal .control-group:after{display:table;content:""}.form-horizontal .control-group:after{clear:both}.form-horizontal .control-label{float:left;width:140px;padding-top:5px;text-align:right}.form-horizontal .controls{*display:inline-block;*padding-left:20px;margin-left:160px;*margin-left:0}.form-horizontal .controls:first-child{*padding-left:160px}.form-horizontal .help-block{margin-top:9px;margin-bottom:0}.form-horizontal .form-actions{padding-left:160px}table{max-width:100%;background-color:transparent;border-collapse:collapse;border-spacing:0}.table{width:100%;margin-bottom:18px}.table th,.table td{padding:8px;line-height:18px;text-align:left;vertical-align:top;border-top:1px solid #ddd}.table th{font-weight:bold}.table thead th{vertical-align:bottom}.table caption+thead tr:first-child th,.table caption+thead tr:first-child td,.table colgroup+thead tr:first-child th,.table colgroup+thead tr:first-child td,.table thead:first-child tr:first-child th,.table thead:first-child tr:first-child td{border-top:0}.table tbody+tbody{border-top:2px solid #ddd}.table-condensed th,.table-condensed td{padding:4px 5px}.table-bordered{border:1px solid #ddd;border-collapse:separate;*border-collapse:collapsed;border-left:0;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.table-bordered th,.table-bordered td{border-left:1px solid #ddd}.table-bordered caption+thead tr:first-child th,.table-bordered caption+tbody tr:first-child th,.table-bordered caption+tbody tr:first-child td,.table-bordered colgroup+thead tr:first-child th,.table-bordered colgroup+tbody tr:first-child th,.table-bordered colgroup+tbody tr:first-child td,.table-bordered thead:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child th,.table-bordered tbody:first-child tr:first-child td{border-top:0}.table-bordered thead:first-child tr:first-child th:first-child,.table-bordered tbody:first-child tr:first-child td:first-child{-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-topleft:4px}.table-bordered thead:first-child tr:first-child th:last-child,.table-bordered tbody:first-child tr:first-child td:last-child{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-moz-border-radius-topright:4px}.table-bordered thead:last-child tr:last-child th:first-child,.table-bordered tbody:last-child tr:last-child td:first-child{-webkit-border-radius:0 0 0 4px;-moz-border-radius:0 0 0 4px;border-radius:0 0 0 4px;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-moz-border-radius-bottomleft:4px}.table-bordered thead:last-child tr:last-child th:last-child,.table-bordered tbody:last-child tr:last-child td:last-child{-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-bottomright:4px}.table-striped tbody tr:nth-child(odd) td,.table-striped tbody tr:nth-child(odd) th{background-color:#f9f9f9}.table tbody tr:hover td,.table tbody tr:hover th{background-color:#f5f5f5}table .span1{float:none;width:44px;margin-left:0}table .span2{float:none;width:124px;margin-left:0}table .span3{float:none;width:204px;margin-left:0}table .span4{float:none;width:284px;margin-left:0}table .span5{float:none;width:364px;margin-left:0}table .span6{float:none;width:444px;margin-left:0}table .span7{float:none;width:524px;margin-left:0}table .span8{float:none;width:604px;margin-left:0}table .span9{float:none;width:684px;margin-left:0}table .span10{float:none;width:764px;margin-left:0}table .span11{float:none;width:844px;margin-left:0}table .span12{float:none;width:924px;margin-left:0}table .span13{float:none;width:1004px;margin-left:0}table .span14{float:none;width:1084px;margin-left:0}table .span15{float:none;width:1164px;margin-left:0}table .span16{float:none;width:1244px;margin-left:0}table .span17{float:none;width:1324px;margin-left:0}table .span18{float:none;width:1404px;margin-left:0}table .span19{float:none;width:1484px;margin-left:0}table .span20{float:none;width:1564px;margin-left:0}table .span21{float:none;width:1644px;margin-left:0}table .span22{float:none;width:1724px;margin-left:0}table .span23{float:none;width:1804px;margin-left:0}table .span24{float:none;width:1884px;margin-left:0}[class^="icon-"],[class*=" icon-"]{display:inline-block;width:14px;height:14px;*margin-right:.3em;line-height:14px;vertical-align:text-top;background-image:url("../img/glyphicons-halflings.png");background-position:14px 14px;background-repeat:no-repeat}[class^="icon-"]:last-child,[class*=" icon-"]:last-child{*margin-left:0}.icon-white{background-image:url("../img/glyphicons-halflings-white.png")}.icon-glass{background-position:0 0}.icon-music{background-position:-24px 0}.icon-search{background-position:-48px 0}.icon-envelope{background-position:-72px 0}.icon-heart{background-position:-96px 0}.icon-star{background-position:-120px 0}.icon-star-empty{background-position:-144px 0}.icon-user{background-position:-168px 0}.icon-film{background-position:-192px 0}.icon-th-large{background-position:-216px 0}.icon-th{background-position:-240px 0}.icon-th-list{background-position:-264px 0}.icon-ok{background-position:-288px 0}.icon-remove{background-position:-312px 0}.icon-zoom-in{background-position:-336px 0}.icon-zoom-out{background-position:-360px 0}.icon-off{background-position:-384px 0}.icon-signal{background-position:-408px 0}.icon-cog{background-position:-432px 0}.icon-trash{background-position:-456px 0}.icon-home{background-position:0 -24px}.icon-file{background-position:-24px -24px}.icon-time{background-position:-48px -24px}.icon-road{background-position:-72px -24px}.icon-download-alt{background-position:-96px -24px}.icon-download{background-position:-120px -24px}.icon-upload{background-position:-144px -24px}.icon-inbox{background-position:-168px -24px}.icon-play-circle{background-position:-192px -24px}.icon-repeat{background-position:-216px -24px}.icon-refresh{background-position:-240px -24px}.icon-list-alt{background-position:-264px -24px}.icon-lock{background-position:-287px -24px}.icon-flag{background-position:-312px -24px}.icon-headphones{background-position:-336px -24px}.icon-volume-off{background-position:-360px -24px}.icon-volume-down{background-position:-384px -24px}.icon-volume-up{background-position:-408px -24px}.icon-qrcode{background-position:-432px -24px}.icon-barcode{background-position:-456px -24px}.icon-tag{background-position:0 -48px}.icon-tags{background-position:-25px -48px}.icon-book{background-position:-48px -48px}.icon-bookmark{background-position:-72px -48px}.icon-print{background-position:-96px -48px}.icon-camera{background-position:-120px -48px}.icon-font{background-position:-144px -48px}.icon-bold{background-position:-167px -48px}.icon-italic{background-position:-192px -48px}.icon-text-height{background-position:-216px -48px}.icon-text-width{background-position:-240px -48px}.icon-align-left{background-position:-264px -48px}.icon-align-center{background-position:-288px -48px}.icon-align-right{background-position:-312px -48px}.icon-align-justify{background-position:-336px -48px}.icon-list{background-position:-360px -48px}.icon-indent-left{background-position:-384px -48px}.icon-indent-right{background-position:-408px -48px}.icon-facetime-video{background-position:-432px -48px}.icon-picture{background-position:-456px -48px}.icon-pencil{background-position:0 -72px}.icon-map-marker{background-position:-24px -72px}.icon-adjust{background-position:-48px -72px}.icon-tint{background-position:-72px -72px}.icon-edit{background-position:-96px -72px}.icon-share{background-position:-120px -72px}.icon-check{background-position:-144px -72px}.icon-move{background-position:-168px -72px}.icon-step-backward{background-position:-192px -72px}.icon-fast-backward{background-position:-216px -72px}.icon-backward{background-position:-240px -72px}.icon-play{background-position:-264px -72px}.icon-pause{background-position:-288px -72px}.icon-stop{background-position:-312px -72px}.icon-forward{background-position:-336px -72px}.icon-fast-forward{background-position:-360px -72px}.icon-step-forward{background-position:-384px -72px}.icon-eject{background-position:-408px -72px}.icon-chevron-left{background-position:-432px -72px}.icon-chevron-right{background-position:-456px -72px}.icon-plus-sign{background-position:0 -96px}.icon-minus-sign{background-position:-24px -96px}.icon-remove-sign{background-position:-48px -96px}.icon-ok-sign{background-position:-72px -96px}.icon-question-sign{background-position:-96px -96px}.icon-info-sign{background-position:-120px -96px}.icon-screenshot{background-position:-144px -96px}.icon-remove-circle{background-position:-168px -96px}.icon-ok-circle{background-position:-192px -96px}.icon-ban-circle{background-position:-216px -96px}.icon-arrow-left{background-position:-240px -96px}.icon-arrow-right{background-position:-264px -96px}.icon-arrow-up{background-position:-289px -96px}.icon-arrow-down{background-position:-312px -96px}.icon-share-alt{background-position:-336px -96px}.icon-resize-full{background-position:-360px -96px}.icon-resize-small{background-position:-384px -96px}.icon-plus{background-position:-408px -96px}.icon-minus{background-position:-433px -96px}.icon-asterisk{background-position:-456px -96px}.icon-exclamation-sign{background-position:0 -120px}.icon-gift{background-position:-24px -120px}.icon-leaf{background-position:-48px -120px}.icon-fire{background-position:-72px -120px}.icon-eye-open{background-position:-96px -120px}.icon-eye-close{background-position:-120px -120px}.icon-warning-sign{background-position:-144px -120px}.icon-plane{background-position:-168px -120px}.icon-calendar{background-position:-192px -120px}.icon-random{background-position:-216px -120px}.icon-comment{background-position:-240px -120px}.icon-magnet{background-position:-264px -120px}.icon-chevron-up{background-position:-288px -120px}.icon-chevron-down{background-position:-313px -119px}.icon-retweet{background-position:-336px -120px}.icon-shopping-cart{background-position:-360px -120px}.icon-folder-close{background-position:-384px -120px}.icon-folder-open{background-position:-408px -120px}.icon-resize-vertical{background-position:-432px -119px}.icon-resize-horizontal{background-position:-456px -118px}.icon-hdd{background-position:0 -144px}.icon-bullhorn{background-position:-24px -144px}.icon-bell{background-position:-48px -144px}.icon-certificate{background-position:-72px -144px}.icon-thumbs-up{background-position:-96px -144px}.icon-thumbs-down{background-position:-120px -144px}.icon-hand-right{background-position:-144px -144px}.icon-hand-left{background-position:-168px -144px}.icon-hand-up{background-position:-192px -144px}.icon-hand-down{background-position:-216px -144px}.icon-circle-arrow-right{background-position:-240px -144px}.icon-circle-arrow-left{background-position:-264px -144px}.icon-circle-arrow-up{background-position:-288px -144px}.icon-circle-arrow-down{background-position:-312px -144px}.icon-globe{background-position:-336px -144px}.icon-wrench{background-position:-360px -144px}.icon-tasks{background-position:-384px -144px}.icon-filter{background-position:-408px -144px}.icon-briefcase{background-position:-432px -144px}.icon-fullscreen{background-position:-456px -144px}.dropup,.dropdown{position:relative}.dropdown-toggle{*margin-bottom:-3px}.dropdown-toggle:active,.open .dropdown-toggle{outline:0}.caret{display:inline-block;width:0;height:0;vertical-align:top;border-top:4px solid #000;border-right:4px solid transparent;border-left:4px solid transparent;content:"";opacity:.3;filter:alpha(opacity=30)}.dropdown .caret{margin-top:8px;margin-left:2px}.dropdown:hover .caret,.open .caret{opacity:1;filter:alpha(opacity=100)}.dropdown-menu{position:absolute;top:100%;left:0;z-index:1000;display:none;float:left;min-width:160px;padding:4px 0;margin:1px 0 0;list-style:none;background-color:#fff;border:1px solid #ccc;border:1px solid rgba(0,0,0,0.2);*border-right-width:2px;*border-bottom-width:2px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,0.2);-moz-box-shadow:0 5px 10px rgba(0,0,0,0.2);box-shadow:0 5px 10px rgba(0,0,0,0.2);-webkit-background-clip:padding-box;-moz-background-clip:padding;background-clip:padding-box}.dropdown-menu.pull-right{right:0;left:auto}.dropdown-menu .divider{*width:100%;height:1px;margin:8px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.dropdown-menu a{display:block;padding:3px 15px;clear:both;font-weight:normal;line-height:18px;color:#333;white-space:nowrap}.dropdown-menu li>a:hover,.dropdown-menu .active>a,.dropdown-menu .active>a:hover{color:#fff;text-decoration:none;background-color:#08c}.open{*z-index:1000}.open .dropdown-menu{display:block}.pull-right .dropdown-menu{right:0;left:auto}.dropup .caret,.navbar-fixed-bottom .dropdown .caret{border-top:0;border-bottom:4px solid #000;content:"\2191"}.dropup .dropdown-menu,.navbar-fixed-bottom .dropdown .dropdown-menu{top:auto;bottom:100%;margin-bottom:1px}.typeahead{margin-top:2px;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.well{min-height:20px;padding:19px;margin-bottom:20px;background-color:#f5f5f5;border:1px solid #eee;border:1px solid rgba(0,0,0,0.05);-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 1px rgba(0,0,0,0.05);box-shadow:inset 0 1px 1px rgba(0,0,0,0.05)}.well blockquote{border-color:#ddd;border-color:rgba(0,0,0,0.15)}.well-large{padding:24px;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.well-small{padding:9px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.fade{opacity:0;filter:alpha(opacity=0);-webkit-transition:opacity .15s linear;-moz-transition:opacity .15s linear;-ms-transition:opacity .15s linear;-o-transition:opacity .15s linear;transition:opacity .15s linear}.fade.in{opacity:1;filter:alpha(opacity=100)}.collapse{position:relative;height:0;overflow:hidden;-webkit-transition:height .35s ease;-moz-transition:height .35s ease;-ms-transition:height .35s ease;-o-transition:height .35s ease;transition:height .35s ease}.collapse.in{height:auto}.close{float:right;font-size:20px;font-weight:bold;line-height:18px;color:#000;text-shadow:0 1px 0 #fff;opacity:.2;filter:alpha(opacity=20)}.close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;filter:alpha(opacity=40)}button.close{padding:0;cursor:pointer;background:transparent;border:0;-webkit-appearance:none}.btn{display:inline-block;*display:inline;padding:4px 10px 4px;margin-bottom:0;*margin-left:.3em;font-size:13px;line-height:18px;*line-height:20px;color:#333;text-align:center;text-shadow:0 1px 1px rgba(255,255,255,0.75);vertical-align:middle;cursor:pointer;background-color:#f5f5f5;*background-color:#e6e6e6;background-image:-ms-linear-gradient(top,#fff,#e6e6e6);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#e6e6e6));background-image:-webkit-linear-gradient(top,#fff,#e6e6e6);background-image:-o-linear-gradient(top,#fff,#e6e6e6);background-image:linear-gradient(top,#fff,#e6e6e6);background-image:-moz-linear-gradient(top,#fff,#e6e6e6);background-repeat:repeat-x;border:1px solid #ccc;*border:0;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);border-color:#e6e6e6 #e6e6e6 #bfbfbf;border-bottom-color:#b3b3b3;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffffff',endColorstr='#e6e6e6',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false);*zoom:1;-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.btn:hover,.btn:active,.btn.active,.btn.disabled,.btn[disabled]{background-color:#e6e6e6;*background-color:#d9d9d9}.btn:active,.btn.active{background-color:#ccc \9}.btn:first-child{*margin-left:0}.btn:hover{color:#333;text-decoration:none;background-color:#e6e6e6;*background-color:#d9d9d9;background-position:0 -15px;-webkit-transition:background-position .1s linear;-moz-transition:background-position .1s linear;-ms-transition:background-position .1s linear;-o-transition:background-position .1s linear;transition:background-position .1s linear}.btn:focus{outline:thin dotted #333;outline:5px auto -webkit-focus-ring-color;outline-offset:-2px}.btn.active,.btn:active{background-color:#e6e6e6;background-color:#d9d9d9 \9;background-image:none;outline:0;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.btn.disabled,.btn[disabled]{cursor:default;background-color:#e6e6e6;background-image:none;opacity:.65;filter:alpha(opacity=65);-webkit-box-shadow:none;-moz-box-shadow:none;box-shadow:none}.btn-large{padding:9px 14px;font-size:15px;line-height:normal;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.btn-large [class^="icon-"]{margin-top:1px}.btn-small{padding:5px 9px;font-size:11px;line-height:16px}.btn-small [class^="icon-"]{margin-top:-1px}.btn-mini{padding:2px 6px;font-size:11px;line-height:14px}.btn-primary,.btn-primary:hover,.btn-warning,.btn-warning:hover,.btn-danger,.btn-danger:hover,.btn-success,.btn-success:hover,.btn-info,.btn-info:hover,.btn-inverse,.btn-inverse:hover{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25)}.btn-primary.active,.btn-warning.active,.btn-danger.active,.btn-success.active,.btn-info.active,.btn-inverse.active{color:rgba(255,255,255,0.75)}.btn{border-color:#ccc;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25)}.btn-primary{background-color:#0074cc;*background-color:#05c;background-image:-ms-linear-gradient(top,#08c,#05c);background-image:-webkit-gradient(linear,0 0,0 100%,from(#08c),to(#05c));background-image:-webkit-linear-gradient(top,#08c,#05c);background-image:-o-linear-gradient(top,#08c,#05c);background-image:-moz-linear-gradient(top,#08c,#05c);background-image:linear-gradient(top,#08c,#05c);background-repeat:repeat-x;border-color:#05c #05c #003580;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#0088cc',endColorstr='#0055cc',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-primary:hover,.btn-primary:active,.btn-primary.active,.btn-primary.disabled,.btn-primary[disabled]{background-color:#05c;*background-color:#004ab3}.btn-primary:active,.btn-primary.active{background-color:#004099 \9}.btn-warning{background-color:#faa732;*background-color:#f89406;background-image:-ms-linear-gradient(top,#fbb450,#f89406);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(top,#fbb450,#f89406);background-repeat:repeat-x;border-color:#f89406 #f89406 #ad6704;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fbb450',endColorstr='#f89406',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-warning:hover,.btn-warning:active,.btn-warning.active,.btn-warning.disabled,.btn-warning[disabled]{background-color:#f89406;*background-color:#df8505}.btn-warning:active,.btn-warning.active{background-color:#c67605 \9}.btn-danger{background-color:#da4f49;*background-color:#bd362f;background-image:-ms-linear-gradient(top,#ee5f5b,#bd362f);background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#bd362f));background-image:-webkit-linear-gradient(top,#ee5f5b,#bd362f);background-image:-o-linear-gradient(top,#ee5f5b,#bd362f);background-image:-moz-linear-gradient(top,#ee5f5b,#bd362f);background-image:linear-gradient(top,#ee5f5b,#bd362f);background-repeat:repeat-x;border-color:#bd362f #bd362f #802420;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ee5f5b',endColorstr='#bd362f',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-danger:hover,.btn-danger:active,.btn-danger.active,.btn-danger.disabled,.btn-danger[disabled]{background-color:#bd362f;*background-color:#a9302a}.btn-danger:active,.btn-danger.active{background-color:#942a25 \9}.btn-success{background-color:#5bb75b;*background-color:#51a351;background-image:-ms-linear-gradient(top,#62c462,#51a351);background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#51a351));background-image:-webkit-linear-gradient(top,#62c462,#51a351);background-image:-o-linear-gradient(top,#62c462,#51a351);background-image:-moz-linear-gradient(top,#62c462,#51a351);background-image:linear-gradient(top,#62c462,#51a351);background-repeat:repeat-x;border-color:#51a351 #51a351 #387038;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#62c462',endColorstr='#51a351',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-success:hover,.btn-success:active,.btn-success.active,.btn-success.disabled,.btn-success[disabled]{background-color:#51a351;*background-color:#499249}.btn-success:active,.btn-success.active{background-color:#408140 \9}.btn-info{background-color:#49afcd;*background-color:#2f96b4;background-image:-ms-linear-gradient(top,#5bc0de,#2f96b4);background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#2f96b4));background-image:-webkit-linear-gradient(top,#5bc0de,#2f96b4);background-image:-o-linear-gradient(top,#5bc0de,#2f96b4);background-image:-moz-linear-gradient(top,#5bc0de,#2f96b4);background-image:linear-gradient(top,#5bc0de,#2f96b4);background-repeat:repeat-x;border-color:#2f96b4 #2f96b4 #1f6377;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#5bc0de',endColorstr='#2f96b4',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-info:hover,.btn-info:active,.btn-info.active,.btn-info.disabled,.btn-info[disabled]{background-color:#2f96b4;*background-color:#2a85a0}.btn-info:active,.btn-info.active{background-color:#24748c \9}.btn-inverse{background-color:#414141;*background-color:#222;background-image:-ms-linear-gradient(top,#555,#222);background-image:-webkit-gradient(linear,0 0,0 100%,from(#555),to(#222));background-image:-webkit-linear-gradient(top,#555,#222);background-image:-o-linear-gradient(top,#555,#222);background-image:-moz-linear-gradient(top,#555,#222);background-image:linear-gradient(top,#555,#222);background-repeat:repeat-x;border-color:#222 #222 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#555555',endColorstr='#222222',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false)}.btn-inverse:hover,.btn-inverse:active,.btn-inverse.active,.btn-inverse.disabled,.btn-inverse[disabled]{background-color:#222;*background-color:#151515}.btn-inverse:active,.btn-inverse.active{background-color:#080808 \9}button.btn,input[type="submit"].btn{*padding-top:2px;*padding-bottom:2px}button.btn::-moz-focus-inner,input[type="submit"].btn::-moz-focus-inner{padding:0;border:0}button.btn.btn-large,input[type="submit"].btn.btn-large{*padding-top:7px;*padding-bottom:7px}button.btn.btn-small,input[type="submit"].btn.btn-small{*padding-top:3px;*padding-bottom:3px}button.btn.btn-mini,input[type="submit"].btn.btn-mini{*padding-top:1px;*padding-bottom:1px}.btn-group{position:relative;*margin-left:.3em;*zoom:1}.btn-group:before,.btn-group:after{display:table;content:""}.btn-group:after{clear:both}.btn-group:first-child{*margin-left:0}.btn-group+.btn-group{margin-left:5px}.btn-toolbar{margin-top:9px;margin-bottom:9px}.btn-toolbar .btn-group{display:inline-block;*display:inline;*zoom:1}.btn-group>.btn{position:relative;float:left;margin-left:-1px;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.btn-group>.btn:first-child{margin-left:0;-webkit-border-bottom-left-radius:4px;border-bottom-left-radius:4px;-webkit-border-top-left-radius:4px;border-top-left-radius:4px;-moz-border-radius-bottomleft:4px;-moz-border-radius-topleft:4px}.btn-group>.btn:last-child,.btn-group>.dropdown-toggle{-webkit-border-top-right-radius:4px;border-top-right-radius:4px;-webkit-border-bottom-right-radius:4px;border-bottom-right-radius:4px;-moz-border-radius-topright:4px;-moz-border-radius-bottomright:4px}.btn-group>.btn.large:first-child{margin-left:0;-webkit-border-bottom-left-radius:6px;border-bottom-left-radius:6px;-webkit-border-top-left-radius:6px;border-top-left-radius:6px;-moz-border-radius-bottomleft:6px;-moz-border-radius-topleft:6px}.btn-group>.btn.large:last-child,.btn-group>.large.dropdown-toggle{-webkit-border-top-right-radius:6px;border-top-right-radius:6px;-webkit-border-bottom-right-radius:6px;border-bottom-right-radius:6px;-moz-border-radius-topright:6px;-moz-border-radius-bottomright:6px}.btn-group>.btn:hover,.btn-group>.btn:focus,.btn-group>.btn:active,.btn-group>.btn.active{z-index:2}.btn-group .dropdown-toggle:active,.btn-group.open .dropdown-toggle{outline:0}.btn-group>.dropdown-toggle{*padding-top:4px;padding-right:8px;*padding-bottom:4px;padding-left:8px;-webkit-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 1px 0 0 rgba(255,255,255,0.125),inset 0 1px 0 rgba(255,255,255,0.2),0 1px 2px rgba(0,0,0,0.05)}.btn-group>.btn-mini.dropdown-toggle{padding-right:5px;padding-left:5px}.btn-group>.btn-small.dropdown-toggle{*padding-top:4px;*padding-bottom:4px}.btn-group>.btn-large.dropdown-toggle{padding-right:12px;padding-left:12px}.btn-group.open .dropdown-toggle{background-image:none;-webkit-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05);box-shadow:inset 0 2px 4px rgba(0,0,0,0.15),0 1px 2px rgba(0,0,0,0.05)}.btn-group.open .btn.dropdown-toggle{background-color:#e6e6e6}.btn-group.open .btn-primary.dropdown-toggle{background-color:#05c}.btn-group.open .btn-warning.dropdown-toggle{background-color:#f89406}.btn-group.open .btn-danger.dropdown-toggle{background-color:#bd362f}.btn-group.open .btn-success.dropdown-toggle{background-color:#51a351}.btn-group.open .btn-info.dropdown-toggle{background-color:#2f96b4}.btn-group.open .btn-inverse.dropdown-toggle{background-color:#222}.btn .caret{margin-top:7px;margin-left:0}.btn:hover .caret,.open.btn-group .caret{opacity:1;filter:alpha(opacity=100)}.btn-mini .caret{margin-top:5px}.btn-small .caret{margin-top:6px}.btn-large .caret{margin-top:6px;border-top-width:5px;border-right-width:5px;border-left-width:5px}.dropup .btn-large .caret{border-top:0;border-bottom:5px solid #000}.btn-primary .caret,.btn-warning .caret,.btn-danger .caret,.btn-info .caret,.btn-success .caret,.btn-inverse .caret{border-top-color:#fff;border-bottom-color:#fff;opacity:.75;filter:alpha(opacity=75)}.alert{padding:8px 35px 8px 14px;margin-bottom:18px;color:#c09853;text-shadow:0 1px 0 rgba(255,255,255,0.5);background-color:#fcf8e3;border:1px solid #fbeed5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.alert-heading{color:inherit}.alert .close{position:relative;top:-2px;right:-21px;line-height:18px}.alert-success{color:#468847;background-color:#dff0d8;border-color:#d6e9c6}.alert-danger,.alert-error{color:#b94a48;background-color:#f2dede;border-color:#eed3d7}.alert-info{color:#3a87ad;background-color:#d9edf7;border-color:#bce8f1}.alert-block{padding-top:14px;padding-bottom:14px}.alert-block>p,.alert-block>ul{margin-bottom:0}.alert-block p+p{margin-top:5px}.nav{margin-bottom:18px;margin-left:0;list-style:none}.nav>li>a{display:block}.nav>li>a:hover{text-decoration:none;background-color:#eee}.nav>.pull-right{float:right}.nav .nav-header{display:block;padding:3px 15px;font-size:11px;font-weight:bold;line-height:18px;color:#999;text-shadow:0 1px 0 rgba(255,255,255,0.5);text-transform:uppercase}.nav li+.nav-header{margin-top:9px}.nav-list{padding-right:15px;padding-left:15px;margin-bottom:0}.nav-list>li>a,.nav-list .nav-header{margin-right:-15px;margin-left:-15px;text-shadow:0 1px 0 rgba(255,255,255,0.5)}.nav-list>li>a{padding:3px 15px}.nav-list>.active>a,.nav-list>.active>a:hover{color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.2);background-color:#08c}.nav-list [class^="icon-"]{margin-right:2px}.nav-list .divider{*width:100%;height:1px;margin:8px 1px;*margin:-5px 0 5px;overflow:hidden;background-color:#e5e5e5;border-bottom:1px solid #fff}.nav-tabs,.nav-pills{*zoom:1}.nav-tabs:before,.nav-pills:before,.nav-tabs:after,.nav-pills:after{display:table;content:""}.nav-tabs:after,.nav-pills:after{clear:both}.nav-tabs>li,.nav-pills>li{float:left}.nav-tabs>li>a,.nav-pills>li>a{padding-right:12px;padding-left:12px;margin-right:2px;line-height:14px}.nav-tabs{border-bottom:1px solid #ddd}.nav-tabs>li{margin-bottom:-1px}.nav-tabs>li>a{padding-top:8px;padding-bottom:8px;line-height:18px;border:1px solid transparent;-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.nav-tabs>li>a:hover{border-color:#eee #eee #ddd}.nav-tabs>.active>a,.nav-tabs>.active>a:hover{color:#555;cursor:default;background-color:#fff;border:1px solid #ddd;border-bottom-color:transparent}.nav-pills>li>a{padding-top:8px;padding-bottom:8px;margin-top:2px;margin-bottom:2px;-webkit-border-radius:5px;-moz-border-radius:5px;border-radius:5px}.nav-pills>.active>a,.nav-pills>.active>a:hover{color:#fff;background-color:#08c}.nav-stacked>li{float:none}.nav-stacked>li>a{margin-right:0}.nav-tabs.nav-stacked{border-bottom:0}.nav-tabs.nav-stacked>li>a{border:1px solid #ddd;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.nav-tabs.nav-stacked>li:first-child>a{-webkit-border-radius:4px 4px 0 0;-moz-border-radius:4px 4px 0 0;border-radius:4px 4px 0 0}.nav-tabs.nav-stacked>li:last-child>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.nav-tabs.nav-stacked>li>a:hover{z-index:2;border-color:#ddd}.nav-pills.nav-stacked>li>a{margin-bottom:3px}.nav-pills.nav-stacked>li:last-child>a{margin-bottom:1px}.nav-tabs .dropdown-menu{-webkit-border-radius:0 0 5px 5px;-moz-border-radius:0 0 5px 5px;border-radius:0 0 5px 5px}.nav-pills .dropdown-menu{-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.nav-tabs .dropdown-toggle .caret,.nav-pills .dropdown-toggle .caret{margin-top:6px;border-top-color:#08c;border-bottom-color:#08c}.nav-tabs .dropdown-toggle:hover .caret,.nav-pills .dropdown-toggle:hover .caret{border-top-color:#005580;border-bottom-color:#005580}.nav-tabs .active .dropdown-toggle .caret,.nav-pills .active .dropdown-toggle .caret{border-top-color:#333;border-bottom-color:#333}.nav>.dropdown.active>a:hover{color:#000;cursor:pointer}.nav-tabs .open .dropdown-toggle,.nav-pills .open .dropdown-toggle,.nav>li.dropdown.open.active>a:hover{color:#fff;background-color:#999;border-color:#999}.nav li.dropdown.open .caret,.nav li.dropdown.open.active .caret,.nav li.dropdown.open a:hover .caret{border-top-color:#fff;border-bottom-color:#fff;opacity:1;filter:alpha(opacity=100)}.tabs-stacked .open>a:hover{border-color:#999}.tabbable{*zoom:1}.tabbable:before,.tabbable:after{display:table;content:""}.tabbable:after{clear:both}.tab-content{overflow:auto}.tabs-below>.nav-tabs,.tabs-right>.nav-tabs,.tabs-left>.nav-tabs{border-bottom:0}.tab-content>.tab-pane,.pill-content>.pill-pane{display:none}.tab-content>.active,.pill-content>.active{display:block}.tabs-below>.nav-tabs{border-top:1px solid #ddd}.tabs-below>.nav-tabs>li{margin-top:-1px;margin-bottom:0}.tabs-below>.nav-tabs>li>a{-webkit-border-radius:0 0 4px 4px;-moz-border-radius:0 0 4px 4px;border-radius:0 0 4px 4px}.tabs-below>.nav-tabs>li>a:hover{border-top-color:#ddd;border-bottom-color:transparent}.tabs-below>.nav-tabs>.active>a,.tabs-below>.nav-tabs>.active>a:hover{border-color:transparent #ddd #ddd #ddd}.tabs-left>.nav-tabs>li,.tabs-right>.nav-tabs>li{float:none}.tabs-left>.nav-tabs>li>a,.tabs-right>.nav-tabs>li>a{min-width:74px;margin-right:0;margin-bottom:3px}.tabs-left>.nav-tabs{float:left;margin-right:19px;border-right:1px solid #ddd}.tabs-left>.nav-tabs>li>a{margin-right:-1px;-webkit-border-radius:4px 0 0 4px;-moz-border-radius:4px 0 0 4px;border-radius:4px 0 0 4px}.tabs-left>.nav-tabs>li>a:hover{border-color:#eee #ddd #eee #eee}.tabs-left>.nav-tabs .active>a,.tabs-left>.nav-tabs .active>a:hover{border-color:#ddd transparent #ddd #ddd;*border-right-color:#fff}.tabs-right>.nav-tabs{float:right;margin-left:19px;border-left:1px solid #ddd}.tabs-right>.nav-tabs>li>a{margin-left:-1px;-webkit-border-radius:0 4px 4px 0;-moz-border-radius:0 4px 4px 0;border-radius:0 4px 4px 0}.tabs-right>.nav-tabs>li>a:hover{border-color:#eee #eee #eee #ddd}.tabs-right>.nav-tabs .active>a,.tabs-right>.nav-tabs .active>a:hover{border-color:#ddd #ddd #ddd transparent;*border-left-color:#fff}.navbar{*position:relative;*z-index:2;margin-bottom:18px;overflow:visible}.navbar-inner{min-height:40px;padding-right:20px;padding-left:20px;background-color:#2c2c2c;background-image:-moz-linear-gradient(top,#333,#222);background-image:-ms-linear-gradient(top,#333,#222);background-image:-webkit-gradient(linear,0 0,0 100%,from(#333),to(#222));background-image:-webkit-linear-gradient(top,#333,#222);background-image:-o-linear-gradient(top,#333,#222);background-image:linear-gradient(top,#333,#222);background-repeat:repeat-x;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#333333',endColorstr='#222222',GradientType=0);-webkit-box-shadow:0 1px 3px rgba(0,0,0,0.25),inset 0 -1px 0 rgba(0,0,0,0.1);-moz-box-shadow:0 1px 3px rgba(0,0,0,0.25),inset 0 -1px 0 rgba(0,0,0,0.1);box-shadow:0 1px 3px rgba(0,0,0,0.25),inset 0 -1px 0 rgba(0,0,0,0.1)}.navbar .container{width:auto}.nav-collapse.collapse{height:auto}.navbar{color:#999}.navbar .brand:hover{text-decoration:none}.navbar .brand{display:block;float:left;padding:8px 20px 12px;margin-left:-20px;font-size:20px;font-weight:200;line-height:1;color:#999}.navbar .navbar-text{margin-bottom:0;line-height:40px}.navbar .navbar-link{color:#999}.navbar .navbar-link:hover{color:#fff}.navbar .btn,.navbar .btn-group{margin-top:5px}.navbar .btn-group .btn{margin:0}.navbar-form{margin-bottom:0;*zoom:1}.navbar-form:before,.navbar-form:after{display:table;content:""}.navbar-form:after{clear:both}.navbar-form input,.navbar-form select,.navbar-form .radio,.navbar-form .checkbox{margin-top:5px}.navbar-form input,.navbar-form select{display:inline-block;margin-bottom:0}.navbar-form input[type="image"],.navbar-form input[type="checkbox"],.navbar-form input[type="radio"]{margin-top:3px}.navbar-form .input-append,.navbar-form .input-prepend{margin-top:6px;white-space:nowrap}.navbar-form .input-append input,.navbar-form .input-prepend input{margin-top:0}.navbar-search{position:relative;float:left;margin-top:6px;margin-bottom:0}.navbar-search .search-query{padding:4px 9px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:13px;font-weight:normal;line-height:1;color:#fff;background-color:#626262;border:1px solid #151515;-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1),0 1px 0 rgba(255,255,255,0.15);-webkit-transition:none;-moz-transition:none;-ms-transition:none;-o-transition:none;transition:none}.navbar-search .search-query:-moz-placeholder{color:#ccc}.navbar-search .search-query::-webkit-input-placeholder{color:#ccc}.navbar-search .search-query:focus,.navbar-search .search-query.focused{padding:5px 10px;color:#333;text-shadow:0 1px 0 #fff;background-color:#fff;border:0;outline:0;-webkit-box-shadow:0 0 3px rgba(0,0,0,0.15);-moz-box-shadow:0 0 3px rgba(0,0,0,0.15);box-shadow:0 0 3px rgba(0,0,0,0.15)}.navbar-fixed-top,.navbar-fixed-bottom{position:fixed;right:0;left:0;z-index:1030;margin-bottom:0}.navbar-fixed-top .navbar-inner,.navbar-fixed-bottom .navbar-inner{padding-right:0;padding-left:0;-webkit-border-radius:0;-moz-border-radius:0;border-radius:0}.navbar-fixed-top .container,.navbar-fixed-bottom .container{width:940px}.navbar-fixed-top{top:0}.navbar-fixed-bottom{bottom:0}.navbar .nav{position:relative;left:0;display:block;float:left;margin:0 10px 0 0}.navbar .nav.pull-right{float:right}.navbar .nav>li{display:block;float:left}.navbar .nav>li>a{float:none;padding:9px 10px 11px;line-height:19px;color:#999;text-decoration:none;text-shadow:0 -1px 0 rgba(0,0,0,0.25)}.navbar .btn{display:inline-block;padding:4px 10px 4px;margin:5px 5px 6px;line-height:18px}.navbar .btn-group{padding:5px 5px 6px;margin:0}.navbar .nav>li>a:hover{color:#fff;text-decoration:none;background-color:transparent}.navbar .nav .active>a,.navbar .nav .active>a:hover{color:#fff;text-decoration:none;background-color:#222}.navbar .divider-vertical{width:1px;height:40px;margin:0 9px;overflow:hidden;background-color:#222;border-right:1px solid #333}.navbar .nav.pull-right{margin-right:0;margin-left:10px}.navbar .btn-navbar{display:none;float:right;padding:7px 10px;margin-right:5px;margin-left:5px;background-color:#2c2c2c;*background-color:#222;background-image:-ms-linear-gradient(top,#333,#222);background-image:-webkit-gradient(linear,0 0,0 100%,from(#333),to(#222));background-image:-webkit-linear-gradient(top,#333,#222);background-image:-o-linear-gradient(top,#333,#222);background-image:linear-gradient(top,#333,#222);background-image:-moz-linear-gradient(top,#333,#222);background-repeat:repeat-x;border-color:#222 #222 #000;border-color:rgba(0,0,0,0.1) rgba(0,0,0,0.1) rgba(0,0,0,0.25);filter:progid:dximagetransform.microsoft.gradient(startColorstr='#333333',endColorstr='#222222',GradientType=0);filter:progid:dximagetransform.microsoft.gradient(enabled=false);-webkit-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);-moz-box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075);box-shadow:inset 0 1px 0 rgba(255,255,255,0.1),0 1px 0 rgba(255,255,255,0.075)}.navbar .btn-navbar:hover,.navbar .btn-navbar:active,.navbar .btn-navbar.active,.navbar .btn-navbar.disabled,.navbar .btn-navbar[disabled]{background-color:#222;*background-color:#151515}.navbar .btn-navbar:active,.navbar .btn-navbar.active{background-color:#080808 \9}.navbar .btn-navbar .icon-bar{display:block;width:18px;height:2px;background-color:#f5f5f5;-webkit-border-radius:1px;-moz-border-radius:1px;border-radius:1px;-webkit-box-shadow:0 1px 0 rgba(0,0,0,0.25);-moz-box-shadow:0 1px 0 rgba(0,0,0,0.25);box-shadow:0 1px 0 rgba(0,0,0,0.25)}.btn-navbar .icon-bar+.icon-bar{margin-top:3px}.navbar .dropdown-menu:before{position:absolute;top:-7px;left:9px;display:inline-block;border-right:7px solid transparent;border-bottom:7px solid #ccc;border-left:7px solid transparent;border-bottom-color:rgba(0,0,0,0.2);content:''}.navbar .dropdown-menu:after{position:absolute;top:-6px;left:10px;display:inline-block;border-right:6px solid transparent;border-bottom:6px solid #fff;border-left:6px solid transparent;content:''}.navbar-fixed-bottom .dropdown-menu:before{top:auto;bottom:-7px;border-top:7px solid #ccc;border-bottom:0;border-top-color:rgba(0,0,0,0.2)}.navbar-fixed-bottom .dropdown-menu:after{top:auto;bottom:-6px;border-top:6px solid #fff;border-bottom:0}.navbar .nav li.dropdown .dropdown-toggle .caret,.navbar .nav li.dropdown.open .caret{border-top-color:#fff;border-bottom-color:#fff}.navbar .nav li.dropdown.active .caret{opacity:1;filter:alpha(opacity=100)}.navbar .nav li.dropdown.open>.dropdown-toggle,.navbar .nav li.dropdown.active>.dropdown-toggle,.navbar .nav li.dropdown.open.active>.dropdown-toggle{background-color:transparent}.navbar .nav li.dropdown.active>.dropdown-toggle:hover{color:#fff}.navbar .pull-right .dropdown-menu,.navbar .dropdown-menu.pull-right{right:0;left:auto}.navbar .pull-right .dropdown-menu:before,.navbar .dropdown-menu.pull-right:before{right:12px;left:auto}.navbar .pull-right .dropdown-menu:after,.navbar .dropdown-menu.pull-right:after{right:13px;left:auto}.breadcrumb{padding:7px 14px;margin:0 0 18px;list-style:none;background-color:#fbfbfb;background-image:-moz-linear-gradient(top,#fff,#f5f5f5);background-image:-ms-linear-gradient(top,#fff,#f5f5f5);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fff),to(#f5f5f5));background-image:-webkit-linear-gradient(top,#fff,#f5f5f5);background-image:-o-linear-gradient(top,#fff,#f5f5f5);background-image:linear-gradient(top,#fff,#f5f5f5);background-repeat:repeat-x;border:1px solid #ddd;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ffffff',endColorstr='#f5f5f5',GradientType=0);-webkit-box-shadow:inset 0 1px 0 #fff;-moz-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff}.breadcrumb li{display:inline-block;*display:inline;text-shadow:0 1px 0 #fff;*zoom:1}.breadcrumb .divider{padding:0 5px;color:#999}.breadcrumb .active a{color:#333}.pagination{height:36px;margin:18px 0}.pagination ul{display:inline-block;*display:inline;margin-bottom:0;margin-left:0;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px;*zoom:1;-webkit-box-shadow:0 1px 2px rgba(0,0,0,0.05);-moz-box-shadow:0 1px 2px rgba(0,0,0,0.05);box-shadow:0 1px 2px rgba(0,0,0,0.05)}.pagination li{display:inline}.pagination a{float:left;padding:0 14px;line-height:34px;text-decoration:none;border:1px solid #ddd;border-left-width:0}.pagination a:hover,.pagination .active a{background-color:#f5f5f5}.pagination .active a{color:#999;cursor:default}.pagination .disabled span,.pagination .disabled a,.pagination .disabled a:hover{color:#999;cursor:default;background-color:transparent}.pagination li:first-child a{border-left-width:1px;-webkit-border-radius:3px 0 0 3px;-moz-border-radius:3px 0 0 3px;border-radius:3px 0 0 3px}.pagination li:last-child a{-webkit-border-radius:0 3px 3px 0;-moz-border-radius:0 3px 3px 0;border-radius:0 3px 3px 0}.pagination-centered{text-align:center}.pagination-right{text-align:right}.pager{margin-bottom:18px;margin-left:0;text-align:center;list-style:none;*zoom:1}.pager:before,.pager:after{display:table;content:""}.pager:after{clear:both}.pager li{display:inline}.pager a{display:inline-block;padding:5px 14px;background-color:#fff;border:1px solid #ddd;-webkit-border-radius:15px;-moz-border-radius:15px;border-radius:15px}.pager a:hover{text-decoration:none;background-color:#f5f5f5}.pager .next a{float:right}.pager .previous a{float:left}.pager .disabled a,.pager .disabled a:hover{color:#999;cursor:default;background-color:#fff}.modal-open .dropdown-menu{z-index:2050}.modal-open .dropdown.open{*z-index:2050}.modal-open .popover{z-index:2060}.modal-open .tooltip{z-index:2070}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1040;background-color:#000}.modal-backdrop.fade{opacity:0}.modal-backdrop,.modal-backdrop.fade.in{opacity:.8;filter:alpha(opacity=80)}.modal{position:fixed;top:50%;left:50%;z-index:1050;width:560px;margin:-250px 0 0 -280px;overflow:auto;background-color:#fff;border:1px solid #999;border:1px solid rgba(0,0,0,0.3);*border:1px solid #999;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 3px 7px rgba(0,0,0,0.3);-moz-box-shadow:0 3px 7px rgba(0,0,0,0.3);box-shadow:0 3px 7px rgba(0,0,0,0.3);-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box}.modal.fade{top:-25%;-webkit-transition:opacity .3s linear,top .3s ease-out;-moz-transition:opacity .3s linear,top .3s ease-out;-ms-transition:opacity .3s linear,top .3s ease-out;-o-transition:opacity .3s linear,top .3s ease-out;transition:opacity .3s linear,top .3s ease-out}.modal.fade.in{top:50%}.modal-header{padding:9px 15px;border-bottom:1px solid #eee}.modal-header .close{margin-top:2px}.modal-body{max-height:400px;padding:15px;overflow-y:auto}.modal-form{margin-bottom:0}.modal-footer{padding:14px 15px 15px;margin-bottom:0;text-align:right;background-color:#f5f5f5;border-top:1px solid #ddd;-webkit-border-radius:0 0 6px 6px;-moz-border-radius:0 0 6px 6px;border-radius:0 0 6px 6px;*zoom:1;-webkit-box-shadow:inset 0 1px 0 #fff;-moz-box-shadow:inset 0 1px 0 #fff;box-shadow:inset 0 1px 0 #fff}.modal-footer:before,.modal-footer:after{display:table;content:""}.modal-footer:after{clear:both}.modal-footer .btn+.btn{margin-bottom:0;margin-left:5px}.modal-footer .btn-group .btn+.btn{margin-left:-1px}.tooltip{position:absolute;z-index:1020;display:block;padding:5px;font-size:11px;opacity:0;filter:alpha(opacity=0);visibility:visible}.tooltip.in{opacity:.8;filter:alpha(opacity=80)}.tooltip.top{margin-top:-2px}.tooltip.right{margin-left:2px}.tooltip.bottom{margin-top:2px}.tooltip.left{margin-left:-2px}.tooltip.top .tooltip-arrow{bottom:0;left:50%;margin-left:-5px;border-top:5px solid #000;border-right:5px solid transparent;border-left:5px solid transparent}.tooltip.left .tooltip-arrow{top:50%;right:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid #000}.tooltip.bottom .tooltip-arrow{top:0;left:50%;margin-left:-5px;border-right:5px solid transparent;border-bottom:5px solid #000;border-left:5px solid transparent}.tooltip.right .tooltip-arrow{top:50%;left:0;margin-top:-5px;border-top:5px solid transparent;border-right:5px solid #000;border-bottom:5px solid transparent}.tooltip-inner{max-width:200px;padding:3px 8px;color:#fff;text-align:center;text-decoration:none;background-color:#000;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.tooltip-arrow{position:absolute;width:0;height:0}.popover{position:absolute;top:0;left:0;z-index:1010;display:none;padding:5px}.popover.top{margin-top:-5px}.popover.right{margin-left:5px}.popover.bottom{margin-top:5px}.popover.left{margin-left:-5px}.popover.top .arrow{bottom:0;left:50%;margin-left:-5px;border-top:5px solid #000;border-right:5px solid transparent;border-left:5px solid transparent}.popover.right .arrow{top:50%;left:0;margin-top:-5px;border-top:5px solid transparent;border-right:5px solid #000;border-bottom:5px solid transparent}.popover.bottom .arrow{top:0;left:50%;margin-left:-5px;border-right:5px solid transparent;border-bottom:5px solid #000;border-left:5px solid transparent}.popover.left .arrow{top:50%;right:0;margin-top:-5px;border-top:5px solid transparent;border-bottom:5px solid transparent;border-left:5px solid #000}.popover .arrow{position:absolute;width:0;height:0}.popover-inner{width:280px;padding:3px;overflow:hidden;background:#000;background:rgba(0,0,0,0.8);-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px;-webkit-box-shadow:0 3px 7px rgba(0,0,0,0.3);-moz-box-shadow:0 3px 7px rgba(0,0,0,0.3);box-shadow:0 3px 7px rgba(0,0,0,0.3)}.popover-title{padding:9px 15px;line-height:1;background-color:#f5f5f5;border-bottom:1px solid #eee;-webkit-border-radius:3px 3px 0 0;-moz-border-radius:3px 3px 0 0;border-radius:3px 3px 0 0}.popover-content{padding:14px;background-color:#fff;-webkit-border-radius:0 0 3px 3px;-moz-border-radius:0 0 3px 3px;border-radius:0 0 3px 3px;-webkit-background-clip:padding-box;-moz-background-clip:padding-box;background-clip:padding-box}.popover-content p,.popover-content ul,.popover-content ol{margin-bottom:0}.thumbnails{margin-left:-20px;list-style:none;*zoom:1}.thumbnails:before,.thumbnails:after{display:table;content:""}.thumbnails:after{clear:both}.row-fluid .thumbnails{margin-left:0}.thumbnails>li{float:left;margin-bottom:18px;margin-left:20px}.thumbnail{display:block;padding:4px;line-height:1;border:1px solid #ddd;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;-webkit-box-shadow:0 1px 1px rgba(0,0,0,0.075);-moz-box-shadow:0 1px 1px rgba(0,0,0,0.075);box-shadow:0 1px 1px rgba(0,0,0,0.075)}a.thumbnail:hover{border-color:#08c;-webkit-box-shadow:0 1px 4px rgba(0,105,214,0.25);-moz-box-shadow:0 1px 4px rgba(0,105,214,0.25);box-shadow:0 1px 4px rgba(0,105,214,0.25)}.thumbnail>img{display:block;max-width:100%;margin-right:auto;margin-left:auto}.thumbnail .caption{padding:9px}.label,.badge{font-size:10.998px;font-weight:bold;line-height:14px;color:#fff;text-shadow:0 -1px 0 rgba(0,0,0,0.25);white-space:nowrap;vertical-align:baseline;background-color:#999}.label{padding:1px 4px 2px;-webkit-border-radius:3px;-moz-border-radius:3px;border-radius:3px}.badge{padding:1px 9px 2px;-webkit-border-radius:9px;-moz-border-radius:9px;border-radius:9px}a.label:hover,a.badge:hover{color:#fff;text-decoration:none;cursor:pointer}.label-important,.badge-important{background-color:#b94a48}.label-important[href],.badge-important[href]{background-color:#953b39}.label-warning,.badge-warning{background-color:#f89406}.label-warning[href],.badge-warning[href]{background-color:#c67605}.label-success,.badge-success{background-color:#468847}.label-success[href],.badge-success[href]{background-color:#356635}.label-info,.badge-info{background-color:#3a87ad}.label-info[href],.badge-info[href]{background-color:#2d6987}.label-inverse,.badge-inverse{background-color:#333}.label-inverse[href],.badge-inverse[href]{background-color:#1a1a1a}@-webkit-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-moz-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-ms-keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}@-o-keyframes progress-bar-stripes{from{background-position:0 0}to{background-position:40px 0}}@keyframes progress-bar-stripes{from{background-position:40px 0}to{background-position:0 0}}.progress{height:18px;margin-bottom:18px;overflow:hidden;background-color:#f7f7f7;background-image:-moz-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-ms-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#f5f5f5),to(#f9f9f9));background-image:-webkit-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:-o-linear-gradient(top,#f5f5f5,#f9f9f9);background-image:linear-gradient(top,#f5f5f5,#f9f9f9);background-repeat:repeat-x;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#f5f5f5',endColorstr='#f9f9f9',GradientType=0);-webkit-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);-moz-box-shadow:inset 0 1px 2px rgba(0,0,0,0.1);box-shadow:inset 0 1px 2px rgba(0,0,0,0.1)}.progress .bar{width:0;height:18px;font-size:12px;color:#fff;text-align:center;text-shadow:0 -1px 0 rgba(0,0,0,0.25);background-color:#0e90d2;background-image:-moz-linear-gradient(top,#149bdf,#0480be);background-image:-webkit-gradient(linear,0 0,0 100%,from(#149bdf),to(#0480be));background-image:-webkit-linear-gradient(top,#149bdf,#0480be);background-image:-o-linear-gradient(top,#149bdf,#0480be);background-image:linear-gradient(top,#149bdf,#0480be);background-image:-ms-linear-gradient(top,#149bdf,#0480be);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#149bdf',endColorstr='#0480be',GradientType=0);-webkit-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-moz-box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);box-shadow:inset 0 -1px 0 rgba(0,0,0,0.15);-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;-webkit-transition:width .6s ease;-moz-transition:width .6s ease;-ms-transition:width .6s ease;-o-transition:width .6s ease;transition:width .6s ease}.progress-striped .bar{background-color:#149bdf;background-image:-o-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-webkit-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-ms-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);-webkit-background-size:40px 40px;-moz-background-size:40px 40px;-o-background-size:40px 40px;background-size:40px 40px}.progress.active .bar{-webkit-animation:progress-bar-stripes 2s linear infinite;-moz-animation:progress-bar-stripes 2s linear infinite;-ms-animation:progress-bar-stripes 2s linear infinite;-o-animation:progress-bar-stripes 2s linear infinite;animation:progress-bar-stripes 2s linear infinite}.progress-danger .bar{background-color:#dd514c;background-image:-moz-linear-gradient(top,#ee5f5b,#c43c35);background-image:-ms-linear-gradient(top,#ee5f5b,#c43c35);background-image:-webkit-gradient(linear,0 0,0 100%,from(#ee5f5b),to(#c43c35));background-image:-webkit-linear-gradient(top,#ee5f5b,#c43c35);background-image:-o-linear-gradient(top,#ee5f5b,#c43c35);background-image:linear-gradient(top,#ee5f5b,#c43c35);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#ee5f5b',endColorstr='#c43c35',GradientType=0)}.progress-danger.progress-striped .bar{background-color:#ee5f5b;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-ms-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-success .bar{background-color:#5eb95e;background-image:-moz-linear-gradient(top,#62c462,#57a957);background-image:-ms-linear-gradient(top,#62c462,#57a957);background-image:-webkit-gradient(linear,0 0,0 100%,from(#62c462),to(#57a957));background-image:-webkit-linear-gradient(top,#62c462,#57a957);background-image:-o-linear-gradient(top,#62c462,#57a957);background-image:linear-gradient(top,#62c462,#57a957);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#62c462',endColorstr='#57a957',GradientType=0)}.progress-success.progress-striped .bar{background-color:#62c462;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-ms-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-info .bar{background-color:#4bb1cf;background-image:-moz-linear-gradient(top,#5bc0de,#339bb9);background-image:-ms-linear-gradient(top,#5bc0de,#339bb9);background-image:-webkit-gradient(linear,0 0,0 100%,from(#5bc0de),to(#339bb9));background-image:-webkit-linear-gradient(top,#5bc0de,#339bb9);background-image:-o-linear-gradient(top,#5bc0de,#339bb9);background-image:linear-gradient(top,#5bc0de,#339bb9);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#5bc0de',endColorstr='#339bb9',GradientType=0)}.progress-info.progress-striped .bar{background-color:#5bc0de;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-ms-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.progress-warning .bar{background-color:#faa732;background-image:-moz-linear-gradient(top,#fbb450,#f89406);background-image:-ms-linear-gradient(top,#fbb450,#f89406);background-image:-webkit-gradient(linear,0 0,0 100%,from(#fbb450),to(#f89406));background-image:-webkit-linear-gradient(top,#fbb450,#f89406);background-image:-o-linear-gradient(top,#fbb450,#f89406);background-image:linear-gradient(top,#fbb450,#f89406);background-repeat:repeat-x;filter:progid:dximagetransform.microsoft.gradient(startColorstr='#fbb450',endColorstr='#f89406',GradientType=0)}.progress-warning.progress-striped .bar{background-color:#fbb450;background-image:-webkit-gradient(linear,0 100%,100% 0,color-stop(0.25,rgba(255,255,255,0.15)),color-stop(0.25,transparent),color-stop(0.5,transparent),color-stop(0.5,rgba(255,255,255,0.15)),color-stop(0.75,rgba(255,255,255,0.15)),color-stop(0.75,transparent),to(transparent));background-image:-webkit-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-moz-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-ms-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:-o-linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent);background-image:linear-gradient(-45deg,rgba(255,255,255,0.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,0.15) 50%,rgba(255,255,255,0.15) 75%,transparent 75%,transparent)}.accordion{margin-bottom:18px}.accordion-group{margin-bottom:2px;border:1px solid #e5e5e5;-webkit-border-radius:4px;-moz-border-radius:4px;border-radius:4px}.accordion-heading{border-bottom:0}.accordion-heading .accordion-toggle{display:block;padding:8px 15px}.accordion-toggle{cursor:pointer}.accordion-inner{padding:9px 15px;border-top:1px solid #e5e5e5}.carousel{position:relative;margin-bottom:18px;line-height:1}.carousel-inner{position:relative;width:100%;overflow:hidden}.carousel .item{position:relative;display:none;-webkit-transition:.6s ease-in-out left;-moz-transition:.6s ease-in-out left;-ms-transition:.6s ease-in-out left;-o-transition:.6s ease-in-out left;transition:.6s ease-in-out left}.carousel .item>img{display:block;line-height:1}.carousel .active,.carousel .next,.carousel .prev{display:block}.carousel .active{left:0}.carousel .next,.carousel .prev{position:absolute;top:0;width:100%}.carousel .next{left:100%}.carousel .prev{left:-100%}.carousel .next.left,.carousel .prev.right{left:0}.carousel .active.left{left:-100%}.carousel .active.right{left:100%}.carousel-control{position:absolute;top:40%;left:15px;width:40px;height:40px;margin-top:-20px;font-size:60px;font-weight:100;line-height:30px;color:#fff;text-align:center;background:#222;border:3px solid #fff;-webkit-border-radius:23px;-moz-border-radius:23px;border-radius:23px;opacity:.5;filter:alpha(opacity=50)}.carousel-control.right{right:15px;left:auto}.carousel-control:hover{color:#fff;text-decoration:none;opacity:.9;filter:alpha(opacity=90)}.carousel-caption{position:absolute;right:0;bottom:0;left:0;padding:10px 15px 5px;background:#333;background:rgba(0,0,0,0.75)}.carousel-caption h4,.carousel-caption p{color:#fff}.hero-unit{padding:60px;margin-bottom:30px;background-color:#eee;-webkit-border-radius:6px;-moz-border-radius:6px;border-radius:6px}.hero-unit h1{margin-bottom:0;font-size:60px;line-height:1;letter-spacing:-1px;color:inherit}.hero-unit p{font-size:18px;font-weight:200;line-height:27px;color:inherit}.pull-right{float:right}.pull-left{float:left}.hide{display:none}.show{display:block}.invisible{visibility:hidden} diff --git a/ckan/public/css/chosen.css b/ckan/public/css/chosen.css deleted file mode 100644 index 1405ebbfc5a..00000000000 --- a/ckan/public/css/chosen.css +++ /dev/null @@ -1,390 +0,0 @@ -/* @group Base */ -.chzn-container { - font-size: 13px; - position: relative; - display: inline-block; - zoom: 1; - *display: inline; -} -.chzn-container .chzn-drop { - background: #fff; - border: 1px solid #aaa; - border-top: 0; - position: absolute; - top: 29px; - left: 0; - -webkit-box-shadow: 0 4px 5px rgba(0,0,0,.15); - -moz-box-shadow : 0 4px 5px rgba(0,0,0,.15); - -o-box-shadow : 0 4px 5px rgba(0,0,0,.15); - box-shadow : 0 4px 5px rgba(0,0,0,.15); - z-index: 999; -} -/* @end */ - -/* @group Single Chosen */ -.chzn-container-single .chzn-single { - background-color: #ffffff; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #f4f4f4), color-stop(0.48, #eeeeee), color-stop(0.5, #f6f6f6), color-stop(0.8, #ffffff)); - background-image: -webkit-linear-gradient(center bottom, #f4f4f4 0%, #eeeeee 48%, #f6f6f6 50%, #ffffff 80%); - background-image: -moz-linear-gradient(center bottom, #f4f4f4 0%, #eeeeee 48%, #f6f6f6 50%, #ffffff 80%); - background-image: -o-linear-gradient(top, #f4f4f4 0%, #eeeeee 48%, #f6f6f6 50%, #ffffff 80%); - background-image: -ms-linear-gradient(top, #f4f4f4 0%, #eeeeee 48%, #f6f6f6 50%, #ffffff 80%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#eeeeee', endColorstr='#ffffff',GradientType=0 ); - background-image: linear-gradient(top, #f4f4f4 0%, #eeeeee 48%, #f6f6f6 50%, #ffffff 80%); - -webkit-border-radius: 5px; - -moz-border-radius : 5px; - border-radius : 5px; - -moz-background-clip : padding; - -webkit-background-clip: padding-box; - background-clip : padding-box; - border: 1px solid #aaaaaa; - -webkit-box-shadow: 0 0 3px #ffffff inset, 0 1px 1px rgba(0,0,0,0.1); - -moz-box-shadow : 0 0 3px #ffffff inset, 0 1px 1px rgba(0,0,0,0.1); - box-shadow : 0 0 3px #ffffff inset, 0 1px 1px rgba(0,0,0,0.1); - display: block; - overflow: hidden; - white-space: nowrap; - position: relative; - height: 23px; - line-height: 24px; - padding: 0 0 0 8px; - color: #444444; - text-decoration: none; -} -.chzn-container-single .chzn-single span { - margin-right: 26px; - display: block; - overflow: hidden; - white-space: nowrap; - -o-text-overflow: ellipsis; - -ms-text-overflow: ellipsis; - text-overflow: ellipsis; -} -.chzn-container-single .chzn-single abbr { - display: block; - position: absolute; - right: 26px; - top: 6px; - width: 12px; - height: 13px; - font-size: 1px; - background: url('../images/chosen-sprite.png') right top no-repeat; -} -.chzn-container-single .chzn-single abbr:hover { - background-position: right -11px; -} -.chzn-container-single .chzn-single div { - position: absolute; - right: 0; - top: 0; - display: block; - height: 100%; - width: 18px; -} -.chzn-container-single .chzn-single div b { - background: url('../images/chosen-sprite.png') no-repeat 0 0; - display: block; - width: 100%; - height: 100%; -} -.chzn-container-single .chzn-search { - padding: 3px 4px; - position: relative; - margin: 0; - white-space: nowrap; - z-index: 1010; -} -.chzn-container-single .chzn-search input { - background: #fff url('../images/chosen-sprite.png') no-repeat 100% -22px; - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, -o-linear-gradient(bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, -ms-linear-gradient(top, #ffffff 85%,#eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat 100% -22px, linear-gradient(top, #ffffff 85%,#eeeeee 99%); - margin: 1px 0; - padding: 4px 20px 4px 5px; - outline: 0; - border: 1px solid #aaa; - font-family: sans-serif; - font-size: 1em; -} -.chzn-container-single .chzn-drop { - -webkit-border-radius: 0 0 4px 4px; - -moz-border-radius : 0 0 4px 4px; - border-radius : 0 0 4px 4px; - -moz-background-clip : padding; - -webkit-background-clip: padding-box; - background-clip : padding-box; -} -/* @end */ - -.chzn-container-single-nosearch .chzn-search input { - position: absolute; - left: -9000px; -} - -/* @group Multi Chosen */ -.chzn-container-multi .chzn-choices { - background-color: #fff; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); - background-image: -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background-image: -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background-image: -o-linear-gradient(bottom, white 85%, #eeeeee 99%); - background-image: -ms-linear-gradient(top, #ffffff 85%, #eeeeee 99%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eeeeee',GradientType=0 ); - background-image: linear-gradient(top, #ffffff 85%, #eeeeee 99%); - border: 1px solid #aaa; - margin: 0; - padding: 0; - cursor: text; - overflow: hidden; - height: auto !important; - height: 1%; - position: relative; -} -.chzn-container-multi .chzn-choices li { - float: left; - list-style: none; -} -.chzn-container-multi .chzn-choices .search-field { - white-space: nowrap; - margin: 0; - padding: 0; -} -.chzn-container-multi .chzn-choices .search-field input { - color: #666; - background: transparent !important; - border: 0 !important; - font-family: sans-serif; - font-size: 100%; - height: 15px; - padding: 5px; - margin: 1px 0; - outline: 0; - -webkit-box-shadow: none; - -moz-box-shadow : none; - -o-box-shadow : none; - box-shadow : none; -} -.chzn-container-multi .chzn-choices .search-field .default { - color: #999; -} -.chzn-container-multi .chzn-choices .search-choice { - -webkit-border-radius: 3px; - -moz-border-radius : 3px; - border-radius : 3px; - -moz-background-clip : padding; - -webkit-background-clip: padding-box; - background-clip : padding-box; - background-color: #e4e4e4; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0, #eeeeee), color-stop(0.48, #e8e8e8), color-stop(0.5, #f0f0f0), color-stop(0.8, #f4f4f4)); - background-image: -webkit-linear-gradient(center bottom, #eeeeee 0%, #e8e8e8 48%, #f0f0f0 50%, #f4f4f4 80%); - background-image: -moz-linear-gradient(center bottom, #eeeeee 0%, #e8e8e8 48%, #f0f0f0 50%, #f4f4f4 80%); - background-image: -o-linear-gradient(top, #eeeeee 0%, #e8e8e8 48%, #f0f0f0 50%, #f4f4f4 80%); - background-image: -ms-linear-gradient(top, #eeeeee 0%, #e8e8e8 48%, #f0f0f0 50%, #f4f4f4 80%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#eeeeee', endColorstr='#f4f4f4',GradientType=0 ); - background-image: linear-gradient(top, #eeeeee 0%, #e8e8e8 48%, #f0f0f0 50%, #f4f4f4 80%); - -webkit-box-shadow: 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05); - -moz-box-shadow : 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05); - box-shadow : 0 0 2px #ffffff inset, 0 1px 0 rgba(0,0,0,0.05); - color: #333; - border: 1px solid #aaaaaa; - line-height: 13px; - padding: 3px 20px 3px 5px; - margin: 3px 0 3px 5px; - position: relative; -} -.chzn-container-multi .chzn-choices .search-choice span { - cursor: default; -} -.chzn-container-multi .chzn-choices .search-choice-focus { - background: #d4d4d4; -} -.chzn-container-multi .chzn-choices .search-choice .search-choice-close { - display: block; - position: absolute; - right: 3px; - top: 4px; - width: 12px; - height: 13px; - font-size: 1px; - background: url('../images/chosen-sprite.png') right top no-repeat; -} -.chzn-container-multi .chzn-choices .search-choice .search-choice-close:hover { - background-position: right -11px; -} -.chzn-container-multi .chzn-choices .search-choice-focus .search-choice-close { - background-position: right -11px; -} -/* @end */ - -/* @group Results */ -.chzn-container .chzn-results { - margin: 0 4px 4px 0; - max-height: 240px; - padding: 0 0 0 4px; - position: relative; - overflow-x: hidden; - overflow-y: auto; -} -.chzn-container-multi .chzn-results { - margin: -1px 0 0; - padding: 0; -} -.chzn-container .chzn-results li { - display: none; - line-height: 15px; - padding: 5px 6px; - margin: 0; - list-style: none; -} -.chzn-container .chzn-results .active-result { - cursor: pointer; - display: list-item; -} -.chzn-container .chzn-results .highlighted { - background-color: #3875d7; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0.1, #2a62bc), color-stop(0.8, #3875d7)); - background-image: -webkit-linear-gradient(center bottom, #2a62bc 10%, #3875d7 80%); - background-image: -moz-linear-gradient(center bottom, #2a62bc 10%, #3875d7 80%); - background-image: -o-linear-gradient(bottom, #2a62bc 10%, #3875d7 80%); - background-image: -ms-linear-gradient(top, #2a62bc 10%, #3875d7 80%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2a62bc', endColorstr='#3875d7',GradientType=0 ); - background-image: linear-gradient(top, #2a62bc 10%, #3875d7 80%); - color: #fff; -} -.chzn-container .chzn-results li em { - background: #feffde; - font-style: normal; -} -.chzn-container .chzn-results .highlighted em { - background: transparent; -} -.chzn-container .chzn-results .no-results { - background: #f4f4f4; - display: list-item; -} -.chzn-container .chzn-results .group-result { - cursor: default; - color: #999; - font-weight: bold; -} -.chzn-container .chzn-results .group-option { - padding-left: 15px; -} -.chzn-container-multi .chzn-drop .result-selected { - display: none; -} -.chzn-container .chzn-results-scroll { - background: white; - margin: 0px 4px; - position: absolute; - text-align: center; - width: 321px; /* This should by dynamic with js */ - z-index: 1; -} -.chzn-container .chzn-results-scroll span { - display: inline-block; - height: 17px; - text-indent: -5000px; - width: 9px; -} -.chzn-container .chzn-results-scroll-down { - bottom: 0; -} -.chzn-container .chzn-results-scroll-down span { - background: url('../images/chosen-sprite.png') no-repeat -4px -3px; -} -.chzn-container .chzn-results-scroll-up span { - background: url('../images/chosen-sprite.png') no-repeat -22px -3px; -} -/* @end */ - -/* @group Active */ -.chzn-container-active .chzn-single { - -webkit-box-shadow: 0 0 5px rgba(0,0,0,.3); - -moz-box-shadow : 0 0 5px rgba(0,0,0,.3); - -o-box-shadow : 0 0 5px rgba(0,0,0,.3); - box-shadow : 0 0 5px rgba(0,0,0,.3); - border: 1px solid #5897fb; -} -.chzn-container-active .chzn-single-with-drop { - border: 1px solid #aaa; - -webkit-box-shadow: 0 1px 0 #fff inset; - -moz-box-shadow : 0 1px 0 #fff inset; - -o-box-shadow : 0 1px 0 #fff inset; - box-shadow : 0 1px 0 #fff inset; - background-color: #eee; - background-image: -webkit-gradient(linear, left bottom, left top, color-stop(0.2, white), color-stop(0.8, #eeeeee)); - background-image: -webkit-linear-gradient(center bottom, white 20%, #eeeeee 80%); - background-image: -moz-linear-gradient(center bottom, white 20%, #eeeeee 80%); - background-image: -o-linear-gradient(bottom, white 20%, #eeeeee 80%); - background-image: -ms-linear-gradient(top, #ffffff 20%,#eeeeee 80%); - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#eeeeee',GradientType=0 ); - background-image: linear-gradient(top, #ffffff 20%,#eeeeee 80%); - -webkit-border-bottom-left-radius : 0; - -webkit-border-bottom-right-radius: 0; - -moz-border-radius-bottomleft : 0; - -moz-border-radius-bottomright: 0; - border-bottom-left-radius : 0; - border-bottom-right-radius: 0; -} -.chzn-container-active .chzn-single-with-drop div { - background: transparent; - border-left: none; -} -.chzn-container-active .chzn-single-with-drop div b { - background-position: -18px 1px; -} -.chzn-container-active .chzn-choices { - -webkit-box-shadow: 0 0 5px rgba(0,0,0,.3); - -moz-box-shadow : 0 0 5px rgba(0,0,0,.3); - -o-box-shadow : 0 0 5px rgba(0,0,0,.3); - box-shadow : 0 0 5px rgba(0,0,0,.3); - border: 1px solid #5897fb; -} -.chzn-container-active .chzn-choices .search-field input { - color: #111 !important; -} -/* @end */ - -/* @group Disabled Support */ -.chzn-disabled { - cursor: default; - opacity:0.5 !important; -} -.chzn-disabled .chzn-single { - cursor: default; -} -.chzn-disabled .chzn-choices .search-choice .search-choice-close { - cursor: default; -} - -/* @group Right to Left */ -.chzn-rtl { direction:rtl;text-align: right; } -.chzn-rtl .chzn-single { padding-left: 0; padding-right: 8px; } -.chzn-rtl .chzn-single span { margin-left: 26px; margin-right: 0; } - -.chzn-rtl .chzn-single div { left: 3px; right: auto; } -.chzn-rtl .chzn-single abbr { - left: 26px; - right: auto; -} -.chzn-rtl .chzn-choices li { float: right; } -.chzn-rtl .chzn-choices .search-choice { padding: 3px 5px 3px 19px; margin: 3px 5px 3px 0; } -.chzn-rtl .chzn-choices .search-choice .search-choice-close { left: 4px; right: auto; background-position: right top;} -.chzn-rtl.chzn-container-single .chzn-results { margin-left: 4px; margin-right: 0; padding-left: 0; padding-right: 4px; } -.chzn-rtl .chzn-results .group-option { padding-left: 0; padding-right: 20px; } -.chzn-rtl.chzn-container-active .chzn-single-with-drop div { border-right: none; } -.chzn-rtl .chzn-search input { - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, #ffffff; - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, -webkit-gradient(linear, left bottom, left top, color-stop(0.85, white), color-stop(0.99, #eeeeee)); - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, -webkit-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, -moz-linear-gradient(center bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, -o-linear-gradient(bottom, white 85%, #eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, -ms-linear-gradient(top, #ffffff 85%,#eeeeee 99%); - background: url('../images/chosen-sprite.png') no-repeat -38px -22px, linear-gradient(top, #ffffff 85%,#eeeeee 99%); - padding: 4px 5px 4px 20px; -} -/* @end */ \ No newline at end of file diff --git a/ckan/public/css/forms.css b/ckan/public/css/forms.css deleted file mode 100644 index e1a6a46de91..00000000000 --- a/ckan/public/css/forms.css +++ /dev/null @@ -1,199 +0,0 @@ -/* Generated at 2010-03-25 16:44:39 from css@pearl.joyent.us commit 1d2b5cf. */ - -fieldset { - padding: 1em; - margin: 0 0 1.5em 0; - border-bottom: 1px solid #ccc; } - -legend { - font-weight: bold; - font-size: 1.2em; } - -textarea, select, -input[type=text], input.text, -input[type=password], input.password, -input[type=email], input.email, -input[type=url], input.url { - padding: 0.3em; - width: 30em; - margin: 0 0 0.5em 0; - background: #fff; - border: 1px solid #bbb; } - textarea:focus, select:focus, - input[type=text]:focus, input.text:focus, - input[type=password]:focus, input.password:focus, - input[type=email]:focus, input.email:focus, - input[type=url]:focus, input.url:focus { - border-color: #666; } - textarea.has-errors, select.has-errors, - textarea.fieldWithErrors, select.fieldWithErrors, - input[type=text].has-errors, input.text.has-errors, - input[type=text].fieldWithErrors, input.text.fieldWithErrors, - input[type=password].has-errors, input.password.has-errors, - input[type=password].fieldWithErrors, input.password.fieldWithErrors, - input[type=email].has-errors, input.email.has-errors, - input[type=email].fieldWithErrors, input.email.fieldWithErrors, - input[type=url].has-errors, input.url.has-errors, - input[type=url].fieldWithErrors, input.url.fieldWithErrors { - border-color: #d12f19; } - table textarea, table select, - table input[type=text], table input.text, - table input[type=password], table input.password, - table input[type=email], table input.email, - table input[type=url], table input.url { - margin: 0; } - -input.title { - font-size: 1.5em; } -input.short { - width: 15em; } -table input.short { - width: 12em; } -input.medium-width { - width: 25em; } -table input.medium-width { - width: 20em; } -input.long { - width: 100%; } - -select.short { - width: 14.5em; } - -textarea { - width: 30em; - height: 15em; } -textarea.short { - height: 1em; } -textarea.wide { - width: 55; - height: 1em; } - -select[multiple], select.multiple { - padding: 0; - height: 10em; } - -form dl { - *display: inline-block; - clear: left; - width: 100%; - background: transparent url(../images/dlbg.png) repeat-y 21% top; - padding: 0.5em 0; } - form dl:after { - content: "."; - display: block; - height: 0; - clear: both; - visibility: hidden; } - form dl dt { - width: 20%; - margin: 1em 0 0 0; - float: left; - clear: right; - text-align: right; } - form dl dt:first-child, form dl dt:first-child + dd { - margin-top: 0em; } - form dl dd { - float: right; - min-height: 1.5em; - width: 78%; - margin: 0 0 0 2%; } - form dl dt + dd { - margin-top: 1em; } - form dl dt, form dl dd { - font-size: 1em; - line-height: 1.5em; } - * html form dl { - height: 1px; } - form dl dd img { - vertical-align: middle; } - form dl dd ul { - margin: 0.5em 0 0 0; - padding-top: 0; - padding-right: 0; - padding-bottom: 0; - } - form dl dd.notes, form dl dd.hints, .hints { - padding: 0 0 0.3em 0; - color: #555; - font-size: 90%; - } - -label.has-errors, label.fieldWithErrors { - font-weight: bold; - color: #d12f19; } - -label { - display: block; - padding: 0.2em; -} - -form .field_error, form .error-explanation { - display: none; } -form.has-errors .field_error, form.has-errors .error-explanation { - display: block; } - -.field_error { - color: #d12f19; - left: 20px; - padding-left: 20px; - position: relative; - background: transparent url(../images/icons/error.png) left 3px no-repeat; } - -td.field_warning { - color: #d12f19; } - -.fieldset_button_error { - background: transparent url(../images/icons/error.png) left center no-repeat; } - -.error-explanation, -#errorExplanation { - background: #fff; - border: 1px solid #d12f19; - margin-bottom: 1em; - clear: left; } - .error-explanation h2, - #errorExplanation h2 { - margin: 0; - font-size: 1.1em; - font-weight: bold; - padding-left: 1em; - line-height: 2.6em; - background: #d12f19; - color: #fff; } - .error-explanation ul, .error-explanation p, - #errorExplanation ul, #errorExplanation p { - margin: 0.5em 1em; } - .error-explanation ul, - #errorExplanation ul { - margin-left: 2em; } - -.taglist { - margin-top: 0; } - .taglist li { - -moz-border-radius: 0.4em; - -webkit-border-radius: 0.4em; - border-radius: 0.4em; - margin: 0 0.3em 0 0; - padding: 0 0.5em; - background: #395ee8; - font-weight: bold; - color: white; - display: inline; - float: left; - line-height: 16px; } - .taglist li img { - opacity: 0.5; } - .taglist li img:hover { - opacity: 1; } - -#preview { - margin-bottom: 30px; - } - -#openid_form { - width: 100%; -} - -#openid_input_area { - padding: 0px; -} diff --git a/ckan/public/css/handheld.css b/ckan/public/css/handheld.css deleted file mode 100755 index 262416019fb..00000000000 --- a/ckan/public/css/handheld.css +++ /dev/null @@ -1,8 +0,0 @@ -* { - float: none; - background: #fff; - color: #000; -} - - -body { font-size: 80%; } \ No newline at end of file diff --git a/ckan/public/css/style.css b/ckan/public/css/style.css deleted file mode 100644 index 6df5b558884..00000000000 --- a/ckan/public/css/style.css +++ /dev/null @@ -1,1507 +0,0 @@ -body.no-sidebar .sidebar-outer { display: none; } -body.no-sidebar #content { padding-right: 0; border-right: none; } -body.no-sidebar .content-outer { - width: 940px; -} - -.header.outer { - background-color: #e2e2e2; - background-image: -webkit-gradient(linear, left top, left bottom, from(#e2e2e2), to(#cccccc)); - background-image: -webkit-linear-gradient(top, #e2e2e2, #cccccc); - background-image: -moz-linear-gradient(top, #e2e2e2, #cccccc); - background-image: -ms-linear-gradient(top, #e2e2e2, #cccccc); - background-image: -o-linear-gradient(top, #e2e2e2, #cccccc); - background-image: linear-gradient(top, #e2e2e2, #cccccc); - filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#e2e2e2', EndColorStr='#cccccc'); - - margin-bottom: 18px; - -moz-box-shadow: 0px 2px 15px #dddddd; - -webkit-box-shadow: 0px 2px 15px #dddddd; - box-shadow: 0px 2px 15px #dddddd; - border-bottom: 1px solid #ccc; -} - -header { - padding: 5px 0px 5px 0px; -} - -header #logo { - float: left; -} - -header #site-name { - font-size: 1.4em; - font-family: Ubuntu, sans-serif; - padding: 5px; - padding-left: 82px; - padding-bottom: 2px; - /*font-weight: bold;*/ - color: #333; - text-shadow: 1px 1px 3px #ccc; - line-height: 1.3; -} - -header #site-name a { - color: #000; -} - -header .menu form { - display: inline; -} - -header .menu input { - width: 200px; - margin-top: 2px; - height: 10px; -} - -header .menu a { - display: inline-block; - padding-top: 5px; - font-size: 1.1em; - text-decoration: none; - font-weight: bold; - margin-left: 1.5em; - text-shadow: 1px 1px 3px #ccc; -} - -header .menu #menusearch { - float: right; -} - -header .menu #mainmenu { - display: inline; -} - -header .account { - float: right; -} - -header .search { - margin: 1px; - margin-left: 1em; - border: 1px solid #ccc; - font-size: 1.1em; - padding: 0.4em; - font-weight: bold; - - -moz-border-radius: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; - -moz-background-clip: padding; -webkit-background-clip: padding-box; background-clip: padding-box; -} - -.footer.outer { - border-top: 2px solid #ccc; - background-color: #dbdbdb; - background-image: -webkit-gradient(linear, left top, left bottom, from(#dbdbdb), to(#ffffff)); - background-image: -webkit-linear-gradient(top, #dbdbdb, #ffffff); - background-image: -moz-linear-gradient(top, #dbdbdb, #ffffff); - background-image: -ms-linear-gradient(top, #dbdbdb, #ffffff); - background-image: -o-linear-gradient(top, #dbdbdb, #ffffff); - background-image: linear-gradient(top, #dbdbdb, #ffffff); - fromilter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#dbdbdb', EndColorStr='#ffffff'); -} - -html, body { - height: 100%; -} - -#wrap { - height: auto !important; - height: 100%; - margin: 0 auto 1%; -} - -footer, #push { - height: auto; -} - -footer { - margin-top: 5px; - padding-top: 1em; -} - -footer a { - text-decoration: none; -} - -footer h3 { - font-size: 1.2em; -} - -h1, h2, h3, h4, h5 { - font-family: 'Ubuntu', Georgia; - font-weight: normal; - margin-bottom: 10px; -} - -a, a:visited { - color: #bb2222; - text-decoration: none; -} - -a:hover { - color: #183661; -} - -a.btn-primary:visited { - color: #fff; -} - -label.control-label { - font-weight: bold; -} - - -/* ====== */ -/* Tables */ -/* ====== */ -/* -table th { - border: 1px solid #e0e0e0; - background-color: #e2e2e2; - background-image: -webkit-gradient(linear, left top, left bottom, from(#f0f0f0), to(#e2e2e2)); - background-image: -webkit-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -moz-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -ms-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -o-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: linear-gradient(top, #f0f0f0, #e2e2e2); - filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#f0f0f0', EndColorStr='#e2e2e2'); -} -table caption { - caption-side: bottom; - color: #888; - font-size: 0.9em; - background-color: white; -} -tbody tr:nth-child(even) td, tbody tr.even td { - background-color: #F9F9F9; -} -tbody tr:nth-child(odd) td, tbody tr.odd td { - background-color: #F2F2F2; -} -*/ - - -/* ==================== */ -/* Common page elements */ -/* ==================== */ -#content { - border-right: 1px solid #e0e0e0; - padding-right: 20px; -} -.page_heading { - margin-top: 0.9em; - margin-bottom: 0.7em; - font-size: 2.2em; - font-weight: normal; -} -#page-logo { - max-width: 36px; - max-height: 36px; - vertical-align: text-top; -} -.hover-for-help { - position: relative; -} -.hover-for-help > .help-text { - position: absolute; - top: 24px; - left: -90px; - display: none; - padding: 2px 8px; - font-size: 11px; - background: #333; - text-align: left; - width: 250px; - z-index: 3; - color: #fff; -} -.hover-for-help > .help-text > span { - display: block; - padding: 2px 0; -} -.hover-for-help > .help-text > span.fail { - color: #999; -} -.hover-for-help:hover > .help-text { - display: block; -} -.semi-link { - border-bottom: 1px dashed #000; -} - -img.gravatar { - margin: 0 5px -5px 0; - border-radius: 3px; - vertical-align: baseline; -} - -.inline-icon { - padding-right: 5px; - vertical-align: top; -} - -.drag-drop-list { - list-style-type: none; - margin: 0; - padding: 0; -} -.drag-drop-list li { - margin-bottom: 3px; - cursor: move; -} -.drag-drop-list li.drag-bars { - padding-left: 35px; - background-image: url('/images/dragbars.png'); - background-repeat: no-repeat; - background-position: top left; -} - -ul.no-break li { - white-space: nowrap; - overflow: hidden; -} - -/* =============== */ -/* MinorNavigation */ -/* =============== */ -#minornavigation .nav { - margin: 0 0 1em 0 ; - border: 1px solid #e0e0e0; - background-color: #e2e2e2; - background-image: -webkit-gradient(linear, left top, left bottom, from(#f0f0f0), to(#e2e2e2)); - background-image: -webkit-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -moz-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -ms-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: -o-linear-gradient(top, #f0f0f0, #e2e2e2); - background-image: linear-gradient(top, #f0f0f0, #e2e2e2); - filter: progid:DXImageTransform.Microsoft.gradient(startColorStr='#f0f0f0', EndColorStr='#e2e2e2'); - - -moz-border-radius: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; - -moz-background-clip: padding; -webkit-background-clip: padding-box; background-clip: padding-box; - padding: 2px 4px; - font-weight: bold; -} -#minornavigation .nav > li > a { - border: 1px solid transparent; - border-bottom: none; - border-right: none; - height: 14px; - margin-right: 5px; - padding-top: 7px; -} -#minornavigation .nav > li > a:hover { - border-color: #bbb; -} -#minornavigation .nav > li.active > a { - background: #fff; - border-color: #666; - color: #000; -} -#minornavigation .nav > li.open > a { - border-color: #666; -} -#minornavigation .nav > li.disabled > a, -#minornavigation .nav > li.disabled > a:hover { - color: #888; - border-color: transparent; - background: transparent; -} -#minornavigation .caret { - border-top-color: #555; - margin-left: 8px; -} -#minornavigation .nav > li.open .caret { - border-top-color: #fff; -} -#minornavigation .divider { - padding: 8px 10px; - font-size: 14px; - color: #888; -} -.dropdown-menu { - min-width: 250px; -} -.dropdown-menu a { - font-weight: bold; - padding: 5px 15px; - margin-bottom: 2px; - color: #bb2222; -} -.dropdown-menu hr { - margin: 4px 0; -} -.dropdown-menu li:last-child a { - margin-bottom: 0; -} -.dropdown-menu li:hover a { - color: #183661; - background: #eee; -} - - -/* ======= */ -/* Sidebar */ -/* ======= */ -#sidebar { - overflow: hidden; -} -#sidebar h2, -#sidebar h3 { - font-size: 1.3em; -} -#sidebar .widget-list { - list-style: none; - margin-left: 0px; -} -#sidebar .widget-list li.widget-container { - padding-bottom: 1em; - border-bottom: 1px solid #e0e0e0; - margin-bottom: 1em; -} -#sidebar .widget-list li.widget-container.boxed { - border-bottom: 0; - background-color: #FFF7C0; - padding: 15px; - padding-top: 10px; - -moz-border-radius: 15px; - -webkit-border-radius: 15px; - border-radius: 15px; -} - - -/* ============== */ -/* = Pagination = */ -/* ============== */ -.pagination-alphabet a { - padding: 0 6px; -} - -/* ====== */ -/* Facets */ -/* ====== */ -.facet-box h2 { - color: #000; - font-size: 1.2em; -} -.facet-box .facet-options { - margin-top: 0.5em; -} -.facet-box .facet-options li { - padding-top: 0.2em; - color: #000; -} - - -/* ======================= */ -/* = Generic Form Footer = */ -/* ======================= */ -div.form-actions p.hints { - width: 50%; - margin: 10px 0 0 0; -} - - -/* ============= */ -/* = Home Page = */ -/* ============= */ -body.index.home #sidebar { - display: none; -} -body.index.home .front-page .action-box h1 { - padding-top: 0.6em; - padding-bottom: 0.5em; - font-size: 2.1em; -} -body.index.home .front-page .action-box { - border-radius: 20px; - background: #FFF7C0; -} -body.index.home .front-page .action-box-inner { - padding: 0 20px 20px; - min-height: 13.4em; -} -body.index.home .front-page .action-box-inner :last-child { - margin-bottom: 0; -} -body.index.home .front-page .action-box-inner.collaborate { - background:url(../img/collaborate.png) no-repeat right top; -} -body.index.home .front-page .action-box-inner.share { - background:url(../img/share.png) no-repeat right top; -} -body.index.home .front-page .action-box-inner.find { - background:url(../img/find.png) no-repeat right top; -} -body.index.home .front-page .action-box-inner a { - font-weight: bold; -} -body.index.home .front-page .action-box-inner input { - font-family: 'Ubuntu'; - border-radius: 10px; - background-color: #fff; - font-size: 1.3em; - width: 90%; - border: 1px solid #999; - color: #666; - padding: 0.5em; - display: inline-block; - margin-right: 5px; - margin-bottom: 10px; - line-height: 16px; -} -body.index.home .front-page .action-box-inner .create-button { - display: block; - float: right; - font-weight: normal; - font-family: 'Ubuntu'; - border-radius: 10px; - background-color: #B22; - border: 0px; - font-size: 1.3em; - color: #fff; - padding: 0.5em; -} -body.index.home .front-page .action-box-inner .create-button:hover { - background-color: #822; -} -body.index.home .front-page .action-box-inner ul { - margin-top: 1em; - margin-bottom: 0; -} -body.index.home .front-page .whoelse { - margin-top: 1em; -} -body.index.home .front-page .group { - overflow: hidden; -} -body.index.home .front-page .group h3 { - margin-bottom: 0.5em; -} -body.index.home .front-page .group p { - margin-bottom: 0em; - min-height: 6em; -} -body.index.home .front-page .group strong { - display: block; - margin-bottom: 1.5em; -} - - -/* ======================== */ -/* Search Page: Filter List */ -/* ======================== */ -.filter-list { - display: inline-block; - margin-right: 5px; - margin-bottom: 10px; - padding: 2px 2px 4px 3px; - font-size: 14px; - background-color: #FFF7C0; - -moz-border-radius: 3px; - -webkit-border-radius: 3px; - border-radius: 3px; - line-height: 16px; -} -.filter-list img { - margin-bottom: -3px; -} -.filter-list .name::after { - content: ":"; -} -.filter-list .value { - font-weight: bold; -} - - -/* ============== */ -/* = Login Form = */ -/* ============== */ -form.simple-form label { - display: inline-block; - float: left; - min-width: 40%; - padding-top: 0.5em; - padding-bottom: 1em; -} -form.simple-form input[type=text], -form.simple-form input[type=password] { - border: 1px solid #E7E7E7; - padding: 0.5em; - width: 40%; - margin-bottom: 1em -} - - -/* ================================== */ -/* = Dataset/Group View: Sidebar List */ -/* ================================== */ -.property-list { - list-style-type: none; - padding-left: 3em; -} -.property-list li { - margin-bottom: 0.2em; - list-style-type: none; -} -.property-list li ul { - margin-left: -1.5em; -} -.property-list li h3 { - font-size: 1.1em; - margin-bottom: 0.5em; - margin-left: -2em; -} -/* Fix the indented headings on the groups page */ -.group.read .property-list { - margin-left: 0; - padding-left: 0; -} -.group.read .property-list li h3, -.group.read .property-list li ul { - margin-left: 0; -} -.group-dataset-list { - margin: 2em 0; -} - -.group-search-box input[type="search"] { - width: 100%; - margin-bottom: 20px; -} -.group-search-box input[type="submit"] { - float: right; -} - - -/* ============== */ -/* = User Index = */ -/* ============== */ - -ul.userlist, -ul.userlist ul { - list-style-type: none; - margin: 0; - padding: 0; -} -ul.userlist li.user { - display: inline-block; - width: 200px; - margin-bottom: 15px; -} -ul.userlist li ul span.edits { - color: #333; - font-size: 1.1em; - font-weight: bold; - margin-left: 3px; -} -ul.userlist .username img { - margin: 0 5px -6px 0; - border-radius: 3px; -} -ul.userlist .created { - color: #888; -} -ul.userlist .badge { - color: #fc0; -} -.user-search input[type=text], -.user-search input[type=password] { - width: 70%; - margin-top: 5px; -} - -/* ================================= */ -/* = User Read and Dashboard pages = */ -/* ================================= */ - -body.user.read #sidebar { display: none; } -body.user.read #content { - border-right: 0; - width: 950px; -} - -.user.read .page_heading, .user.dashboard .page_heading { - font-weight: bold; -} - -.user.read .page_heading img.gravatar, .user.dashboard .page_heading img.gravatar { - padding: 2px; - border: solid 1px #ddd; - vertical-align: middle; - margin-right: 5px; - margin-top: -3px; -} - -.user.read .page_heading .fullname, .user.dashboard .page_heading .fullname { - font-weight: normal; - color: #999; -} - -.user.read .rule { - clear: both; - margin-bottom: 15px; - padding-top: 20px; - border-bottom: 1px solid #ddd; -} - -.vcard dt { - width: 115px; - float: left; - font-weight: normal; - color: #999; -} - -.vcard dd { - margin-left: 115px; -} - -.user.read ul.stats { - margin-left: 0; - padding-left: 0; -} - -.user.read ul.stats li { - display: inline-block; - color: inherit; - width: 115px; -} - -.user.read ul.stats li strong { - font-size: 36px; - display: block; - line-height: 35px; -} - -.user.read ul.stats li span { - color: #999; -} - -.user.read .listing div.datasets .datasets { - padding-right: 15px; -} - -.user.read .listing .changes { -} - - -/* ========================= */ -/* = Dataset Snapshot View = */ -/* ========================= */ -.state-deleted, .state-deleted a, .state-deleted * { - color: rgba(0, 0, 0, 0.4); -} -.state-deleted { - padding-left: 3px; -} -.state-deleted:hover * { - color: rgba(0, 0, 0, 0.8); -} -.state-notice { - text-transform: uppercase; - font-size: 120%; - background: #aaa; - padding: 15px; - text-align: center; - color: #fff; -} - - -/* =============== */ -/* = Search Page = */ -/* =============== */ -body.package.search #menusearch { - display: none; -} -.dataset-search { - margin-bottom: 35px; -} -input.search { - width: 380px; - float: left; - font-size: 1.2em; - margin: 0px; - border: 1px solid #ccc; - padding: 0.6em 0.5em 0.6em 5px; - font-weight: bold; - -moz-border-radius: 5px; - -webkit-border-radius: 5px; - border-radius: 5px; - -moz-background-clip: padding; - -webkit-background-clip: padding-box; - background-clip: padding-box; -} -.dataset-search input.button { - display: inline-block; - float: left; - margin-left: 9px; -} - - -/* ======================================== */ -/* = Dataset listing (eg. search results) = */ -/* ======================================== */ -/* TODO strip and use .search-result class in markup everywhere */ -ul.datasets { - padding-left: 0; - margin: 0 0 1em 0; -} -ul.datasets li { - list-style: none; - padding: 1em 0 0.2em 0.0em; - border-bottom: 1px solid #ececec; - overflow: hidden; -} -ul.datasets li .header { - padding-top: 0.5em; - font-weight: bold; - font-size: 1.1em; -} -ul.datasets li .extract { - padding-top: 0.3em; -} -ul.datasets li a { - text-decoration: none; -} -ul.datasets li img { - margin-bottom: -2px; -} -ul.datasets .search_meta { - float:right; -} -ul.datasets ul.dataset_formats { - float: right; - padding: 0 0 3px 0; - margin: 0; - font-family: monospace; -} -ul.datasets ul.dataset_formats li { - display: inline; - margin: 0; - padding: 0 5px 0 5px; - border: none; - font-weight: normal; - font-size: 0.9em; - color: #808080; - background:#ececec; -} -ul.datasets .openness { - clear:right; - float:right; - font-size:0.8em; -} -ul.datasets .openness img { - vertical-align:top; -} -ul.datasets .openness li { - margin:0; - padding:0; - border:none; -} - - -/* =================== */ -/* = Markdown Editor = */ -/* =================== */ -.markdown-editor { - background: #EEE; - border-radius: 5px 5px; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border: 1px solid #CCC; - padding: 0 5px 5px 10px; - width: 32em; -} -.markdown-editor .button-row { - padding-right: 40px; - text-align: center; -} -.markdown-editor div.markdown-preview { - background: white; - border: 1px solid #CCC; - padding: 5px; - margin-bottom: 5px; - overflow: auto; -} -.markdown-editor textarea.markdown-input { - display: block; - width: 360px; - height: 70px; - margin: 0 0 5px 0; - padding: 5px; -} - - - -/* ============= */ -/* = Mini-Tabs = */ -/* ============= */ -ul.button-row { - margin-top: 5px; - margin-bottom: 5px; -} -ul.button-row li { - display: inline; - margin-right: 10px; -} - - -/* ===================== */ -/* = Edit Dataset Page = */ -/* ===================== */ -.dataset-edit-form button.dataset-delete { - vertical-align: middle; -} -.dataset-edit-form fieldset#summary { - border-top: 1px solid #ccc; - padding-top: 15px; -} -.dataset-edit-tabs ul.nav { - min-width: 180px; - margin-right: -1px; - background: #fff; -} -.dataset-edit-tabs form { - border: 1px solid #DDD; -} -.dataset-edit-tabs form > div, -.dataset-edit-tabs form > fieldset { - padding: 18px; -} -hr.extras-divider { - border: none; - border-bottom: 1px dashed #ddd; -} -span.extras-label { - display: inline-block; - min-width: 50px; - text-align: right; -} - - -/* ======================= */ -/* = Edit Resources Page = */ -/* ======================= */ -.dataset-editresources-form fieldset { - display: none; -} -.dataset-editresources-form fieldset#resources, -.dataset-editresources-form fieldset#summary { - display: block; -} - -.dataset-editresources-form .resource-add .fileinfo { - margin: 7px 0; -} -.name-field { - padding-top: 0.2em; -} -.name-field p { - margin: 2px 0; -} -.description-field textarea { - width: 400px; - height: 70px; -} -.resource-add > .nav { - margin-bottom: 0; - width: 522px; -} -.resource-add .tab-pane { - padding: 20px; - background: #fff; - border: 1px solid #DDD; - border-top: none; - width: 480px; - -} - -/* ==================== */ -/* = Add Dataset Page = */ -/* ==================== */ -.dataset-create-form fieldset { - /* Show only one field */ - display: none; -} -.dataset-create-form fieldset#basic-information, -.dataset-create-form fieldset#resources, -.dataset-create-form fieldset#summary { - display: block; -} -.dataset-create-form .homepage-field, -.dataset-create-form .tags-field { - display: none; -} -#license-instructions { - font-size: 11px; -} - -.group-create-form dd.name-field { - padding-top: 0.2em; -} -.group-create-form dd.name-field p { - margin-bottom: 4px; -} - -a.url-edit { - font-weight: normal; - margin-left: 10px; -} -p.url-is-long { - color: #600; - display: none; - font-size: 11px; - font-weight: bold; -} -div.author-box, -label.edit-summary { - font-size: 11px; - color: #666; -} -#log_message { - height: 40px; - width: 400px; - color: #666; - font-size: 11px; -} -#log_message:focus { - color: #000; -} - - -/* ===================== */ -/* = Dataset View Page = */ -/* ===================== */ -body.package.read .sidebar-section { - margin-bottom: 2em; -} -body.package.read .tags, body.package.read .groups { - padding: 0; -} -body.package.read .tags li, body.package.read .groups li { - list-style-type: none; - display: inline-block; - padding: 3px 3px 3px 0px; - margin-right: 6px; - padding:0 5px 2px 5px; - border:none; - font-weight:normal; - font-size:0.8em; - background:#afc6e9; -} -body.package.read .tags a, body.package.read .groups a { - color: black; -} -body.package.read .tags li:hover, -body.package.read .groups li:hover { - background: #bdf; -} -body.package.read .related-datasets { - padding: 0; -} -body.package.read .related-datasets li { - list-style-type: none; -} - -img.open-data { margin: 1px 0 0 8px; vertical-align: top; } -#dataset-resources { - margin-top: 2em; - margin-bottom: 2em; -} -body.package.read h3 { - margin-bottom: 8px; -} -.search-result { - border-left: 2px solid #eee; - margin: 0; - padding: 8px; - margin-bottom: 16px; -} -.search-result:hover { - border-left: 2px solid #aaa; - background: #f7f7f7; -} - -.search-result .main-link { - font-size: 125%; -} -.search-result .extra-links { - float: right; - text-align: right; -} -.search-result .view-more-link { - color: #000; - display: block; - margin-top: 4px; - padding: 3px 22px 3px 10px; - background: url('../images/icons/arrow-right-16-black.png') no-repeat right; - opacity:0.4; - filter:alpha(opacity=40); /* For IE8 and earlier */ -} -.search-result .view-more-link:hover { - opacity:1.0; - filter:alpha(opacity=100); /* For IE8 and earlier */ - text-decoration: underline; -} - -.search-result .result-url, -.search-result .result-url a { - color: #888; -} -.search-result .result-lrl:hover, -.search-result .result-url:hover a { - color: #333; -} -.search-result .result-url:hover a { - text-decoration: underline; -} -.search-result .result-url img { - opacity: 0.5; -} -.search-result .result-url:hover img { - opacity: 1.0; -} -.search-result p { - margin: 0; -} -.resource-url-cached { - font-size: 0.9em; -} - -body.package.read .resource-information { - color: #808080; -} -.format-box { - border: 1px solid #EEE; - margin-left: 8px; - padding: 2px 8px; - box-shadow: 1px 1px 3px #f7f7f7; - color: #808080; -} -body.package.read #sidebar li.widget-container { - border: 0 -} -.notes { - background: url('../images/ldquo.png') no-repeat top left #f7f7f7; - border: 1px solid #eee; - border-radius: 5px; -} -.notes > div { - padding: 8px; -} -#notes-toggle { - padding: 0; - height: 23px; -} -.notes #notes-toggle button { - cursor: pointer; - width: 100%; - height: 23px; - padding: 4px; - border-radius: 0; - border: 0; - border-top: 1px solid #eee; -} -#notes-extract p { - margin-bottom: 0; -} -#notes-remainder { - overflow: hidden; - padding: 0 8px; -} -#notes-remainder p:last-child { - margin-bottom: 0; -} -.dataset-label { - font-weight: bold; - min-width: 10em; -} - - -/* ====================== */ -/* = Resource View Page = */ -/* ====================== */ - -body.package.resource_read #sidebar { display: none; } -body.package.resource_read #content { - border-right: 0; - width: 940px; -} - -.resource_read .notes { - margin-bottom: 1em; - font-size: 110%; -} - -.resource_read .quick-info dt { - width: 115px; - float: left; - font-weight: normal; - color: gray; -} - -.resource_read .resource-actions { - float: right; - text-align: right; -} - -body.package.resource_read #dataset-description { margin-bottom: 2em; } -body.package.resource_read #resource-explore { margin-bottom: 2em; } - - -/* ================== */ -/* = Add Group Page = */ -/* ================== */ -.group-create-form .state-field, -.group-create-form fieldset { - display: none; -} -.group-create-form fieldset#basic-information, -.group-create-form fieldset#summary { - display: block; -} - - -/* ============== */ -/* = About Page = */ -/* ============== */ -body.about #content { border-right: 0; } - - -/* ============== */ -/* = Admin Page = */ -/* ============== */ -body.admin form#form-purge-packages, -body.admin form#form-purge-revisions { - margin-bottom: 30px; - text-align: right; -} - - -/* ======================= */ -/* = Authorization Pages = */ -/* ======================= */ -body.authz form { - margin-bottom: 30px; - text-align: right; -} -body.authz form button { - min-width: 120px; -} - - -/* ================== */ -/* :: QUESTIONABLE :: */ -/* ================== */ -.dataset .api div { - background:#f0f0f0; - padding:10px; -} -.dataset .api h5 { - font-weight:bold; - margin-bottom:1em!important; - font-size:1em; -} -.dataset .api code { - background:#444; - color:#fff; - padding:3px 10px ; - margin-bottom:1em; - display:block; -} -.dataset .api code a { - color:#fff; -} - -/* ==================== */ -/* = Activity Streams = */ -/* ==================== */ -.activity-stream .activity { - padding-bottom:1em; -} -.activity-stream .activity a { - font-weight:bold; -} -.activity-stream .activity .verb { - background-color:PapayaWhip; - padding:.25em; - margin:.25em; -} -.activity-stream .activity .date { - color:#999; -} - -/* ===================== */ -/* == Resource Editor == */ -/* ===================== */ -fieldset#resources { - margin-bottom: 40px; - padding: 0; -} -body.editresources fieldset#resources > legend, -body.editresources fieldset#resources > .instructions { - display: none; -} -fieldset#resources > .instructions { - padding: 12px 12px 2px 12px; -} -.resource-list { - list-style-type: none; - padding: 0; - margin: 0; -} -.resource-list li { - white-space: nowrap; - overflow: hidden; - background: #fff; - border-right: 1px solid transparent; - border-left: 1px solid transparent; - border-top: 1px solid transparent; - border-bottom: 1px solid #eee; - margin-bottom: 0; - position: relative; - z-index: 1; -} -.resource-list li:hover { - background-color: #f7f7f7; -} -.resource-list li:last-child { - border-bottom-color: transparent; -} -.resource-list li.active { - border-color: #888; - border-right-color: #f9f9f9; - background-color: #f9f9f9; - margin-right: -21px; -} -/**/ -.resource-list li a { - display: block; - padding: 5px 10px; - color: #333; - border-right: 0; - font-weight: bold; -} -.resource-list li a:hover { - color: #B22; - text-decoration: none; -} - -/* Resource-list-edit */ -.resource-list-edit { - padding-top: 10px; -} -/* While dragging.... */ -.resource-list-edit li.ui-sortable-helper { - border-color: #888; - box-shadow: 2px 2px 8px rgba(0,0,0,0.1); -} - -/* Resource-list-add */ -.resource-list-add { - margin-top: 20px; -} -.resource-list-add li { - border-top: 1px solid #eee; - padding-left: 43px; -} - -/* Right-hand-side edit resource panel */ -.resource-panel { - background: #f9f9f9; - border: 1px solid #888; - padding: 10px 20px; - position: relative; -} -.resource-panel .resource-panel-close { - position: absolute; - right: -8px; - top: -12px; - width: 20px; - padding: 0; - text-align: center; -} -.resource-panel input[type="text"] { - width: 397px; -} -.resource-panel .markdown-editor { - width: 390px; -} -.resource-panel textarea { - height: 90px; -} -.resource-panel .control-group { - margin-bottom: 3px; -} -.resource-panel .hint { - font-size: 11px; -} -.resource-panel .resource-add { - min-height: 140px; - margin-bottom: 30px; -} -.resource-panel .resource-add input[type="text"] { - width: 280px; -} - -/* Resource extra fields */ -/* --------------------- */ -.dynamic-extras .dynamic-extra { - margin: 1px 15px; -} -.dynamic-extras .remove-resource-extra { - padding: 0 7px; - font-size: 8px; -} -.dynamic-extras input.strikethrough { - text-decoration: line-through; -} -.dynamic-extras input[type="text"] { - width: 164px; -} - - -button.resource-edit-delete { - margin-top: 10px; - float: right; -} - - - -/* HasErrors */ -.resource-list li.hasErrors { - border-color: #c00; - border-right: 1px solid #c00; -} -.resource-list li.active.hasErrors { - border-right: 0; -} -.resource-list li.hasErrors a { - color: #c00; -} -.resource-errors { - display: none; -} -.resource-errors dl { - margin-bottom: 0; -} -body.editresources .error-explanation { - /* Let JS render the resource errors inline */ - display: none; -} - -/* Modal Dialog Styles */ - -.modal-header .heading { - margin-bottom: 0; -} - -.modal-body form { - margin-bottom: 0; -} - -.popover-title { - margin-bottom: 0; -} - -.popover-inner { - background: #aaa; -} - -.popover.right .arrow { - border-right-color: #aaa; -} - -/* Chosen Form Styles */ - -.chzn-container-single { - margin-bottom: 9px; /* Keep Chosen inline with Bootstrap */ -} - -.form-inline .chzn-container-single, -.form-horizontal .chzn-select { - margin-bottom: 0; -} - -.required { - color: #808080; -} - -.related-help { - opacity: 0.3; - position: relative; - top: 2px; - cursor: pointer; -} - -.thumbnails li { - z-index: 0; - position: relative; - background-color: #fff; -} - -.thumbnails li:nth-of-type(5n) { - clear: left; -} - -.thumbnails li.expanded-description { - z-index: 1; -} - -.thumbnail .heading { - font-weight: bold; -} - -.thumbnail .image { - display: block; - width: 210px; - height: 180px; - overflow: hidden; - background: #ececec; - border: 1px solid #dedede; - margin: -1px; -} - -.thumbnail .image img { - max-width: 100%; - width: auto; - height: auto; -} - -.thumbnail .close { - padding-bottom: 7px; - padding-top: 2px; - position: relative; - top: -1px; - right: -1px; - display: none; -} - -.thumbnail:hover .close { - display: block; -} - -.thumbnail .empty { - color: #ccc; -} - -.thumbnail .read-more { - margin-top: 10px; - margin-bottom: 0; -} - -.no-related-items { - font-size: 16px; - color: #666; - background: #EBEBEB; - border: 1px solid #DBDBDB; - padding: 20px; - border-radius: 5px; - margin: 40px auto; - float: none; - text-align: center; -} diff --git a/ckan/public/images/bullet_separator.png b/ckan/public/images/bullet_separator.png deleted file mode 100644 index aa368638fa3..00000000000 Binary files a/ckan/public/images/bullet_separator.png and /dev/null differ diff --git a/ckan/public/images/button-shadow.png b/ckan/public/images/button-shadow.png deleted file mode 100644 index e842365ddcc..00000000000 Binary files a/ckan/public/images/button-shadow.png and /dev/null differ diff --git a/ckan/public/images/chevron-down.png b/ckan/public/images/chevron-down.png deleted file mode 100644 index 8d6c121eb9b..00000000000 Binary files a/ckan/public/images/chevron-down.png and /dev/null differ diff --git a/ckan/public/images/chevron-up.png b/ckan/public/images/chevron-up.png deleted file mode 100644 index 78b0290d06d..00000000000 Binary files a/ckan/public/images/chevron-up.png and /dev/null differ diff --git a/ckan/public/images/chosen-sprite.png b/ckan/public/images/chosen-sprite.png deleted file mode 100644 index 231fe905534..00000000000 Binary files a/ckan/public/images/chosen-sprite.png and /dev/null differ diff --git a/ckan/public/images/ckan_logo_fullname_long.png b/ckan/public/images/ckan_logo_fullname_long.png deleted file mode 100644 index 182a288da48..00000000000 Binary files a/ckan/public/images/ckan_logo_fullname_long.png and /dev/null differ diff --git a/ckan/public/images/dlbg.png b/ckan/public/images/dlbg.png deleted file mode 100644 index f77e7ada640..00000000000 Binary files a/ckan/public/images/dlbg.png and /dev/null differ diff --git a/ckan/public/images/dragbars.png b/ckan/public/images/dragbars.png deleted file mode 100644 index ef6a8d60dff..00000000000 Binary files a/ckan/public/images/dragbars.png and /dev/null differ diff --git a/ckan/public/images/icons/add.png b/ckan/public/images/icons/add.png deleted file mode 100644 index 6332fefea4b..00000000000 Binary files a/ckan/public/images/icons/add.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow-closed.gif b/ckan/public/images/icons/arrow-closed.gif deleted file mode 100644 index b247824e904..00000000000 Binary files a/ckan/public/images/icons/arrow-closed.gif and /dev/null differ diff --git a/ckan/public/images/icons/arrow-down-16.png b/ckan/public/images/icons/arrow-down-16.png deleted file mode 100644 index 2b9732a9cc6..00000000000 Binary files a/ckan/public/images/icons/arrow-down-16.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow-down-32.png b/ckan/public/images/icons/arrow-down-32.png deleted file mode 100644 index 00c085f6def..00000000000 Binary files a/ckan/public/images/icons/arrow-down-32.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow-open.gif b/ckan/public/images/icons/arrow-open.gif deleted file mode 100644 index e1c60aa558e..00000000000 Binary files a/ckan/public/images/icons/arrow-open.gif and /dev/null differ diff --git a/ckan/public/images/icons/arrow-right-16-black.png b/ckan/public/images/icons/arrow-right-16-black.png deleted file mode 100644 index 5096d9e2b29..00000000000 Binary files a/ckan/public/images/icons/arrow-right-16-black.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow-right-16.png b/ckan/public/images/icons/arrow-right-16.png deleted file mode 100644 index 102269baf89..00000000000 Binary files a/ckan/public/images/icons/arrow-right-16.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow-right-32.png b/ckan/public/images/icons/arrow-right-32.png deleted file mode 100644 index f68956e02a5..00000000000 Binary files a/ckan/public/images/icons/arrow-right-32.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow_down.png b/ckan/public/images/icons/arrow_down.png deleted file mode 100644 index 2c4e279377b..00000000000 Binary files a/ckan/public/images/icons/arrow_down.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow_down_grey.png b/ckan/public/images/icons/arrow_down_grey.png deleted file mode 100644 index 2443111c7a9..00000000000 Binary files a/ckan/public/images/icons/arrow_down_grey.png and /dev/null differ diff --git a/ckan/public/images/icons/arrow_up.png b/ckan/public/images/icons/arrow_up.png deleted file mode 100644 index 1ebb1932437..00000000000 Binary files a/ckan/public/images/icons/arrow_up.png and /dev/null differ diff --git a/ckan/public/images/icons/atom_feed.png b/ckan/public/images/icons/atom_feed.png deleted file mode 100644 index c7ea44727d0..00000000000 Binary files a/ckan/public/images/icons/atom_feed.png and /dev/null differ diff --git a/ckan/public/images/icons/ckan.ico b/ckan/public/images/icons/ckan.ico deleted file mode 100644 index 0d9295c77aa..00000000000 Binary files a/ckan/public/images/icons/ckan.ico and /dev/null differ diff --git a/ckan/public/images/icons/comments.png b/ckan/public/images/icons/comments.png deleted file mode 100644 index 39433cf78a3..00000000000 Binary files a/ckan/public/images/icons/comments.png and /dev/null differ diff --git a/ckan/public/images/icons/delete.png b/ckan/public/images/icons/delete.png deleted file mode 100755 index 1514d51a3cf..00000000000 Binary files a/ckan/public/images/icons/delete.png and /dev/null differ diff --git a/ckan/public/images/icons/door.png b/ckan/public/images/icons/door.png deleted file mode 100644 index 369fc46ed25..00000000000 Binary files a/ckan/public/images/icons/door.png and /dev/null differ diff --git a/ckan/public/images/icons/door_grey.png b/ckan/public/images/icons/door_grey.png deleted file mode 100644 index aaf93184261..00000000000 Binary files a/ckan/public/images/icons/door_grey.png and /dev/null differ diff --git a/ckan/public/images/icons/door_open.png b/ckan/public/images/icons/door_open.png deleted file mode 100644 index 64bab57ddd0..00000000000 Binary files a/ckan/public/images/icons/door_open.png and /dev/null differ diff --git a/ckan/public/images/icons/drive_web.png b/ckan/public/images/icons/drive_web.png deleted file mode 100644 index 8850a83557e..00000000000 Binary files a/ckan/public/images/icons/drive_web.png and /dev/null differ diff --git a/ckan/public/images/icons/edit-collapse.png b/ckan/public/images/icons/edit-collapse.png deleted file mode 100755 index cee4c74bda4..00000000000 Binary files a/ckan/public/images/icons/edit-collapse.png and /dev/null differ diff --git a/ckan/public/images/icons/edit-expand.png b/ckan/public/images/icons/edit-expand.png deleted file mode 100755 index 72a5235d004..00000000000 Binary files a/ckan/public/images/icons/edit-expand.png and /dev/null differ diff --git a/ckan/public/images/icons/error.png b/ckan/public/images/icons/error.png deleted file mode 100644 index 628cf2dae3d..00000000000 Binary files a/ckan/public/images/icons/error.png and /dev/null differ diff --git a/ckan/public/images/icons/followers.png b/ckan/public/images/icons/followers.png deleted file mode 100644 index 7fb4e1f1e1c..00000000000 Binary files a/ckan/public/images/icons/followers.png and /dev/null differ diff --git a/ckan/public/images/icons/group.png b/ckan/public/images/icons/group.png deleted file mode 100755 index abcd93689a0..00000000000 Binary files a/ckan/public/images/icons/group.png and /dev/null differ diff --git a/ckan/public/images/icons/group_add.png b/ckan/public/images/icons/group_add.png deleted file mode 100755 index 2a3e5c4df14..00000000000 Binary files a/ckan/public/images/icons/group_add.png and /dev/null differ diff --git a/ckan/public/images/icons/group_edit.png b/ckan/public/images/icons/group_edit.png deleted file mode 100755 index bfcb0249afd..00000000000 Binary files a/ckan/public/images/icons/group_edit.png and /dev/null differ diff --git a/ckan/public/images/icons/key.png b/ckan/public/images/icons/key.png deleted file mode 100644 index 4ec1a928140..00000000000 Binary files a/ckan/public/images/icons/key.png and /dev/null differ diff --git a/ckan/public/images/icons/lock.png b/ckan/public/images/icons/lock.png deleted file mode 100644 index 2ebc4f6f966..00000000000 Binary files a/ckan/public/images/icons/lock.png and /dev/null differ diff --git a/ckan/public/images/icons/magnifier.png b/ckan/public/images/icons/magnifier.png deleted file mode 100644 index cf3d97f75e9..00000000000 Binary files a/ckan/public/images/icons/magnifier.png and /dev/null differ diff --git a/ckan/public/images/icons/note.png b/ckan/public/images/icons/note.png deleted file mode 100644 index 244e6ca045c..00000000000 Binary files a/ckan/public/images/icons/note.png and /dev/null differ diff --git a/ckan/public/images/icons/openid.png b/ckan/public/images/icons/openid.png deleted file mode 100644 index 2829b00358e..00000000000 Binary files a/ckan/public/images/icons/openid.png and /dev/null differ diff --git a/ckan/public/images/icons/package-disabled.png b/ckan/public/images/icons/package-disabled.png deleted file mode 100644 index beac3e99cd0..00000000000 Binary files a/ckan/public/images/icons/package-disabled.png and /dev/null differ diff --git a/ckan/public/images/icons/package.png b/ckan/public/images/icons/package.png deleted file mode 100644 index da3c2a2d74b..00000000000 Binary files a/ckan/public/images/icons/package.png and /dev/null differ diff --git a/ckan/public/images/icons/package_add.png b/ckan/public/images/icons/package_add.png deleted file mode 100755 index 9c8a9da4ae4..00000000000 Binary files a/ckan/public/images/icons/package_add.png and /dev/null differ diff --git a/ckan/public/images/icons/package_edit.png b/ckan/public/images/icons/package_edit.png deleted file mode 100644 index 96b9a24896f..00000000000 Binary files a/ckan/public/images/icons/package_edit.png and /dev/null differ diff --git a/ckan/public/images/icons/page_stack.png b/ckan/public/images/icons/page_stack.png deleted file mode 100644 index a6c8e5c6777..00000000000 Binary files a/ckan/public/images/icons/page_stack.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white.png b/ckan/public/images/icons/page_white.png deleted file mode 100755 index 8b8b1ca0000..00000000000 Binary files a/ckan/public/images/icons/page_white.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_add.png b/ckan/public/images/icons/page_white_add.png deleted file mode 100755 index aa23dde3746..00000000000 Binary files a/ckan/public/images/icons/page_white_add.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_code.png b/ckan/public/images/icons/page_white_code.png deleted file mode 100755 index 0c76bd12977..00000000000 Binary files a/ckan/public/images/icons/page_white_code.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_compressed.png b/ckan/public/images/icons/page_white_compressed.png deleted file mode 100755 index 2b6b1007f33..00000000000 Binary files a/ckan/public/images/icons/page_white_compressed.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_cup.png b/ckan/public/images/icons/page_white_cup.png deleted file mode 100755 index 0a7d6f4a6f6..00000000000 Binary files a/ckan/public/images/icons/page_white_cup.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_database.png b/ckan/public/images/icons/page_white_database.png deleted file mode 100755 index bddba1f98ca..00000000000 Binary files a/ckan/public/images/icons/page_white_database.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_error.png b/ckan/public/images/icons/page_white_error.png deleted file mode 100755 index 9fc5a0a103d..00000000000 Binary files a/ckan/public/images/icons/page_white_error.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_excel.png b/ckan/public/images/icons/page_white_excel.png deleted file mode 100755 index b977d7e52e2..00000000000 Binary files a/ckan/public/images/icons/page_white_excel.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_gear.png b/ckan/public/images/icons/page_white_gear.png deleted file mode 100755 index 106f5aa3611..00000000000 Binary files a/ckan/public/images/icons/page_white_gear.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_json.png b/ckan/public/images/icons/page_white_json.png deleted file mode 100644 index 237ae52abb1..00000000000 Binary files a/ckan/public/images/icons/page_white_json.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_link.png b/ckan/public/images/icons/page_white_link.png deleted file mode 100755 index bf7bd1c9bfd..00000000000 Binary files a/ckan/public/images/icons/page_white_link.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_rdf.png b/ckan/public/images/icons/page_white_rdf.png deleted file mode 100644 index d623d8abc06..00000000000 Binary files a/ckan/public/images/icons/page_white_rdf.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_stack.png b/ckan/public/images/icons/page_white_stack.png deleted file mode 100644 index 44084add79b..00000000000 Binary files a/ckan/public/images/icons/page_white_stack.png and /dev/null differ diff --git a/ckan/public/images/icons/page_white_text.png b/ckan/public/images/icons/page_white_text.png deleted file mode 100755 index 813f712f726..00000000000 Binary files a/ckan/public/images/icons/page_white_text.png and /dev/null differ diff --git a/ckan/public/images/icons/pencil.png b/ckan/public/images/icons/pencil.png deleted file mode 100755 index 0bfecd50ee9..00000000000 Binary files a/ckan/public/images/icons/pencil.png and /dev/null differ diff --git a/ckan/public/images/icons/remove.png b/ckan/public/images/icons/remove.png deleted file mode 100644 index 08f249365af..00000000000 Binary files a/ckan/public/images/icons/remove.png and /dev/null differ diff --git a/ckan/public/images/icons/star.png b/ckan/public/images/icons/star.png deleted file mode 100755 index 8cea494e2fa..00000000000 Binary files a/ckan/public/images/icons/star.png and /dev/null differ diff --git a/ckan/public/images/icons/tag_blue.png b/ckan/public/images/icons/tag_blue.png deleted file mode 100644 index 9757fc6ed65..00000000000 Binary files a/ckan/public/images/icons/tag_blue.png and /dev/null differ diff --git a/ckan/public/images/icons/unfilter.png b/ckan/public/images/icons/unfilter.png deleted file mode 100755 index bd6271b2467..00000000000 Binary files a/ckan/public/images/icons/unfilter.png and /dev/null differ diff --git a/ckan/public/images/icons/user.png b/ckan/public/images/icons/user.png deleted file mode 100644 index 79f35ccbdad..00000000000 Binary files a/ckan/public/images/icons/user.png and /dev/null differ diff --git a/ckan/public/images/icons/user_grey.png b/ckan/public/images/icons/user_grey.png deleted file mode 100644 index 8fd539e9cb0..00000000000 Binary files a/ckan/public/images/icons/user_grey.png and /dev/null differ diff --git a/ckan/public/images/icons/world_go.png b/ckan/public/images/icons/world_go.png deleted file mode 100644 index aee9c97f823..00000000000 Binary files a/ckan/public/images/icons/world_go.png and /dev/null differ diff --git a/ckan/public/images/ldquo.png b/ckan/public/images/ldquo.png deleted file mode 100644 index 286f719f3a1..00000000000 Binary files a/ckan/public/images/ldquo.png and /dev/null differ diff --git a/ckan/public/images/photo-placeholder.png b/ckan/public/images/photo-placeholder.png deleted file mode 100644 index efdea70ea20..00000000000 Binary files a/ckan/public/images/photo-placeholder.png and /dev/null differ diff --git a/ckan/public/images/stars.png b/ckan/public/images/stars.png deleted file mode 100644 index 21e3b7fee19..00000000000 Binary files a/ckan/public/images/stars.png and /dev/null differ diff --git a/ckan/public/img/collaborate.png b/ckan/public/img/collaborate.png deleted file mode 100644 index dff90f1d890..00000000000 Binary files a/ckan/public/img/collaborate.png and /dev/null differ diff --git a/ckan/public/img/find.png b/ckan/public/img/find.png deleted file mode 100644 index 133102ada8c..00000000000 Binary files a/ckan/public/img/find.png and /dev/null differ diff --git a/ckan/public/img/glyphicons-halflings-white.png b/ckan/public/img/glyphicons-halflings-white.png deleted file mode 100644 index 3bf6484a29d..00000000000 Binary files a/ckan/public/img/glyphicons-halflings-white.png and /dev/null differ diff --git a/ckan/public/img/glyphicons-halflings.png b/ckan/public/img/glyphicons-halflings.png deleted file mode 100644 index 79bc568c213..00000000000 Binary files a/ckan/public/img/glyphicons-halflings.png and /dev/null differ diff --git a/ckan/public/img/lod2.png b/ckan/public/img/lod2.png deleted file mode 100644 index 9cdf946c6de..00000000000 Binary files a/ckan/public/img/lod2.png and /dev/null differ diff --git a/ckan/public/img/logo.png b/ckan/public/img/logo.png deleted file mode 100644 index b759085234a..00000000000 Binary files a/ckan/public/img/logo.png and /dev/null differ diff --git a/ckan/public/img/logo_64px_wide.png b/ckan/public/img/logo_64px_wide.png deleted file mode 100644 index 967144ee0ff..00000000000 Binary files a/ckan/public/img/logo_64px_wide.png and /dev/null differ diff --git a/ckan/public/img/share.png b/ckan/public/img/share.png deleted file mode 100644 index a97a0317980..00000000000 Binary files a/ckan/public/img/share.png and /dev/null differ diff --git a/ckan/public/scripts/application.js b/ckan/public/scripts/application.js deleted file mode 100644 index f61a1a3ac51..00000000000 --- a/ckan/public/scripts/application.js +++ /dev/null @@ -1,1869 +0,0 @@ -var CKAN = CKAN || {}; - -CKAN.View = CKAN.View || {}; -CKAN.Model = CKAN.Model || {}; -CKAN.Utils = CKAN.Utils || {}; - -/* ================================= */ -/* == Initialise CKAN Application == */ -/* ================================= */ -(function ($) { - $(document).ready(function () { - CKAN.Utils.relatedSetup($("#form-add-related")); - CKAN.Utils.setupUserAutocomplete($('input.autocomplete-user')); - CKAN.Utils.setupOrganizationUserAutocomplete($('input.autocomplete-organization-user')); - CKAN.Utils.setupGroupAutocomplete($('input.autocomplete-group')); - CKAN.Utils.setupPackageAutocomplete($('input.autocomplete-dataset')); - CKAN.Utils.setupTagAutocomplete($('input.autocomplete-tag')); - $('input.autocomplete-format').live('keyup', function(){ - CKAN.Utils.setupFormatAutocomplete($(this)); - }); - CKAN.Utils.setupMarkdownEditor($('.markdown-editor')); - // bootstrap collapse - $('.collapse').collapse({toggle: false}); - - // Buttons with href-action should navigate when clicked - $('input.href-action').click(function(e) { - e.preventDefault(); - window.location = ($(e.target).attr('action')); - }); - - var isGroupView = $('body.group.read').length > 0; - if (isGroupView) { - // Show extract of notes field - CKAN.Utils.setupNotesExtract(); - } - - var isDatasetView = $('body.package.read').length > 0; - if (isDatasetView) { - // Show extract of notes field - CKAN.Utils.setupNotesExtract(); - } - - var isResourceView = false; //$('body.package.resource_read').length > 0; - if (isResourceView) { - CKAN.DataPreview.loadPreviewDialog(preload_resource); - } - - var isEmbeddedDataviewer = false;//$('body.package.resource_embedded_dataviewer').length > 0; - if (isEmbeddedDataviewer) { - CKAN.DataPreview.loadEmbeddedPreview(preload_resource, reclineState); - } - - if ($(document.body).hasClass('search')) { - // Calculate the optimal width for the search input regardless of the - // width of the submit button (which can vary depending on translation). - (function resizeSearchInput() { - var form = $('#dataset-search'), - input = form.find('[name=q]'), - button = form.find('[type=submit]'), - offset = parseFloat(button.css('margin-left')); - - // Grab the horizontal properties of the input that affect the width. - $.each(['padding-left', 'padding-right', 'border-left-width', 'border-right-width'], function (i, prop) { - offset += parseFloat(input.css(prop)) || 0; - }); - - input.width(form.outerWidth() - button.outerWidth() - offset); - })(); - } - - var isDatasetNew = $('body.package.new').length > 0; - if (isDatasetNew) { - // Set up magic URL slug editor - var urlEditor = new CKAN.View.UrlEditor({ - slugType: 'package' - }); - $('#save').val(CKAN.Strings.addDataset); - $("#title").focus(); - } - var isGroupNew = $('body.group.new').length > 0; - if (isGroupNew) { - // Set up magic URL slug editor - var urlEditor = new CKAN.View.UrlEditor({ - slugType: 'group' - }); - $('#save').val(CKAN.Strings.addGroup); - $("#title").focus(); - } - - var isDatasetEdit = $('body.package.edit').length > 0; - if (isDatasetEdit) { - CKAN.Utils.warnOnFormChanges($('form#dataset-edit')); - var urlEditor = new CKAN.View.UrlEditor({ - slugType: 'package' - }); - - // Set up dataset delete button - CKAN.Utils.setupDatasetDeleteButton(); - } - var isDatasetResourceEdit = $('body.package.editresources').length > 0; - if (isDatasetNew || isDatasetResourceEdit) { - // Selectively enable the upload button - var storageEnabled = $.inArray('storage',CKAN.plugins)>=0; - if (storageEnabled) { - $('li.js-upload-file').show(); - } - // Backbone collection class - var CollectionOfResources = Backbone.Collection.extend({model: CKAN.Model.Resource}); - // 'resources_json' was embedded into the page - var view = new CKAN.View.ResourceEditor({ - collection: new CollectionOfResources(resources_json), - el: $('form#dataset-edit') - }); - view.render(); - - $( ".drag-drop-list" ).sortable({ - distance: 10 - }); - $( ".drag-drop-list" ).disableSelection(); - } - - var isGroupEdit = $('body.group.edit').length > 0; - if (isGroupEdit) { - var urlEditor = new CKAN.View.UrlEditor({ - slugType: 'group' - }); - } - // OpenID hack - // We need to remember the language we are using whilst logging in - // we set this in the user session so we don't forget then - // carry on as before. - if (window.openid && openid.signin){ - openid._signin = openid.signin; - openid.signin = function (arg) { - $.get(CKAN.SITE_URL + '/user/set_lang/' + CKAN.LANG, function (){openid._signin(arg);}) - }; - } - if ($('#login').length){ - $('#login').submit( function () { - $.ajax(CKAN.SITE_URL + '/user/set_lang/' + CKAN.LANG, {async:false}); - }); - } - }); -}(jQuery)); - -/* =============================== */ -/* jQuery Plugins */ -/* =============================== */ - -jQuery.fn.truncate = function (max, suffix) { - return this.each(function () { - var element = jQuery(this), - isTruncated = element.hasClass('truncated'), - cached, length, text, expand; - - if (isTruncated) { - element.html(element.data('truncate:' + (max === 'expand' ? 'original' : 'truncated'))); - return; - } - - cached = element.text(); - length = max || element.data('truncate') || 30; - text = cached.slice(0, length); - expand = jQuery('').text(suffix || '»'); - - // Bail early if there is nothing to truncate. - if (cached.length < length) { - return; - } - - // Try to truncate to nearest full word. - while ((/\S/).test(text[text.length - 1])) { - text = text.slice(0, text.length - 1); - } - - element.html(jQuery.trim(text)); - expand.appendTo(element.append(' ')); - expand.click(function (event) { - event.preventDefault(); - element.html(cached); - }); - - element.addClass('truncated'); - element.data('truncate:original', cached); - element.data('truncate:truncated', element.html()); - }); -}; - -/* =============================== */ -/* Backbone Model: Resource object */ -/* =============================== */ -CKAN.Model.Resource = Backbone.Model.extend({ - constructor: function Resource() { - Backbone.Model.prototype.constructor.apply(this, arguments); - }, - toTemplateJSON: function() { - var obj = Backbone.Model.prototype.toJSON.apply(this, arguments); - obj.displaytitle = obj.description ? obj.description : 'No description ...'; - return obj; - } -}); - - - -/* ============================== */ -/* == Backbone View: UrlEditor == */ -/* ============================== */ -CKAN.View.UrlEditor = Backbone.View.extend({ - initialize: function() { - _.bindAll(this,'titleToSlug','titleChanged','urlChanged','checkSlugIsValid','apiCallback'); - - // Initial state - var self = this; - this.updateTimer = null; - this.titleInput = $('.js-title'); - this.urlInput = $('.js-url-input'); - this.validMsg = $('.js-url-is-valid'); - this.lengthMsg = $('.url-is-long'); - this.lastTitle = ""; - this.disableTitleChanged = false; - - // Settings - this.regexToHyphen = [ new RegExp('[ .:/_]', 'g'), - new RegExp('[^a-zA-Z0-9-_]', 'g'), - new RegExp('-+', 'g')]; - this.regexToDelete = [ new RegExp('^-*', 'g'), - new RegExp('-*$', 'g')]; - - // Default options - if (!this.options.apiUrl) { - this.options.apiUrl = CKAN.SITE_URL + '/api/2/util/is_slug_valid'; - } - if (!this.options.MAX_SLUG_LENGTH) { - this.options.MAX_SLUG_LENGTH = 90; - } - this.originalUrl = this.urlInput.val(); - - // Hook title changes to the input box - CKAN.Utils.bindInputChanges(this.titleInput, this.titleChanged); - CKAN.Utils.bindInputChanges(this.urlInput, this.urlChanged); - - // If you've bothered typing a URL, I won't overwrite you - function disable() { - self.disableTitleChanged = true; - }; - this.urlInput.keyup (disable); - this.urlInput.keydown (disable); - this.urlInput.keypress(disable); - - // Set up the form - this.urlChanged(); - }, - - titleToSlug: function(title) { - var slug = title; - $.each(this.regexToHyphen, function(idx,regex) { slug = slug.replace(regex, '-'); }); - $.each(this.regexToDelete, function(idx,regex) { slug = slug.replace(regex, ''); }); - slug = slug.toLowerCase(); - - if (slug.length'+CKAN.Strings.urlIsTooShort+''); - } - else if (slug==this.originalUrl) { - this.validMsg.html(''+CKAN.Strings.urlIsUnchanged+''); - } - else { - this.validMsg.html(''+CKAN.Strings.checking+''); - var self = this; - this.updateTimer = setTimeout(function () { - self.checkSlugIsValid(slug); - }, 200); - } - if (slug.length>20) { - this.lengthMsg.show(); - } - else { - this.lengthMsg.hide(); - } - }, - - checkSlugIsValid: function(slug) { - $.ajax({ - url: this.options.apiUrl, - data: 'type='+this.options.slugType+'&slug=' + slug, - dataType: 'jsonp', - type: 'get', - jsonpCallback: 'callback', - success: this.apiCallback - }); - }, - - /* Called when the slug-validator gets back to us */ - apiCallback: function(data) { - if (data.valid) { - this.validMsg.html(''+CKAN.Strings.urlIsAvailable+''); - } else { - this.validMsg.html(''+CKAN.Strings.urlIsNotAvailable+''); - } - } -}); - - -/* =================================== */ -/* == Backbone View: ResourceEditor == */ -/* =================================== */ -CKAN.View.ResourceEditor = Backbone.View.extend({ - initialize: function() { - // Init bindings - _.bindAll(this, 'resourceAdded', 'resourceRemoved', 'sortStop', 'openFirstPanel', 'closePanel', 'openAddPanel'); - this.collection.bind('add', this.resourceAdded); - this.collection.bind('remove', this.resourceRemoved); - this.collection.each(this.resourceAdded); - this.el.find('.resource-list-edit').bind("sortstop", this.sortStop); - - // Delete the barebones editor. We will populate our own form. - this.el.find('.js-resource-edit-barebones').remove(); - - // Warn on form changes - var flashWarning = CKAN.Utils.warnOnFormChanges(this.el); - this.collection.bind('add', flashWarning); - this.collection.bind('remove', flashWarning); - - // Trigger the Add Resource pane - this.el.find('.js-resource-add').click(this.openAddPanel); - - // Tabs for adding resources - new CKAN.View.ResourceAddUrl({ - collection: this.collection, - el: this.el.find('.js-add-url-form'), - mode: 'file' - }); - new CKAN.View.ResourceAddUrl({ - collection: this.collection, - el: this.el.find('.js-add-api-form'), - mode: 'api' - }); - new CKAN.View.ResourceAddUpload({ - collection: this.collection, - el: this.el.find('.js-add-upload-form') - }); - - - // Close details button - this.el.find('.resource-panel-close').click(this.closePanel); - - // Did we embed some form errors? - if (typeof global_form_errors == 'object') { - if (global_form_errors.resources) { - var openedOne = false; - for (i in global_form_errors.resources) { - var resource_errors = global_form_errors.resources[i]; - if (CKAN.Utils.countObject(resource_errors) > 0) { - var resource = this.collection.at(i); - resource.view.setErrors(resource_errors); - if (!openedOne) { - resource.view.openMyPanel(); - openedOne = true; - } - } - } - } - } - else { - // Initial state - this.openFirstPanel(); - } - }, - /* - * Called when the page loads or the current resource is deleted. - * Reset page state to the first available edit panel. - */ - openFirstPanel: function() { - if (this.collection.length>0) { - this.collection.at(0).view.openMyPanel(); - } - else { - this.openAddPanel(); - } - }, - /* - * Open the 'Add New Resource' special-case panel on the right. - */ - openAddPanel: function(e) { - if (e) { e.preventDefault(); } - var panel = this.el.find('.resource-panel'); - var addLi = this.el.find('.resource-list-add > li'); - this.el.find('.resource-list > li').removeClass('active'); - $('.resource-details').hide(); - this.el.find('.resource-details.resource-add').show(); - addLi.addClass('active'); - panel.show(); - }, - /* - * Close the panel on the right. - */ - closePanel: function(e) { - if (e) { e.preventDefault(); } - this.el.find('.resource-list > li').removeClass('active'); - this.el.find('.resource-panel').hide(); - }, - /* - * Update the resource__N__field names to match - * new sort order. - */ - sortStop: function(e,ui) { - this.collection.each(function(resource) { - // Ask the DOM for the new sort order - var index = resource.view.li.index(); - resource.view.options.position = index; - // Update the form element names - var table = resource.view.table; - $.each(table.find('input,textarea,select'), function(input_index, input) { - var name = $(input).attr('name'); - if (name) { - name = name.replace(/(resources__)\d+(.*)/, '$1'+index+'$2'); - $(input).attr('name',name); - } - }); - }); - }, - /* - * Calculate id of the next resource to create - */ - nextIndex: function() { - var maxId=-1; - var root = this.el.find('.resource-panel'); - root.find('input').each(function(idx,input) { - var name = $(input).attr('name') || ''; - var splitName=name.split('__'); - if (splitName.length>1) { - var myId = parseInt(splitName[1],10); - maxId = Math.max(myId, maxId); - } - }); - return maxId+1; - }, - /* - * Create DOM elements for new resource. - */ - resourceAdded: function(resource) { - var self = this; - resource.view = new CKAN.View.Resource({ - position: this.nextIndex(), - model: resource, - callback_deleteMe: function() { self.collection.remove(resource); } - }); - this.el.find('.resource-list-edit').append(resource.view.li); - this.el.find('.resource-panel').append(resource.view.table); - if (resource.isNew()) { - resource.view.openMyPanel(); - } - }, - /* - * Destroy DOM elements for deleted resource. - */ - resourceRemoved: function(resource) { - resource.view.removeFromDom(); - delete resource.view; - this.openFirstPanel(); - } -}); - - -/* ============================== */ -/* == Backbone View: Resource == */ -/* ============================== */ - -CKAN.View.Resource = Backbone.View.extend({ - initialize: function() { - this.el = $(this.el); - _.bindAll(this,'updateName','updateIcon','name','askToDelete','openMyPanel','setErrors','setupDynamicExtras','addDynamicExtra' ); - this.render(); - }, - render: function() { - this.raw_resource = this.model.toTemplateJSON(); - var resource_object = { - resource: this.raw_resource, - num: this.options.position, - resource_icon: '/images/icons/page_white.png', - resourceTypeOptions: [ - ['file', CKAN.Strings.dataFile], - ['api', CKAN.Strings.api], - ['visualization', CKAN.Strings.visualization], - ['image', CKAN.Strings.image], - ['metadata', CKAN.Strings.metadata], - ['documentation', CKAN.Strings.documentation], - ['code', CKAN.Strings.code], - ['example', CKAN.Strings.example] - ] - }; - // Generate DOM elements - this.li = $($.tmpl(CKAN.Templates.resourceEntry, resource_object)); - this.table = $($.tmpl(CKAN.Templates.resourceDetails, resource_object)); - - // Hook to changes in name - this.nameBox = this.table.find('input.js-resource-edit-name'); - this.descriptionBox = this.table.find('textarea.js-resource-edit-description'); - CKAN.Utils.bindInputChanges(this.nameBox,this.updateName); - CKAN.Utils.bindInputChanges(this.descriptionBox,this.updateName); - // Hook to changes in format - this.formatBox = this.table.find('input.js-resource-edit-format'); - CKAN.Utils.bindInputChanges(this.formatBox,this.updateIcon); - // Hook to open panel link - this.li.find('.resource-open-my-panel').click(this.openMyPanel); - this.table.find('.js-resource-edit-delete').click(this.askToDelete); - // Hook to markdown editor - CKAN.Utils.setupMarkdownEditor(this.table.find('.markdown-editor')); - - // Set initial state - this.updateName(); - this.updateIcon(); - this.setupDynamicExtras(); - this.hasErrors = false; - }, - /* - * Process a JSON object of errors attached to this resource - */ - setErrors: function(obj) { - if (CKAN.Utils.countObject(obj) > 0) { - this.hasErrors = true; - this.errors = obj; - this.li.addClass('hasErrors'); - var errorList = $('
').addClass('errorList'); - $.each(obj,function(k,v) { - var errorText = ''; - var newLine = false; - $.each(v,function(index,value) { - if (newLine) { errorText += '
'; } - errorText += value; - newLine = true; - }); - errorList.append($('
').html(k)); - errorList.append($('
').html(errorText)); - }); - this.table.find('.resource-errors').append(errorList).show(); - } - }, - /* - * Work out what I should be called. Rough-match - * of helpers.py:resource_display_name. - */ - name: function() { - var name = this.nameBox.val(); - if (!name) { - name = this.descriptionBox.val(); - if (!name) { - if (this.model.isNew()) { - name = '[new resource]'; - } - else { - name = '[no name] ' + this.model.id; - } - } - } - if (name.length>45) { - name = name.substring(0,45)+'...'; - } - return name; - }, - /* - * Called when the user types to update the name in - * my
  • to match the values. - */ - updateName: function() { - // Need to structurally modify the DOM to force a re-render of text - var $link = this.li.find('.js-resource-edit-name'); - $link.html(''+this.name()+''); - }, - /* - * Called when the user types to update the icon - * tags. Uses server API to select icon. - */ - updateIcon: function() { - var self = this; - if (self.updateIconTimer) { - clearTimeout(self.updateIconTimer); - } - self.updateIconTimer = setTimeout(function() { - // AJAX to server API - $.getJSON(CKAN.SITE_URL + '/api/2/util/resource/format_icon?format='+encodeURIComponent(self.formatBox.val()), function(data) { - if (data && data.icon && data.format==self.formatBox.val()) { - self.li.find('.js-resource-icon').attr('src',data.icon); - self.table.find('.js-resource-icon').attr('src',data.icon); - } - }); - delete self.updateIconTimer; - }, - 100); - }, - /* - * Closes all other panels on the right and opens my editor panel. - */ - openMyPanel: function(e) { - if (e) { e.preventDefault(); } - // Close all tables - var panel = this.table.parents('.resource-panel'); - panel.find('.resource-details').hide(); - this.li.parents('fieldset#resources').find('.resource-list > li').removeClass('active'); - panel.show(); - this.table.show(); - this.table.find('.js-resource-edit-name').focus(); - this.li.addClass('active'); - }, - /* - * Called when my delete button is clicked. Calls back to the parent - * resource editor. - */ - askToDelete: function(e) { - e.preventDefault(); - var confirmMessage = CKAN.Strings.deleteThisResourceQuestion.replace('%name%', this.name()); - if (confirm(confirmMessage)) { - this.options.callback_deleteMe(); - } - }, - /* - * Set up the dynamic-extras section of the table. - */ - setupDynamicExtras: function() { - var self = this; - $.each(this.raw_resource, function(key,value) { - // Skip the known keys - if (self.reservedWord(key)) { return; } - self.addDynamicExtra(key,value); - }); - this.table.find('.add-resource-extra').click(function(e) { - e.preventDefault(); - self.addDynamicExtra('',''); - }); - }, - addDynamicExtra: function(key,value) { - // Create elements - var dynamicExtra = $($.tmpl(CKAN.Templates.resourceExtra, { - num: this.options.position, - key: key, - value: value})); - this.table.find('.dynamic-extras').append(dynamicExtra); - // Captured values - var inputKey = dynamicExtra.find('.extra-key'); - var inputValue = dynamicExtra.find('.extra-value'); - // Callback function - var self = this; - var setExtraName = function() { - var _key = inputKey.val(); - var key = $.trim(_key).replace(/\s+/g,''); - // Don't allow you to create an extra called mimetype (etc) - if (self.reservedWord(key)) { key=''; } - // Set or unset the field's name - if (key.length) { - var newName = 'resources__'+self.options.position+'__'+key; - inputValue.attr('name',newName); - inputValue.removeClass('strikethrough'); - } - else { - inputValue.removeAttr('name'); - inputValue.addClass('strikethrough'); - } - }; - // Callback function - var clickRemove = function(e) { - e.preventDefault(); - dynamicExtra.remove(); - }; - // Init with bindings - CKAN.Utils.bindInputChanges(dynamicExtra.find('.extra-key'), setExtraName); - dynamicExtra.find('.remove-resource-extra').click(clickRemove); - setExtraName(); - }, - - - - reservedWord: function(word) { - return word=='cache_last_updated' || - word=='cache_url' || - word=='dataset' || - word=='description' || - word=='displaytitle' || - word=='extras' || - word=='format' || - word=='hash' || - word=='id' || - word=='created' || - word=='last_modified' || - word=='mimetype' || - word=='mimetype_inner' || - word=='name' || - word=='package_id' || - word=='position' || - word=='resource_type' || - word=='revision_id' || - word=='revision_timestamp' || - word=='size' || - word=='size_extra' || - word=='state' || - word=='url' || - word=='webstore_last_updated' || - word=='webstore_url'; - }, - /* - * Called when my model is destroyed. Remove me from the page. - */ - removeFromDom: function() { - this.li.remove(); - this.table.remove(); - } -}); - - -/* ============================================= */ -/* Backbone View: Add Resource by uploading file */ -/* ============================================= */ -CKAN.View.ResourceAddUpload = Backbone.View.extend({ - tagName: 'div', - - initialize: function(options) { - this.el = $(this.el); - _.bindAll(this, 'render', 'updateFormData', 'setMessage', 'uploadFile'); - $(CKAN.Templates.resourceUpload).appendTo(this.el); - this.$messages = this.el.find('.alert'); - this.setupFileUpload(); - }, - - events: { - 'click input[type="submit"]': 'uploadFile' - }, - - setupFileUpload: function() { - var self = this; - this.el.find('.fileupload').fileupload({ - // needed because we are posting to remote url - forceIframeTransport: true, - replaceFileInput: false, - autoUpload: false, - fail: function(e, data) { - alert('Upload failed'); - }, - add: function(e,data) { - self.fileData = data; - self.fileUploadData = data; - self.key = self.makeUploadKey(data.files[0].name); - self.updateFormData(self.key); - }, - send: function(e, data) { - self.setMessage(CKAN.Strings.uploadingFile +' '); - }, - done: function(e, data) { - self.onUploadComplete(self.key); - } - }) - }, - - ISODateString: function(d) { - function pad(n) {return n<10 ? '0'+n : n}; - return d.getUTCFullYear()+'-' - + pad(d.getUTCMonth()+1)+'-' - + pad(d.getUTCDate())+'T' - + pad(d.getUTCHours())+':' - + pad(d.getUTCMinutes())+':' - + pad(d.getUTCSeconds()); - }, - - // Create an upload key/label for this file. - // - // Form: {current-date}/file-name. Do not just use the file name as this - // would lead to collisions. - // (Could add userid/username and/or a small random string to reduce - // collisions but chances seem very low already) - makeUploadKey: function(fileName) { - // google storage replaces ' ' with '+' which breaks things - // See http://trac.ckan.org/ticket/1518 for more. - var corrected = fileName.replace(/ /g, '-'); - // note that we put hh mm ss as hhmmss rather hh:mm:ss (former is 'basic - // format') - var now = new Date(); - // replace ':' with nothing - var str = this.ISODateString(now).replace(':', '').replace(':', ''); - return str + '/' + corrected; - }, - - updateFormData: function(key) { - var self = this; - self.setMessage(CKAN.Strings.checkingUploadPermissions + ' '); - self.el.find('.fileinfo').text(key); - $.ajax({ - url: CKAN.SITE_URL + '/api/storage/auth/form/' + key, - async: false, - success: function(data) { - self.el.find('form').attr('action', data.action); - _tmpl = ''; - var $hidden = $(self.el.find('form div.hidden-inputs')[0]); - $.each(data.fields, function(idx, item) { - $hidden.append($.tmpl(_tmpl, item)); - }); - self.hideMessage(); - }, - error: function(jqXHR, textStatus, errorThrown) { - // TODO: more graceful error handling (e.g. of 409) - self.setMessage(CKAN.Strings.failedToGetCredentialsForUpload, 'error'); - self.el.find('input[name="add-resource-upload"]').hide(); - } - }); - }, - - uploadFile: function(e) { - e.preventDefault(); - if (!this.fileData) { - alert('No file selected'); - return; - } - var jqXHR = this.fileData.submit(); - }, - - onUploadComplete: function(key) { - var self = this; - $.ajax({ - url: CKAN.SITE_URL + '/api/storage/metadata/' + self.key, - success: function(data) { - var name = data._label; - if (name && name.length > 0 && name[0] === '/') { - name = name.slice(1); - } - var d = new Date(data._last_modified); - var lastmod = self.ISODateString(d); - var newResource = new CKAN.Model.Resource({}); - newResource.set({ - url: data._location - , name: name - , size: data._content_length - , last_modified: lastmod - , format: data._format - , mimetype: data._format - , resource_type: 'file.upload' - , owner: data['uploaded-by'] - , hash: data._checksum - , cache_url: data._location - , cache_url_updated: lastmod - } - , { - error: function(model, error) { - var msg = 'Filed uploaded OK but error adding resource: ' + error + '.'; - msg += 'You may need to create a resource directly. Uploaded file at: ' + data._location; - self.setMessage(msg, 'error'); - } - } - ); - self.collection.add(newResource); - self.setMessage('File uploaded OK and resource added', 'success'); - } - }); - }, - - setMessage: function(msg, category) { - var category = category || 'alert-info'; - this.$messages.removeClass('alert-info alert-success alert-error'); - this.$messages.addClass(category); - this.$messages.show(); - this.$messages.html(msg); - }, - - hideMessage: function() { - this.$messages.hide('slow'); - } -}); - -/* ======================================== */ -/* == Backbone View: Add resource by URL == */ -/* ======================================== */ -CKAN.View.ResourceAddUrl = Backbone.View.extend({ - initialize: function(options) { - _.bindAll(this, 'clickSubmit'); - }, - - clickSubmit: function(e) { - e.preventDefault(); - - var self = this; - var newResource = new CKAN.Model.Resource({}); - - this.el.find('input[name="add-resource-save"]').addClass("disabled"); - var urlVal = this.el.find('input[name="add-resource-url"]').val(); - var qaEnabled = $.inArray('qa',CKAN.plugins)>=0; - - if(qaEnabled && this.options.mode=='file') { - $.ajax({ - url: CKAN.SITE_URL + '/qa/link_checker', - context: newResource, - data: {url: urlVal}, - dataType: 'json', - error: function(){ - newResource.set({url: urlVal, resource_type: 'file'}); - self.collection.add(newResource); - self.resetForm(); - }, - success: function(data){ - data = data[0]; - newResource.set({ - url: urlVal, - resource_type: 'file', - format: data.format, - size: data.size, - mimetype: data.mimetype, - last_modified: data.last_modified, - url_error: (data.url_errors || [""])[0] - }); - self.collection.add(newResource); - self.resetForm(); - } - }); - } - else { - newResource.set({url: urlVal, resource_type: this.options.mode}); - this.collection.add(newResource); - this.resetForm(); - } - }, - - resetForm: function() { - this.el.find('input[name="add-resource-save"]').removeClass("disabled"); - this.el.find('input[name="add-resource-url"]').val(''); - }, - - events: { - 'click .btn': 'clickSubmit' - } -}); - - - -/* ================ */ -/* == CKAN.Utils == */ -/* ================ */ -CKAN.Utils = function($, my) { - // Animate the appearance of an element by expanding its height - my.animateHeight = function(element, animTime) { - if (!animTime) { animTime = 350; } - element.show(); - var finalHeight = element.height(); - element.height(0); - element.animate({height:finalHeight}, animTime); - }; - - my.bindInputChanges = function(input, callback) { - input.keyup(callback); - input.keydown(callback); - input.keypress(callback); - input.change(callback); - }; - - my.setupDatasetDeleteButton = function() { - var select = $('select.dataset-delete'); - select.attr('disabled','disabled'); - select.css({opacity: 0.3}); - $('button.dataset-delete').click(function(e) { - select.removeAttr('disabled'); - select.fadeTo('fast',1.0); - $(e.target).css({opacity:0}); - $(e.target).attr('disabled','disabled'); - return false; - }); - }; - - // Attach dataset autocompletion to provided elements - // - // Requires: jquery-ui autocomplete - my.setupPackageAutocomplete = function(elements) { - elements.autocomplete({ - minLength: 0, - source: function(request, callback) { - var url = '/dataset/autocomplete?q=' + request.term; - $.ajax({ - url: url, - success: function(data) { - // atm is a string with items broken by \n and item = title (name)|name - var out = []; - var items = data.split('\n'); - $.each(items, function(idx, value) { - var _tmp = value.split('|'); - var _newItem = { - label: _tmp[0], - value: _tmp[1] - }; - out.push(_newItem); - }); - callback(out); - } - }); - } - , select: function(event, ui) { - var input_box = $(this); - input_box.val(''); - var old_name = input_box.attr('name'); - var field_name_regex = /^(\S+)__(\d+)__(\S+)$/; - var split = old_name.match(field_name_regex); - - var new_name = split[1] + '__' + (parseInt(split[2],10) + 1) + '__' + split[3]; - - input_box.attr('name', new_name); - input_box.attr('id', new_name); - - var $new = $('

    '); - $new.append($('').attr('name', old_name).val(ui.item.value)); - $new.append(' '); - $new.append(ui.item.label); - input_box.after($new); - - // prevent setting value in autocomplete box - return false; - } - }); - }; - - // Attach tag autocompletion to provided elements - // - // Requires: jquery-ui autocomplete - my.setupTagAutocomplete = function(elements) { - // don't navigate away from the field on tab when selecting an item - elements.bind( "keydown", - function( event ) { - if ( event.keyCode === $.ui.keyCode.TAB && $( this ).data( "autocomplete" ).menu.active ) { - event.preventDefault(); - } - } - ).autocomplete({ - minLength: 1, - source: function(request, callback) { - // here request.term is whole list of tags so need to get last - var _realTerm = $.trim(request.term.split(',').pop()); - var url = CKAN.SITE_URL + '/api/2/util/tag/autocomplete?incomplete=' + _realTerm; - $.getJSON(url, function(data) { - // data = { ResultSet: { Result: [ {Name: tag} ] } } (Why oh why?) - var tags = $.map(data.ResultSet.Result, function(value, idx) { - return value.Name; - }); - callback( $.ui.autocomplete.filter(tags, _realTerm) ); - }); - }, - focus: function() { - // prevent value inserted on focus - return false; - }, - select: function( event, ui ) { - var terms = this.value.split(','); - // remove the current input - terms.pop(); - // add the selected item - terms.push( " "+ui.item.value ); - // add placeholder to get the comma-and-space at the end - terms.push( " " ); - this.value = terms.join( "," ); - return false; - } - }); - }; - - // Attach tag autocompletion to provided elements - // - // Requires: jquery-ui autocomplete - my.setupFormatAutocomplete = function(elements) { - elements.autocomplete({ - minLength: 1, - source: function(request, callback) { - var url = CKAN.SITE_URL + '/api/2/util/resource/format_autocomplete?incomplete=' + request.term; - $.getJSON(url, function(data) { - // data = { ResultSet: { Result: [ {Name: tag} ] } } (Why oh why?) - var formats = $.map(data.ResultSet.Result, function(value, idx) { - return value.Format; - }); - callback(formats); - }); - } - }); - }; - - my.setupOrganizationUserAutocomplete = function(elements) { - elements.autocomplete({ - minLength: 2, - source: function(request, callback) { - var url = '/api/2/util/user/autocomplete?q=' + request.term; - $.getJSON(url, function(data) { - $.each(data, function(idx, userobj) { - var label = userobj.name; - if (userobj.fullname) { - label += ' [' + userobj.fullname + ']'; - } - userobj.label = label; - userobj.value = userobj.name; - }); - callback(data); - }); - }, - select: function(event, ui) { - var input_box = $(this); - input_box.val(''); - var parent_dd = input_box.parent('dd'); - var old_name = input_box.attr('name'); - var field_name_regex = /^(\S+)__(\d+)__(\S+)$/; - var split = old_name.match(field_name_regex); - - var new_name = split[1] + '__' + (parseInt(split[2],10) + 1) + '__' + split[3]; - input_box.attr('name', new_name); - input_box.attr('id', new_name); - - parent_dd.before( - '' + - '' + - '
    ' + ui.item.label + '
    ' - ); - - return false; // to cancel the event ;) - } - }); - }; - - - // Attach user autocompletion to provided elements - // - // Requires: jquery-ui autocomplete - my.setupUserAutocomplete = function(elements) { - elements.autocomplete({ - minLength: 2, - source: function(request, callback) { - var url = CKAN.SITE_URL + '/api/2/util/user/autocomplete?q=' + request.term; - $.getJSON(url, function(data) { - $.each(data, function(idx, userobj) { - var label = userobj.name; - if (userobj.fullname) { - label += ' [' + userobj.fullname + ']'; - } - userobj.label = label; - userobj.value = userobj.name; - }); - callback(data); - }); - } - }); - }; - - - my.relatedSetup = function(form) { - $('[rel=popover]').popover(); - - function addAlert(msg) { - $('
    ').html(msg).hide().prependTo(form).fadeIn(); - } - - function relatedRequest(action, method, data) { - return $.ajax({ - type: method, - dataType: 'json', - contentType: 'application/json', - url: CKAN.SITE_URL + '/api/3/action/related_' + action, - data: data ? JSON.stringify(data) : undefined, - error: function(err, txt, w) { - // This needs to be far more informative. - addAlert('Error: Unable to ' + action + ' related item'); - } - }); - } - - // Center thumbnails vertically. - var relatedItems = $('.related-items'); - relatedItems.find('li').each(function () { - var item = $(this), description = item.find('.description'); - - function vertiallyAlign() { - var img = $(this), - height = img.height(), - parent = img.parent().height(), - top = (height - parent) / 2; - - if (parent < height) { - img.css('margin-top', -top); - } - } - - item.find('img').load(vertiallyAlign); - description.data('height', description.height()).truncate(); - }); - - relatedItems.on('mouseenter mouseleave', '.description.truncated', function (event) { - var isEnter = event.type === 'mouseenter' - description = $(this) - timer = description.data('hover-intent'); - - function update() { - var parent = description.parents('li:first'), - difference = description.data('height') - description.height(); - - description.truncate(isEnter ? 'expand' : 'collapse'); - parent.toggleClass('expanded-description', isEnter); - - // Adjust the bottom margin of the item relative to it's current value - // to allow the description to expand without breaking the grid. - parent.css('margin-bottom', isEnter ? '-=' + difference + 'px' : ''); - description.removeData('hover-intent'); - } - - if (!isEnter && timer) { - // User has moused out in the time set so cancel the action. - description.removeData('hover-intent'); - return clearTimeout(timer); - } else if (!isEnter && !timer) { - update(); - } else { - // Delay the hover action slightly to wait to see if the user mouses - // out again. This prevents unwanted actions. - description.data('hover-intent', setTimeout(update, 200)); - } - }); - - // Add a handler for the delete buttons. - relatedItems.on('click', '[data-action=delete]', function (event) { - var id = $(this).data('relatedId'); - relatedRequest('delete', 'POST', {id: id}).done(function () { - $('#related-item-' + id).remove(); - }); - event.preventDefault(); - }); - - $(form).submit(function (event) { - event.preventDefault(); - - // Validate the form - var form = $(this), data = {}; - jQuery.each(form.serializeArray(), function () { - data[this.name] = this.value; - }); - - form.find('.alert').remove(); - form.find('.error').removeClass('error'); - if (!data.title) { - addAlert('Missing field: A title is required'); - $('[name=title]').parent().addClass('error'); - return; - } - if (!data.url) { - addAlert('Missing field: A url is required'); - $('[name=url]').parent().addClass('error'); - return; - } - - relatedRequest('create', this.method, data).done(function () { - // TODO: Insert item dynamically. - window.location.reload(); - }); - }); - }; - - my.setupGroupAutocomplete = function(elements) { - elements.autocomplete({ - minLength: 2, - source: function(request, callback) { - var url = CKAN.SITE_URL + '/api/2/util/group/autocomplete?q=' + request.term; - $.getJSON(url, function(data) { - $.each(data, function(idx, userobj) { - var label = userobj.name; - userobj.label = label; - userobj.value = userobj.name; - }); - callback(data); - }); - } - }); - }; - - my.setupMarkdownEditor = function(markdownEditor) { - // Markdown editor hooks - markdownEditor.find('button, div.markdown-preview').live('click', function(e) { - e.preventDefault(); - var $target = $(e.target); - // Extract neighbouring elements - var markdownEditor=$target.closest('.markdown-editor'); - markdownEditor.find('button').removeClass('depressed'); - var textarea = markdownEditor.find('.markdown-input'); - var preview = markdownEditor.find('.markdown-preview'); - // Toggle the preview - if ($target.is('.js-markdown-preview')) { - $target.addClass('depressed'); - raw_markdown=textarea.val(); - preview.html(""+CKAN.Strings.loading+""); - $.post(CKAN.SITE_URL + "/api/util/markdown", { q: raw_markdown }, - function(data) { preview.html(data); } - ); - preview.width(textarea.width()); - preview.height(textarea.height()); - textarea.hide(); - preview.show(); - } else { - markdownEditor.find('.js-markdown-edit').addClass('depressed'); - textarea.show(); - preview.hide(); - textarea.focus(); - } - return false; - }); - }; - - // If notes field is more than 1 paragraph, just show the - // first paragraph with a 'Read more' link that will expand - // the div if clicked - my.setupNotesExtract = function() { - var notes = $('#content div.notes'); - var paragraphs = notes.find('#notes-extract > *'); - if (paragraphs.length===0) { - notes.hide(); - } - else if (paragraphs.length > 1) { - var remainder = notes.find('#notes-remainder'); - $.each(paragraphs,function(i,para) { - if (i > 0) { remainder.append($(para).remove()); } - }); - var finalHeight = remainder.height(); - remainder.height(0); - notes.find('#notes-toggle').show(); - notes.find('#notes-toggle button').click( - function(event){ - notes.find('#notes-toggle button').toggle(); - if ($(event.target).hasClass('more')) { - remainder.animate({'height':finalHeight}); - } - else { - remainder.animate({'height':0}); - } - return false; - } - ); - } - }; - - my.warnOnFormChanges = function() { - var boundToUnload = false; - return function($form) { - var flashWarning = function() { - if (boundToUnload) { return; } - boundToUnload = true; - // Bind to the window departure event - window.onbeforeunload = function () { - return CKAN.Strings.youHaveUnsavedChanges; - }; - }; - // Hook form modifications to flashWarning - $form.find('input,select').live('change', function(e) { - $target = $(e.target); - // Entering text in the 'add' box does not represent a change - if ($target.closest('.resource-add').length===0) { - flashWarning(); - } - }); - // Don't stop us leaving - $form.submit(function() { - window.onbeforeunload = null; - }); - // Calling functions might hook to flashWarning - return flashWarning; - }; - }(); - - my.countObject = function(obj) { - var count=0; - $.each(obj, function() { - count++; - }); - return count; - }; - - function followButtonClicked(event) { - var button = event.currentTarget; - if (button.id === 'user_follow_button') { - var object_type = 'user'; - } else if (button.id === 'dataset_follow_button') { - var object_type = 'dataset'; - } - else { - // This shouldn't happen. - return; - } - var object_id = button.getAttribute('data-obj-id'); - if (button.getAttribute('data-state') === "follow") { - if (object_type == 'user') { - var url = '/api/action/follow_user'; - } else if (object_type == 'dataset') { - var url = '/api/action/follow_dataset'; - } else { - // This shouldn't happen. - return; - } - var data = JSON.stringify({ - id: object_id - }); - var nextState = 'unfollow'; - var nextString = CKAN.Strings.unfollow; - } else if (button.getAttribute('data-state') === "unfollow") { - if (object_type == 'user') { - var url = '/api/action/unfollow_user'; - } else if (object_type == 'dataset') { - var url = '/api/action/unfollow_dataset'; - } else { - // This shouldn't happen. - return; - } - var data = JSON.stringify({ - id: object_id - }); - var nextState = 'follow'; - var nextString = CKAN.Strings.follow; - } - else { - // This shouldn't happen. - return; - } - $.ajax({ - contentType: 'application/json', - url: url, - data: data, - dataType: 'json', - processData: false, - type: 'POST', - success: function(data) { - button.setAttribute('data-state', nextState); - button.innerHTML = nextString; - } - }); - }; - - // This only needs to happen on dataset pages, but it doesn't seem to do - // any harm to call it anyway. - $('#user_follow_button').on('click', followButtonClicked); - $('#dataset_follow_button').on('click', followButtonClicked); - - return my; -}(jQuery, CKAN.Utils || {}); - - - -/* ==================== */ -/* == Data Previewer == */ -/* ==================== */ -CKAN.DataPreview = function ($, my) { - my.jsonpdataproxyUrl = 'http://jsonpdataproxy.appspot.com/'; - my.dialogId = 'ckanext-datapreview'; - my.$dialog = $('#' + my.dialogId); - - // **Public: Loads a data previewer for an embedded page** - // - // Uses the provided reclineState to restore the Dataset. Creates a single - // view for the Dataset (the one defined by reclineState.currentView). And - // then passes the constructed Dataset, the constructed View, and the - // reclineState into the DataExplorer constructor. - my.loadEmbeddedPreview = function(resourceData, reclineState) { - my.$dialog.html('

    Loading ...

    '); - - // Restore the Dataset from the given reclineState. - var datasetInfo = _.extend({ - url: reclineState.url, - backend: reclineState.backend - }, - reclineState.dataset - ); - var dataset = new recline.Model.Dataset(datasetInfo); - - // Only create the view defined in reclineState.currentView. - // TODO: tidy this up. - var views = null; - if (reclineState.currentView === 'grid') { - views = [ { - id: 'grid', - label: 'Grid', - view: new recline.View.SlickGrid({ - model: dataset, - state: reclineState['view-grid'] - }) - }]; - } else if (reclineState.currentView === 'graph') { - views = [ { - id: 'graph', - label: 'Graph', - view: new recline.View.Graph({ - model: dataset, - state: reclineState['view-graph'] - }) - }]; - } else if (reclineState.currentView === 'map') { - views = [ { - id: 'map', - label: 'Map', - view: new recline.View.Map({ - model: dataset, - state: reclineState['view-map'] - }) - }]; - } - - // Finally, construct the DataExplorer. Again, passing in the reclineState. - var dataExplorer = new recline.View.MultiView({ - el: my.$dialog, - model: dataset, - state: reclineState, - views: views - }); - - }; - - // **Public: Creates a link to the embeddable page. - // - // For a given DataExplorer state, this function constructs and returns the - // url to the embeddable view of the current dataexplorer state. - my.makeEmbedLink = function(explorerState) { - var state = explorerState.toJSON(); - state.state_version = 1; - - var queryString = '?'; - var items = []; - $.each(state, function(key, value) { - if (typeof(value) === 'object') { - value = JSON.stringify(value); - } - items.push(key + '=' + escape(value)); - }); - queryString += items.join('&'); - return embedPath + queryString; - }; - - // **Public: Loads a data preview** - // - // Fetches the preview data object from the link provided and loads the - // parsed data from the webstore displaying it in the most appropriate - // manner. - // - // link - Preview button. - // - // Returns nothing. - my.loadPreviewDialog = function(resourceData) { - my.$dialog.html('

    Loading ...

    '); - - function showError(msg){ - msg = msg || CKAN.Strings.errorLoadingPreview; - return $('#ckanext-datapreview') - .append('
    ') - .addClass('alert alert-error fade in') - .html(msg); - } - - function initializeDataExplorer(dataset) { - var views = [ - { - id: 'grid', - label: 'Grid', - view: new recline.View.SlickGrid({ - model: dataset - }) - }, - { - id: 'graph', - label: 'Graph', - view: new recline.View.Graph({ - model: dataset - }) - }, - { - id: 'map', - label: 'Map', - view: new recline.View.Map({ - model: dataset - }) - } - ]; - - var dataExplorer = new recline.View.MultiView({ - el: my.$dialog, - model: dataset, - views: views, - config: { - readOnly: true - } - }); - - // Hide the fields control by default - // (This should be done in recline!) - $('.menu-right a[data-action="fields"]').click(); - - // ----------------------------- - // Setup the Embed modal dialog. - // ----------------------------- - - // embedLink holds the url to the embeddable view of the current DataExplorer state. - var embedLink = $('.embedLink'); - - // embedIframeText contains the '', - { - link: link.replace(/"/g, '"'), - width: width, - height: height - })); - embedLink.attr('href', link); - } - - // Bind changes to the DataExplorer, or the two width and height inputs - // to re-calculate the url. - dataExplorer.state.bind('change', updateLink); - for (var i=0; i 1) { - resourceData.formatNormalized = ext[ext.length-1]; - } - } - - // Set recline CKAN backend API endpoint to right location (so it can locate - // CKAN DataStore) - recline.Backend.Ckan.API_ENDPOINT = CKAN.SITE_URL + '/api'; - - if (resourceData.datastore_active) { - resourceData.backend = 'ckan'; - var dataset = new recline.Model.Dataset(resourceData); - var errorMsg = CKAN.Strings.errorLoadingPreview + ': ' + CKAN.Strings.errorDataStore; - dataset.fetch() - .done(function(dataset){ - initializeDataExplorer(dataset); - }) - .fail(function(error){ - if (error.message) errorMsg += ' (' + error.message + ')'; - showError(errorMsg); - }); - - } - else if (resourceData.formatNormalized in {'csv': '', 'xls': '', 'tsv':''}) { - // set format as this is used by Recline in setting format for DataProxy - resourceData.format = resourceData.formatNormalized; - resourceData.backend = 'dataproxy'; - var dataset = new recline.Model.Dataset(resourceData); - var errorMsg = CKAN.Strings.errorLoadingPreview + ': ' +CKAN.Strings.errorDataProxy; - dataset.fetch() - .done(function(dataset){ - - dataset.bind('query:fail', function(error) { - $('#ckanext-datapreview .data-view-container').hide(); - $('#ckanext-datapreview .header').hide(); - $('.preview-header .btn').hide(); - }); - - initializeDataExplorer(dataset); - $('.recline-query-editor .text-query').hide(); - }) - .fail(function(error){ - if (error.message) errorMsg += ' (' + error.message + ')'; - showError(errorMsg); - }); - } - else if (resourceData.formatNormalized in { - 'rdf+xml': '', - 'owl+xml': '', - 'xml': '', - 'n3': '', - 'n-triples': '', - 'turtle': '', - 'plain': '', - 'atom': '', - 'tsv': '', - 'rss': '', - 'txt': '' - }) { - // HACK: treat as plain text / csv - // pass url to jsonpdataproxy so we can load remote data (and tell dataproxy to treat as csv!) - var _url = my.jsonpdataproxyUrl + '?type=csv&url=' + resourceData.url; - my.getResourceDataDirect(_url, function(data) { - my.showPlainTextData(data); - }); - } - else if (resourceData.formatNormalized in {'html':'', 'htm':''} - || resourceData.url.substring(0,23)=='http://docs.google.com/') { - // we displays a fullscreen dialog with the url in an iframe. - my.$dialog.empty(); - var el = $(''); - el.attr('src', resourceData.url); - el.attr('width', '100%'); - el.attr('height', '100%'); - my.$dialog.append(el); - } - // images - else if (resourceData.formatNormalized in {'png':'', 'jpg':'', 'gif':''} - || resourceData.resource_type=='image') { - // we displays a fullscreen dialog with the url in an iframe. - my.$dialog.empty(); - var el = $(''); - el.attr('src', resourceData.url); - el.css('max-width', '100%'); - el.css('border', 'solid 4px black'); - my.$dialog.append(el); - } - else { - // Cannot reliably preview this item - with no mimetype/format information, - // can't guarantee it's not a remote binary file such as an executable. - my.showError({ - title: CKAN.Strings.previewNotAvailableForDataType + resourceData.formatNormalized, - message: '' - }); - } - }; - - // Public: Requests the formatted resource data from the webstore and - // passes the data into the callback provided. - // - // preview - A preview object containing resource metadata. - // callback - A Function to call with the data when loaded. - // - // Returns nothing. - my.getResourceDataDirect = function(url, callback) { - // $.ajax() does not call the "error" callback for JSONP requests so we - // set a timeout to provide the callback with an error after x seconds. - var timeout = 5000; - var timer = setTimeout(function error() { - callback({ - error: { - title: 'Request Error', - message: 'Dataproxy server did not respond after ' + (timeout / 1000) + ' seconds' - } - }); - }, timeout); - - // have to set jsonp because webstore requires _callback but that breaks jsonpdataproxy - var jsonp = '_callback'; - if (url.indexOf('jsonpdataproxy') != -1) { - jsonp = 'callback'; - } - - // We need to provide the `cache: true` parameter to prevent jQuery appending - // a cache busting `={timestamp}` parameter to the query as the webstore - // currently cannot handle custom parameters. - $.ajax({ - url: url, - cache: true, - dataType: 'jsonp', - jsonp: jsonp, - success: function(data) { - clearTimeout(timer); - callback(data); - } - }); - }; - - // Public: Displays a String of data in a fullscreen dialog. - // - // data - An object of parsed CSV data returned by the webstore. - // - // Returns nothing. - my.showPlainTextData = function(data) { - if(data.error) { - my.showError(data.error); - } else { - var content = $('
    ');
    -      for (var i=0; i<%= title %>
    <%= message %>
    ', - error - ); - my.$dialog.html(_html); - }; - - my.normalizeFormat = function(format) { - var out = format.toLowerCase(); - out = out.split('/'); - out = out[out.length-1]; - return out; - }; - - my.normalizeUrl = function(url) { - if (url.indexOf('https') === 0) { - return 'http' + url.slice(5); - } else { - return url; - } - } - - // Public: Escapes HTML entities to prevent broken layout and XSS attacks - // when inserting user generated or external content. - // - // string - A String of HTML. - // - // Returns a String with HTML special characters converted to entities. - my.escapeHTML = function (string) { - return string.replace(/&(?!\w+;|#\d+;|#x[\da-f]+;)/gi, '&') - .replace(//g, '>') - .replace(/"/g, '"') - .replace(/'/g, ''') - .replace(/\//g,'/'); - }; - - - // Export the CKANEXT object onto the window. - $.extend(true, window, {CKANEXT: {}}); - CKANEXT.DATAPREVIEW = my; - return my; -}(jQuery, CKAN.DataPreview || {}); - diff --git a/ckan/public/scripts/dataexplorer/icon-sprite.png b/ckan/public/scripts/dataexplorer/icon-sprite.png deleted file mode 100644 index c0799191dac..00000000000 Binary files a/ckan/public/scripts/dataexplorer/icon-sprite.png and /dev/null differ diff --git a/ckan/public/scripts/dataexplorer/loading.gif b/ckan/public/scripts/dataexplorer/loading.gif deleted file mode 100644 index e14a0487dc6..00000000000 Binary files a/ckan/public/scripts/dataexplorer/loading.gif and /dev/null differ diff --git a/ckan/public/scripts/dataexplorer/table-view-template.js b/ckan/public/scripts/dataexplorer/table-view-template.js deleted file mode 100644 index 91a5cce6b40..00000000000 --- a/ckan/public/scripts/dataexplorer/table-view-template.js +++ /dev/null @@ -1,49 +0,0 @@ -DATAEXPLORER.TABLEVIEW.template.html = ' \ -
    \ -
    \ - \ - \ - \ - \ - \ - \ - \ - \ -
    \ -
    \ -
    \ -

    Help

    \ -

    To create a chart select a column (group) to use as the x-axis \ - then another column (Series A) to plot against it.

    \ -

    You can add add \ - additional series by clicking the "Add series" button

    \ -

    Please note you must be logged in to save charts.

    \ -
    \ -
    \ -
      \ -
    • \ - \ - \ -
    • \ -
    • \ - \ - \ -
    • \ -
    • \ - \ - \ -
    • \ -
    \ -
    \ - \ -
    \ -
    \ - \ - \ -
    \ -
    \ -
    \ -
    \ -
    \ -
    \ -'; diff --git a/ckan/public/scripts/dataexplorer/table-view.css b/ckan/public/scripts/dataexplorer/table-view.css deleted file mode 100644 index 2f89967a076..00000000000 --- a/ckan/public/scripts/dataexplorer/table-view.css +++ /dev/null @@ -1,247 +0,0 @@ -#dataexplorer-tableview-dialog table td { - background: #fff; - border: 1px solid #eee; - padding: 6px; - color: #555; -} - -#dataexplorer-tableview-dialog table thead td { - background: #444; - color: #fff; - border-color: #444; - border-bottom: none; -} - -.dataexplorer-tableview-viewer { - position: relative; - height: 100%; - overflow: hidden; -} - -.dataexplorer-tableview-nav { - list-style-type: none; - margin: 0; - padding: 0; - height: 30px; -} - -.dataexplorer-tableview-nav-toggle { - float: left; -} - -.dataexplorer-tableview-nav li { - float: left; -} - -#dataexplorer-tableview-nav-editor, -label[for=dataexplorer-tableview-nav-editor] { - float: right; -} - -.dataexplorer-tableview-grid { - border-left: 1px solid #ccc; -} - -.dataexplorer-tableview-graph { - z-index: 1; - background-color: #fff; - margin-right: 220px; -} - -.dataexplorer-tableview-editor { - z-index: 1; - background-color: #efefef; - width: 198px; - padding: 5px 10px; - border: 1px solid #ccc; - overflow: auto; - overflow-x: hidden; - float: right; -} - -.dataexplorer-tableview-editor ul { - list-style-type: none; - margin: 0; - padding: 0; - overflow: hidden; -} - -.dataexplorer-tableview-editor li { - margin-bottom: 10px; -} - -.dataexplorer-tableview-editor .dataexplorer-tableview-editor-group { - padding-bottom: 10px; - margin-bottom: 10px; - border-bottom: 1px solid #ddd; -} - -.dataexplorer-tableview-editor label { - display: block; - font-weight: bold; - color: #555; - line-height: 1.4; -} - -.dataexplorer-tableview-editor label a { - float: right; - font-size: 11px; - color: #999; - font-weight: normal; -} - -.dataexplorer-tableview-editor select { - width: 100%; -} - -.dataexplorer-tableview-editor button { - float: right; -} - -.dataexplorer-tableview-editor-buttons { - clear: right; - overflow: hidden; -} - -.dataexplorer-tableview-editor-submit { - margin-top: 10px; - padding-top: 10px; - border-top: 1px solid #ddd; -} - -.dataexplorer-tableview-editor-info { - border-bottom: 1px solid #ddd; - margin-bottom: 10px; -} - -.dataexplorer-tableview-editor-info h1, -.dataexplorer-tableview-editor-info p { - font-size: 12px; - margin: 0 0 10px; - color: #555; -} - -.dataexplorer-tableview-editor-info h1 { - line-height: 16px; - cursor: pointer; - font-family: sans-serif; - font-size: 13px; - font-weight: bold; - margin: 0 0 4px; -} - -.dataexplorer-tableview-editor-info h1 span { - position: relative; - top: 1px; - display: inline-block; - width: 12px; - height: 12px; - background: url(jquery-ui/css/ckan/images/ui-icons_444444_256x240.png) no-repeat -68px -17px; -} - -.dataexplorer-tableview-editor-hide-info h1 span { - background-position: -36px -18px; -} - -.dataexplorer-tableview-editor-hide-info p { - display: none; -} - -.dataexplorer-tableview-hide-editor .dataexplorer-tableview-editor { - display: none; -} - -.dataexplorer-tableview-hide-editor .dataexplorer-tableview-panel { - right: 0; -} - -/* Style the preview buttons */ -.preview { - width: 65px; -} - -.preview .resource-preview-button { - border: 1px solid #eaeaea; - color: #444; - padding: 3px 6px 2px 21px; - font-size: 12px; - font-weight: bold; - background: #fff url(./icon-sprite.png) no-repeat 5px 6px; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - -ms-border-radius: 4px; - -o-border-radius: 4px; - border-radius: 4px; - display: block; - margin: 0 -5px; -} - -.preview .resource-preview-button:hover { - color: #000; - text-decoration: none; - border-color: #aaa; - background-color: #fafafa; - background-position: 5px -24px; -} - -.preview .resource-preview-button:active { - color: #b22; - border-color: #b22; - background-position: 5px -54px; -} - -.preview .resource-preview-chart { - background-position: 5px -83px; -} - -.preview .resource-preview-chart:hover { - background-position: 5px -113px; -} - -.preview .resource-preview-chart:active { - background-position: 5px -143px; -} - -.preview .resource-preview-loading, -.preview .resource-preview-loading:hover, -.preview .resource-preview-loading:active { - color: #aaa; - border: 1px solid #eaeaea; - background-image: url(./loading.gif); - background-position: 3px 5px; - cursor: default; -} - -/* Reduce the default size of the alert dialog */ -.ui-dialog .ui-button-text-only .ui-button-text { - padding: 3px 16px 1px; -} - -/* Extend the resize handle into the adjacent column */ -.slick-resizable-handle { - width: 12px; - right: -6px; -} - -/* Fix to crop the text correctly */ -.slick-header-wrapper { - overflow: hidden; - display: inline-block; - width: 100%; - text-overflow: ellipsis; -} - -.slick-columnpicker { - border-color: #888; - z-index: 99999!important; -} - -.slick-columnpicker label, -.slick-columnpicker input { - cursor: pointer; -} - -.dataexplorer-tableview-graph .legend table { - width: auto; -} - diff --git a/ckan/public/scripts/dataexplorer/table-view.js b/ckan/public/scripts/dataexplorer/table-view.js deleted file mode 100644 index dc70b0400fd..00000000000 --- a/ckan/public/scripts/dataexplorer/table-view.js +++ /dev/null @@ -1,177 +0,0 @@ -(function ($) { - var dp = {}; - - // Set up in DOM ready. - dp.$dialog = null; - - // Time to wait for a JSONP request to timeout. - dp.timeout = 5000; - - // Template url. The html property is populated from data-preview-templates.js - dp.template = { - html: '' - }; - - // Public: Sets up the dialog for displaying a full screen of data. - // - // dialogTitle - title for dialog window. - // - // Returns nothing. - // - dp.setupFullscreenDialog = function (dialogTitle) { - var dialog = dp.$dialog; - dialog.empty(); - } - - // Public: Displays a smaller alert style dialog with an error message. - // - // error - An error object to display. - // - // Returns nothing. - // - dp.showError = function (error) { - var _html = '

    ' + $.trim(error.title) + '
    ' + $.trim(error.message) + '

    '; - dp.$dialog.html(_html); - }; - - // Public: Displays the datapreview UI in a fullscreen dialog. - // - // This method also parses the data returned by the webstore for use in - // the data preview UI. - // - // data - An object of parsed CSV data returned by the webstore. - // - // Returns nothing. - // - dp.showData = function(data) { - dp.setupFullscreenDialog(); - - if(data.error) { - return dp.showError(data.error); - } - var tabular = dp.convertData(data); - - // dp.loadTableView(tabular.columns, tabular.data); - var columns = tabular.columns; - var data = tabular.data; - - var element = $(dp.template.html).appendTo(dp.$dialog); - // set plot height explicitly or flot is not happy - // also for grid - var height = $(window).height(); - // $('.dataexplorer-tableview-viewer').height(height); - $('.dataexplorer-tableview-grid').height(height); - $('.dataexplorer-tableview-graph').height(height); - var viewer = new dp.createTableView(element, columns, data); - - // Load chart data from external source - // TODO: reinstate - // this used to load chart info from related CKAN dataset - viewer.editor.loading(); - viewer.editor.loading(false).disableSave(); - - // Save chart data to the client provided callback - // TODO: implement - viewer.editor.bind('save', function (chart) { - viewer.editor.saving(); - viewer.editor.saving(false); - }); - }; - - // **Public: parse data from webstore or other source into form for data - // preview UI** - // - // :param data: An object of parsed CSV data returned by the webstore. - // - // :return: parsed data. - dp.convertData = function(data) { - var tabular = { - columns: [], - data: [] - }; - isNumericRegex = (/^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/); - - // two types of data: that from webstore and that from jsonpdataproxy - // if fields then from dataproxy - if (data.fields) { - tabular.columns = $.map(data.fields || [], function (column, i) { - return {id: 'header-' + i, name: column, field: 'column-' + i, sortable: true}; - }); - - tabular.data = $.map(data.data || [], function (row, id) { - var cells = {id: id}; - for (var i = 0, c = row.length; i < c; i++) { - var isNumeric = isNumericRegex.test(row[i]); - cells['column-' + i] = isNumeric ? parseFloat(row[i]) : row[i]; - } - return cells; - }); - } else { - tabular.columns = $.map(data.keys, function(key, idx) { - return {id: 'header-' + key, name: key, field: 'column-' + key, sortable: true}; - }); - tabular.data = $.map(data.data, function(row, id) { - var cells = {id: id}; - for(i in row) { - var val = row[i]; - var isNumeric = isNumericRegex.test(val); - cells['column-' + tabular.columns[i].name] = isNumeric ? parseFloat(val) : val; - } - return cells; - }); - } - return tabular; - }; - - // Public: Kickstarts the plugin. - // - // dialogId - The id of the dialog Element in the page. - // options - An object containing aditional options. - // timeout: Time in seconds to wait for a JSONP timeout. - // - // Returns nothing. - // - dp.initialize = function(dialogId, options) { - dp.$dialog = $('#' + dialogId); - options = options || {}; - - dp.timeout = options.timeout || dp.timeout; - - var _height = Math.round($(window).height() * 0.6); - - // Large stylable dialog for displaying data. - dp.dialogOptions = { - autoOpen: false, - // does not seem to work for width ... - position: ['center', 'center'], - buttons: [], - width: $(window).width() - 20, - height: $(window).height() - 20, - resize: 'auto', - modal: false, - draggable: true, - resizable: true - }; - - // Smaller alert style dialog for error messages. - dp.errorDialogOptions = { - title: 'Unable to Preview - Had an error from dataproxy', - position: ['center', 'center'], - buttons: [{ - text: "OK", - click: function () { $(this).dialog("close"); } - }], - width: 360, - height: 180, - resizable: false, - draggable: false, - modal: true, - position: 'fixed' - }; - }; - - // Export the DATAEXPLORER object onto the window. - $.extend(true, window, {DATAEXPLORER: {}}); - DATAEXPLORER.TABLEVIEW = dp; - -})(jQuery); diff --git a/ckan/public/scripts/dataexplorer/table-view.ui.js b/ckan/public/scripts/dataexplorer/table-view.ui.js deleted file mode 100644 index 1d0c540dff9..00000000000 --- a/ckan/public/scripts/dataexplorer/table-view.ui.js +++ /dev/null @@ -1,1154 +0,0 @@ -// This file contains all of the UI elements aside from the containing element -// (ie. lightbox) used to build the datapreview widget. The MainView should -// be initiated with an element containing the elements required by the -// subviews. -// -// Use TABLEVIEW.createTableView() to create new instances of MainView. -// -// Examples -// -// var $element = $(templateString); -// var datapreview = TABLEVIEW.createTableView($element); -// -// -(function ($, undefined) { - - var ui = {}; - - // Binds methods on an object to always be called with the object as the - // method context. - // - // context - An object with methods to bind. - // arguments* - Following arguments should be method names to bind. - // - // Examples - // - // var object = { - // method1: function () { - // return this; - // }, - // method2: function () {} - // }; - // - // bindAll(object, 'method1', 'method2'); - // - // object.method1.call(window) === object //=> true; - // - // Returns the context argument. - // - function bindAll(context) { - var args = [].slice.call(arguments, 0), i = 0, count = args.length; - for (; i < count; i += 1) { - context[args[i]] = $.proxy(context[args[i]], context); - } - return context; - } - - // Creates a new object that inherits from the proto argument. - // - // Source: http://github.com/aron/inheritance.js - // - // This function will use Object.create() if it exists otherwise falls back - // to using a dummy constructor function to create a new object instance. - // Unlike Object.create() this function will always return a new object even - // if a non object is provided as an argument. - // - // proto - An object to use for the new objects internal prototype. - // - // Examples - // - // var appleObject = {color: 'green'} - // var appleInstance = create(appleObject); - // - // appleInstance.hasOwnProperty('color'); //=> false - // appleInstance.color === appleObject.color; //=> true - // - // Returns a newly created object. - // - function create(proto) { - if (typeof proto !== 'object') { - return {}; - } - else if (Object.create) { - return Object.create(proto); - } - function DummyObject() {} - DummyObject.prototype = proto; - return new DummyObject(); - } - - // Public: Creates a new constructor function that inherits from a parent. - // - // Source: http://github.com/aron/inheritance.js - // - // Instance and static methods can also be provided as additional arguments. - // if the methods argument has a property called "constructor" this will be - // used as the constructor function. - // - // Static methods will also be copied over from the parent object. However - // these will not be inheritied prototypally as with the instance methods. - // - // parent - A constructor Function to inherit from. - // methods - An Object literal of instance methods that are added to the - // constructors prototype. - // properties - An Object literal of static/class methods to add to the - // constructor itself. - // - // Examples - // - // function MyObject() {}; - // - // var SubClass = inherit(MyObject, {method: function () {}}); - // var instance = new SubClass(); - // - // instance instanceof MyObject //=> true - // - // Returns the new constructor Function. - // - function inherit(parent, methods, properties) { - methods = methods || {}; - - var Child = methods.hasOwnProperty('constructor') ? - methods.constructor : inherit.constructor(parent); - - Child.prototype = create(parent.prototype); - Child.prototype.constructor = Child; - - delete methods.constructor; - $.extend(Child.prototype, methods, {__super__: parent.prototype}); - - return $.extend(Child, parent, properties); - } - - // Public: Base view object that other views should inherit from. - // - // A wrapper around a dom element (itself wrapped in jQuery). Provides useful - // features such as pub/sub methods, and show/hide toggling of the element. - // - // Implements Ben Allman's Tiny PubSub, https://gist.github.com/661855 - // - // element - A jQuery wrapper, DOM Element or selector String. - // - // Examples - // - // var myView = new View('my-element'); - // - // Returns a new View instance. - // - ui.View = inherit({}, { - constructor: function View(element) { - this.el = element instanceof $ ? element : $(element); - - // Use a custom empty jQuery wrapper rather than this.el to prevent - // browser events being triggered. - this.events = $({}); - }, - - // Public: Performs a jQuery lookup within the views element. - // - // selector - A selector String to query. - // - // Examples - // - // this.$('.some-child-class'); - // - // Returns a jQuery collection. - // - $: function (selector) { - return this.el.find(selector); - }, - - // Public: Registers a listener for a topic that will be called when the - // event is triggered. Optionally an Object of topic/callback pairs can - // be passed to the method. Built on top of the jQuery .bind() method - // so other features like namespaces can also be used. - // - // topic - Topic string to subscribe to. - // fn - Callback function to be called when the topic is triggered. - // - // Examples - // - // view.bind('my-event', onMyEvent); - // view.bind({ - // 'my-event', onMyEvent, - // 'my-other-events': onMyOtherEvent - // }); - // - // Returns itself for chaining. - // - bind: function (topic, fn) { - if (arguments.length === 1) { - for (var key in topic) { - if (topic.hasOwnProperty(key)) { - this.bind(key, topic[key]); - } - } - return this; - } - - function wrapper() { - return fn.apply(this, Array.prototype.slice.call(arguments, 1)); - } - wrapper.guid = fn.guid = fn.guid || ($.guid ? $.guid++ : $.event.guid++); - this.events.bind(topic, wrapper); - return this; - }, - - // Public: Unbinds a callback for a topic. - // - // Accepts the same arguments as jQuery's .unbind(). - // - // topic - The topic to unbind. - // fn - A specific function to unbind from the topic. - // - // Examples - // - // view.unbind('my-event'); - // - // Returns itself for chaining. - // - unbind: function () { - this.events.unbind.apply(this.events, arguments); - return this; - }, - - // Public: Triggers a topic providing an array of arguments to all listeners. - // - // topic - A topic to publish. - // args - An Array of arguments to pass into registered listeners. - // - // Examples - // - // view.trigger('my-event', [anArg, anotherArg]); - // - // Returns itself. - // - trigger: function () { - this.events.triggerHandler.apply(this.events, arguments); - return this; - }, - - // Public: Shows the element if hidden. - // - // Returns itself. - // - show: function () { - this.el.show(); - return this.trigger('show'); - }, - - // Public: Hides the element if shown. - // - // Returns itself. - // - hide: function () { - this.el.hide(); - return this.trigger('hide'); - } - }); - - // Public: Main view object for the data preview plugin. - // - // Contains the main interface elements and acts as a controller binding - // them together. - // - // element - The main DOM Element used for the plugin. - // columns - The columns array for the data rows formatted for SlickGrid. - // data - A data object formatted for use in SlickGrid. - // chart - A chart object to load. - // - // Examples - // - // new MainView($('.datapraview-wrapper'), columns, data); - // - // Returns a new instance of MainView. - // - ui.MainView = inherit(ui.View, { - constructor: function MainView(element, columns, data, chart) { - this.__super__.constructor.apply(this, arguments); - - bindAll(this, 'redraw', 'onNavChange', 'onNavToggleEditor', 'onEditorSubmit'); - - var view = this; - this.nav = new ui.NavigationView(this.$('.dataexplorer-tableview-nav')); - this.grid = new ui.GridView(this.$('.dataexplorer-tableview-grid'), columns, data); - this.chart = new ui.ChartView(this.$('.dataexplorer-tableview-graph'), columns, data); - this.editor = new ui.EditorView(this.$('.dataexplorer-tableview-editor'), columns, chart); - - this.nav.bind({ - 'change': this.onNavChange, - 'toggle-editor': this.onNavToggleEditor - }); - this.editor.bind({ - 'show hide': this.redraw, - 'submit': this.onEditorSubmit - }); - - this.$('.dataexplorer-tableview-editor-info h1').click(function () { - $(this).parent().toggleClass('dataexplorer-tableview-editor-hide-info'); - }); - - this.chart.hide(); - }, - - // Public: Redraws the both the grid and chart views. - // - // Useful if the viewport changes or is resized. - // - // Examples - // - // view.resize(); - // - // Returns itself. - // - redraw: function () { - this.chart.redraw(); - this.grid.redraw(); - return this; - }, - - // Public: Toggles the display of the grid and chart views. - // - // Used as a callback function for the NavigationView "change" event. - // - // selected - The name of the newly selected view. - // - // Returns nothing. - // - onNavChange: function (selected) { - var isGrid = selected === 'grid'; - this.grid[isGrid ? 'show' : 'hide'](); - this.chart[isGrid ? 'hide' : 'show'](); - }, - - // Public: Toggles the display of the editor panel. - // - // Used as a callback function for the NavigationView "toggle-editor" event. - // - // showEditor - True if the editor should be visible. - // - // Returns nothing. - // - onNavToggleEditor: function (showEditor) { - this.el.toggleClass('dataexplorer-tableview-hide-editor', !showEditor); - this.redraw(); - }, - - // Public: Updates the chart view when the editor is submitted. - // - // chart - The chart object to render. - // - // Returns nothing. - // - onEditorSubmit: function (chart) { - this.nav.toggle('chart'); - this.chart.update(chart); - } - }); - - // Public: Navigation element for switching between views. - // - // Handles the toggling of views within the plugin by firing events when - // buttons are clicked within the view. - // - // element - The Element to use as navigation. - // - // Examples - // - // var nav = new NavigationView($('.dataexplorer-tableview-nav')); - // - // // Recieve events when the navigation buttons are clicked. - // nav.bind('change', onNavigationChangeHandler); - // - // Returns a new instance of NavigationView. - // - ui.NavigationView = inherit(ui.View, { - constructor: function NavigationView(element) { - this.__super__.constructor.apply(this, arguments); - - bindAll(this, 'onEditorToggleChange', 'onPanelToggleChange'); - - this.panelButtons = this.$('.dataexplorer-tableview-nav-toggle').buttonset(); - this.panelButtons.change(this.onPanelToggleChange); - - this.editorButton = this.$('#dataexplorer-tableview-nav-editor').button(); - this.editorButton.change(this.onEditorToggleChange); - }, - - // Public: Toggles a navigation button. - // - // Triggers the "change" event with the panel name provided. - // - // panel - The name of a button to be selected. - // - // Examples - // - // nav.toggle("grid"); - // - // Returns itself. - // - toggle: function (panel) { - // Need to fire all these events just to get jQuery UI to change state. - this.$('input[value="' + panel + '"]').click().change().next().click(); - return this; - }, - - // Public: Triggers the "change" event when the navgation changes. - // - // Passes the name of the selected item into all callbacks. - // - // event - An event object. - // - // Returns nothing - // - onPanelToggleChange: function (event) { - this.trigger('change', [event.target.value]); - }, - - // Public: Triggers the "toggle-editor" event when the editor button is - // clicked. Passes true into callbacks if the button is active. - // - // event - An event object. - // - // Returns nothing - // - onEditorToggleChange: function (event) { - this.trigger('toggle-editor', [event.target.checked]); - } - }); - - // Public: Creates and manages a SlickGrid instance for displaying the - // resource data in a useful grid. - // - // SlickGrid documentation: http://github.com/mleibman/SlickGrid/wiki - // - // element - The Element to use as a container for the SlickGrid. - // columns - Column options formatted for use in the SlickGrid container. - // data - Data Object formatted for use in the SlickGrid. - // options - Additional instance and SlickGrid options. - // - // Examples - // - // var grid = new GridView($('.dataexplorer-tableview-grid'), columns, data); - // - // Returns a new instance of GridView. - // - ui.GridView = inherit(ui.View, { - constructor: function GridView(element, columns, data, options) { - this.__super__.constructor.apply(this, arguments); - - bindAll(this, '_onSort', 'redraw'); - - this.dirty = false; - this.columns = columns; - this.data = data; - this.grid = new Slick.Grid(element, data, columns, $.extend({ - enableColumnReorder: false, - forceFitColumns: true, - syncColumnCellResize: true, - enableCellRangeSelection: false - }, options)); - - this.grid.onSort = this._onSort; - - // In order to extend the resize handles across into the adjacent column - // we need to disable overflow hidden and increase each cells z-index. - // We then wrap the contents in order to reapply the overflow hidden. - this.$('.slick-header-column') - .wrapInner('
    ') - .css('overflow', 'visible') - .css('z-index', function (index) { - return columns.length - index; - }); - - new Slick.Controls.ColumnPicker(this.columns, this.grid); - }, - - // Public: Reveals the view. - // - // If the dirty property is true then it will redraw the grid. - // - // Examples - // - // grid.show(); - // - // Returns itself. - // - show: function () { - this.__super__.show.apply(this, arguments); - if (this.dirty) { - this.redraw(); - this.dirty = false; - } - return this; - }, - - // Public: Redraws the grid. - // - // The grid will only be drawn if the element is visible. If hidden the - // dirty property will be set to true and the grid redrawn the next time - // the view is shown. - // - // Examples - // - // grid.redraw(); - // - // Returns itself. - // - redraw: function () { - if (this.el.is(':visible')) { - this.grid.resizeCanvas(); - this.grid.autosizeColumns(); - } else { - this.dirty = true; - } - }, - - // Public: Sort callback for the SlickGrid grid. - // - // Called when the grids columns are re-ordered. Accepts the selected - // column and the direction and should sort the data property. - // - // column - The column object being sorted. - // sortAsc - True if the solumn should be sorted by ascending items. - // - // Returns nothing. - // - _onSort: function (column, sortAsc) { - this.data.sort(function (a, b) { - var x = a[column.field], - y = b[column.field]; - - if (x == y) { - return 0; - } - return (x > y ? 1 : -1) * (sortAsc ? 1 : -1); - }); - this.grid.invalidate(); - } - }); - - // Public: Creates a wrapper around a jQuery.Flot() chart. - // - // Currently a very basic implementation that accepts data prepared for the - // SlickGrid, ie columns and data objects and uses them to generate a canvas - // chart. - // - // Flot documentation: http://people.iola.dk/olau/flot/API.txt - // - // element - Element to use as a container for the Flot canvas. - // columns - Array of column data. - // data - Data Object. - // chart - Optional chart data to load. - // - // Examples - // - // new ChartView($('.dataexplorer-tableview-chart'), columns, data, { - // id: 'my-chart-id', // Any unique id for the chart used for storage. - // type: 'line', // ID of one of the ChartView.TYPES. - // groups: 'column-2', // The column to use as the x-axis. - // series: ['column-3', 'column-4'] // Columns to use as the series. - // }); - // - // Returns a new instance of ChartView. - // - ui.ChartView = inherit(ui.View, { - constructor: function ChartView(element, columns, data, chart) { - this.__super__.constructor.apply(this, arguments); - this.data = data; - this.columns = columns; - this.chart = chart; - this.createPlot((chart && chart.type) || 'line'); - this.draw(); - }, - - // Public: Creates a new Flot chart and assigns it to the plot property. - // - // typeId - The id String of the grid to create used to load chart - // specific options on creation. - // - // Examples - // - // chart.createPlot('line'); - // - // Returns itself. - // - createPlot: function (typeId) { - var type = ui.ChartView.findTypeById(typeId), - options = type && type.getOptions ? type.getOptions(this) : {}; - - this.plot = $.plot(this.el, this.createSeries(), options); - return this; - }, - - // Public: Creates the series/data Array required by jQuery.plot() - // - // Examples - // - // $.plot(editor.el, editor.createSeries(), options); - // - // Returns an Array containing points for each series in the chart. - // - createSeries: function () { - var series = [], view = this; - if (this.chart) { - $.each(this.chart.series, function (seriesIndex, field) { - var points = []; - $.each(view.data, function (index) { - var x = this[view.chart.groups], y = this[field]; - if (typeof x === 'string') { - x = index; - } - points.push([x, y]); - }); - series.push({data: points, label: view._getColumnName(field)}); - }); - } - return series; - }, - - // Public: Redraws the chart with regenerated series data. - // - // Usually .update() will be called instead. - // - // Returns itself. - // - draw: function () { - this.plot.setData(this.createSeries()); - return this.redraw(); - }, - - // Public: Updates the current plot with a new chart Object. - // - // chart - A chart Object usually provided by the EditorView. - // - // Examples - // - // editor.bind('submit', function (chart) { - // chart.update(chart); - // }); - // - // Returns itself. - // - update: function (chart) { - if (!this.chart || chart.type !== this.chart.type) { - this.createPlot(chart.type); - } - this.chart = chart; - this.draw(); - return this; - }, - - // Public: Redraws the current chart in the canvas. - // - // Used if the chart data has changed or the viewport has been resized. - // - // Examples - // - // $(window).resize(function () { - // chart.redraw(); - // }); - // - // Returns itself. - // - redraw: function () { - this.plot.resize(); - this.plot.setupGrid(); - this.plot.draw(); - return this; - }, - - // Public: Gets the human readable column name for the field id. - // - // field - A field id String used in the data object. - // - // Examples - // - // chart._getColumnName('column-1'); - // - // Returns the String column name. - // - _getColumnName: function (field) { - for (var i = 0, count = this.columns.length; i < count; i += 1) { - if (this.columns[i].field === field) { - return this.columns[i].name; - } - } - return name; - } - }, { - // Array of chart formatters. They require an id and name attribute and - // and optional getOptions() method. Used to generate different chart types. - // - // id - A unique id String for the chart type. - // name - A human readable name for the type. - // getOptions - Function that accepts an instance of ChartView and returns - // an options object suitable for use in $.plot(); - // - TYPES: [{ - id: 'line', - name: 'Line Chart' - }, { - id: 'bar', - name: 'Bar Chart (draft)', - getOptions: function (view) { - return { - series: { - lines: {show: false}, - bars: { - show: true, - barWidth: 1, - align: "left", - fill: true - } - }, - xaxis: { - tickSize: 1, - tickLength: 1, - tickFormatter: function (val) { - if (view.data[val]) { - return view.data[val][view.chart.groups]; - } - return ''; - } - } - }; - } - }], - - // Public: Helper method for findind a chart type by id key. - // - // id - The id key to search for in the ChartView.TYPES Array. - // - // Examples - // - // var type = ChartView.findTypeById('line'); - // - // Returns the type object or null if not found. - // - findTypeById: function (id) { - var filtered = $.grep(this.TYPES, function (type) { - return type.id === id; - }); - return filtered.length ? filtered[0] : null; - } - }); - - // Public: Creates a form for editing chart metadata. - // - // Publishes "submit" and "save" events providing a chart Obejct to all - // registered callbacks. - // - // element - The Element to use as the form wrapper. - // columns - Array of columns that are used by the data set. - // chart - Optional chart Object to display on load. - // - // Examples - // - // new EditorView($('.dataexplorer-tableview-editor'), columns, { - // id: 'my-chart-id', - // type: 'line', - // groups: 'column-2', - // series: ['column-3', 'column-4'] - // }); - // - // Returns a new instance of EditorView. - // - ui.EditorView = inherit(ui.View, { - constructor: function EditorView(element, columns, chart) { - this.__super__.constructor.apply(this, arguments); - - bindAll(this, 'onAdd', 'onRemove', 'onSubmit', 'onSave'); - - this.columns = columns; - this.type = this.$('.dataexplorer-tableview-editor-type select'); - this.groups = this.$('.dataexplorer-tableview-editor-group select'); - this.series = this.$('.dataexplorer-tableview-editor-series select'); - this.id = this.$('.dataexplorer-tableview-editor-id'); - - this.$('button').button(); - this.save = this.$('.dataexplorer-tableview-editor-save').click(this.onSave); - this.el.bind('submit', this.onSubmit); - this.el.delegate('a[href="#remove"]', 'click', this.onRemove); - this.el.delegate('select', 'change', this.onSubmit); - - this.$('.dataexplorer-tableview-editor-add').click(this.onAdd); - - this.setupTypeOptions().setupColumnOptions(); - - this.seriesClone = this.series.parent().clone(); - - if (chart) { - this.load(chart); - } - }, - - // Public: Fills the "type" select box with options. - // - // Returns itself. - // - setupTypeOptions: function () { - var types = {}; - // TODO: This shouldn't be referenced directly but passed in as an option. - $.each(ui.ChartView.TYPES, function () { - types[this.id] = this.name; - }); - - this.type.html(this._createOptions(types)); - return this; - }, - - // Public: Fills the groups and series select elements with options. - // - // Returns nothing. - // - setupColumnOptions: function () { - var options = {}, optionsString = ''; - $.each(this.columns, function (index, column) { - options[column.field] = column.name; - }); - optionsString = this._createOptions(options); - - this.groups.html(optionsString); - this.series.html(optionsString); - return this; - }, - - // Public: Adds a new empty series select box to the editor. - // - // All but the first select box will have a remove button that allows them - // to be removed. - // - // Examples - // - // editor.addSeries(); - // - // Returns itself. - // - addSeries: function () { - var element = this.seriesClone.clone(), - label = element.find('label'), - index = this.series.length; - - this.$('ul').append(element); - this.updateSeries(); - - label.append('Remove'); - label.find('span').text(String.fromCharCode(this.series.length + 64)); - - return this; - }, - - // Public: Removes a series list item from the editor. - // - // Also updates the labels of the remianing series elements. - // - // element - A jQuery wrapped list item Element to remove. - // - // Examples - // - // // Remove the third series element. - // editor.removeSeries(editor.series.eq(2).parent()); - // - // Returns itself. - // - removeSeries: function (element) { - element.remove(); - this.updateSeries(); - this.series.each(function (index) { - if (index > 0) { - var labelSpan = $(this).prev().find('span'); - labelSpan.text(String.fromCharCode(index + 65)); - } - }); - return this.submit(); - }, - - // Public: Resets the series property to reference the select elements. - // - // Returns itself. - // - updateSeries: function () { - this.series = this.$('.dataexplorer-tableview-editor-series select'); - return this; - }, - - // Public: Loads a chart into the editor. - // - // For an example of the chart object structure see the ChartView docs. - // - // chart - A chart Object to be loaded. - // - // Examples - // - // editor.load(chart); - // - // Returns itself. - // - load: function (chart) { - var editor = this; - this._selectOption(this.type, chart.type); - this._selectOption(this.groups, chart.groups); - - this.id.val(chart.id); - this.type.val(chart.type); - $.each(chart.series, function update(index, option) { - var element = editor.series.eq(index); - if (!element.length) { - editor.addSeries(); - return update(index, option); - } - editor._selectOption(element, option); - }); - - return this; - }, - - // Public: Submits the current form. - // - // Triggers the "submit" event providing a chart object to all listeners. - // - // Examples - // - // editor.bind("submit", chart.update); - // editor.submit(); - // - // Returns itself. - // - submit: function () { - return this._triggerChartData('submit'); - }, - - // Public: Toggles the loading state on the view. - // - // Freezes all interface elements and displays a loading message. - // - // show - If false disables the loading state. - // - // Examples - // - // // Set the state to loading. - // editor.loading(); - // - // // Disable the loading state. - // editor.loading(false); - // - // Returns itself. - // - loading: function (show) { - var action = show === false ? 'enable' : 'disable'; - - this.$('select').attr('disabled', show !== false); - this.save.button(action); - - this._updateSaveText(show === false ? null : 'Loading...'); - - return this; - }, - - // Public: Toggles the saving state on the view. - // - // show - If false disables the saving state. - // - // Examples - // - // // Set the state to saving. - // editor.saving(); - // - // // Disable the saving state. - // editor.saving(false); - // - // Returns itself. - // - saving: function (show) { - this.disableSave(show); - this._updateSaveText(show === false ? null : 'Saving...'); - return this; - }, - - // Public: Toggles the save button state between enabled/disabled. - // - // disable - If false enables the button. - // - // Returns itself. - // - disableSave: function (disable) { - this.save.button(disable === false ? 'enable' : 'disable'); - return this; - }, - - // Public: Event callback for the "Add series" button. - // - // event - A jQuery Event object. - // - // Examples - // - // $('button').click(event.onAdd); - // - // Returns nothing. - // - onAdd: function (event) { - event.preventDefault(); - this.addSeries(); - }, - - // Public: Event callback for the "Remove series" button. - // - // event - A jQuery Event object. - // - // Examples - // - // $('button').click(event.onRemove); - // - // Returns nothing. - // - onRemove: function (event) { - event.preventDefault(); - var element = $(event.target).parents('.dataexplorer-tableview-editor-series'); - this.removeSeries(element); - }, - - // Public: Event callback for the "Save" button. - // - // Triggers the "save" event passing a chart object to all registered - // callbacks. - // - // event - A jQuery Event object. - // - // Examples - // - // $('button.save').click(editor.onSave); - // - // Returns nothing. - // - onSave: function (event) { - event.preventDefault(); - this._triggerChartData('save'); - }, - - // Public: Event callback for the editor form. - // - // event - A jQuery Event object. - // - // Examples - // - // $('form.editor').submit(editor.onSubmit); - // - // Returns nothing. - // - onSubmit: function (event) { - event && event.preventDefault(); - this.submit(); - }, - - // Updates the text on the save button. - // - // If no text is provided reverts to the original button text. - // - // text - A text String to use in the button. - // - // Examples - // - // editor._updateSaveText('Now saving!'); - // - // Returns nothing. - // - _updateSaveText: function (text) { - var span = this.save.find('span'), - original = span.data('default'); - - if (!original) { - span.data('default', span.text()); - } - - span.text(text || original); - }, - - // Triggers an event on the editor and passes a chart object to callbacks. - // - // topic - Topic String for the event to fire. - // - // Examples - // - // editor.bind('save', function (chart) { - // // DO something with the chart. - // }); - // editor._triggerChartData('save'); - // - // Returns - // - _triggerChartData: function (topic) { - var series = this.series.map(function () { - return $(this).val(); - }); - - return this.trigger(topic, [{ - id: this.id.val(), - type: this.type.val(), - groups: this.groups.val(), - series: $.makeArray(series) - }]); - }, - - // Finds an option by "value" in a select element and makes it selected. - // - // select - A jQuery wrapped select Element. - // option - The String value of the options "value" attribute. - // - // Examples - // - // // For - // editor._selectOption(mySelect, 'bill'); - // - // Returns nothing. - // - _selectOption: function (select, option) { - select.find('[value="' + option + '"]').attr('selected', 'selected'); - }, - - // Creates a String of option elements. - // - // options - An object of value/text pairs. - // - // Examples - // - // var html = editor._createOptions({ - // value1: 'Value 1', - // value2: 'Value 2' - // }); - // - // Returns a String of HTML. - // - _createOptions: function (options) { - var html = []; - $.each(options, function (value, text) { - html.push(''); - }); - return html.join(''); - } - }); - - // Exports the UI and createTableView() methods onto the plugin object. - $.extend(true, this, {DATAEXPLORER: {TABLEVIEW: { - - UI: ui, - - // Public: Helper method for creating a new view. - // - // element - The main DOM Element used for the plugin. - // columns - The columns array for the data rows formatted for SlickGrid. - // data - A data object formatted for use in SlickGrid. - // chart - An optional chart object to load. - // - // Examples - // - // TABLEVIEW.createTableView($('my-view'), columns, data); - // - // Returns a new instance of MainView. - // - createTableView: function (element, columns, data, chart) { - return new ui.MainView(element, columns, data, chart); - } - }}}); - -})(jQuery); diff --git a/ckan/public/scripts/outside.js b/ckan/public/scripts/outside.js deleted file mode 100644 index 12f3ce33058..00000000000 --- a/ckan/public/scripts/outside.js +++ /dev/null @@ -1,66 +0,0 @@ -var CKAN = CKAN || {}; - -(function ($) { - $(document).ready(function () { - CKAN.DataPreviewIframe.attachToIframe(); - }); -}(jQuery)); - -/* =========================== */ -/* == Data Previewer Iframe == */ -/* =========================== */ -CKAN.DataPreviewIframe = function ($, my) { - // ** Public: resizes a data preview iframe to match the content - var resize = function(iframe) { - var self = iframe; - offset = 0; - var height = iframe.contents().height(); - iframe.animate({height: height+offset}, height); - }; - my.$iframes = $('.ckanext-datapreview-iframe'); - - // **Public: Attaches lad listener to preview iframes** - // - // Returns nothing. - my.attachToIframe = function() { - $.each(my.$iframes, function(index, iframe) { - var recalibrate = function() { - resizeTimer = setTimeout(function() { - resize(iframe); - }, 100); - }; - iframe = $(iframe); - iframe.load(function() { - loc = window.location.protocol+'//'+window.location.host; - if (iframe.attr('src').substring(0, loc.length) === loc) { - recalibrate(); - iframe.contents().find('body').resize(function() { - recalibrate(); - }); - } - else { - iframe.animate({height: 600}, 600); - } - }); - - var resizeTimer; - // firefox caches iframes so force it to get fresh content - if(/#$/.test(this.src)){ - this.src = this.src.substr(0, this.src.length - 1); - } else { - this.src = this.src + '#'; - } - }); - }; - - - // ** Public: connect to child iframe context - my.getChild = function(iframe) { - return $(iframe)[0].contentWindow; - }; - - // Export the CKANEXT object onto the window. - $.extend(true, window, {CKANEXT: {}}); - CKANEXT.DATAPREVIEW = my; - return my; -}(jQuery, CKAN.DataPreview || {}); diff --git a/ckan/public/scripts/templates.js b/ckan/public/scripts/templates.js deleted file mode 100644 index 8256567345c..00000000000 --- a/ckan/public/scripts/templates.js +++ /dev/null @@ -1,158 +0,0 @@ -var CKAN = CKAN || {}; -CKAN.Templates = CKAN.Templates || {}; - -CKAN.Templates.resourceUpload = ' \ -
    \ -
    \ - \ -
    \ - \ -
    \ -
    \ - \ -
    \ - \ -
    '; - - - -CKAN.Templates.resourceEntry = ' \ -
  • \ - \ - \ - ${resource.name}\ - \ -
  • '; - -var youCanUseMarkdownString = CKAN.Strings.youCanUseMarkdown.replace('%a', '').replace('%b', ''); -var datesAreInISOString = CKAN.Strings.datesAreInISO.replace('%a', '').replace('%b', '').replace('%c', '').replace('%d', ''); - -// TODO it would be nice to unify this with the markdown editor specified in helpers.py -CKAN.Templates.resourceDetails = ' \ -