openshift-origin-console 1.3.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (291) hide show
  1. data/COPYRIGHT +1 -0
  2. data/Gemfile +21 -0
  3. data/LICENSE +203 -0
  4. data/README.md +123 -0
  5. data/Rakefile +44 -0
  6. data/app/assets/images/cartridge-edge.gif +0 -0
  7. data/app/assets/images/console/arrow-down.png +0 -0
  8. data/app/assets/images/console/console-sprite.png +0 -0
  9. data/app/assets/images/favicon-32.png +0 -0
  10. data/app/assets/images/loader-dark.gif +0 -0
  11. data/app/assets/images/loader.gif +0 -0
  12. data/app/assets/images/sprite-vert.png +0 -0
  13. data/app/assets/javascripts/console.js +10 -0
  14. data/app/assets/javascripts/console/form.js.coffee +51 -0
  15. data/app/assets/stylesheets/_alerts.scss +84 -0
  16. data/app/assets/stylesheets/_breadcrumbs.scss +31 -0
  17. data/app/assets/stylesheets/_buttons.scss +229 -0
  18. data/app/assets/stylesheets/_code.scss +86 -0
  19. data/app/assets/stylesheets/_custom.scss +207 -0
  20. data/app/assets/stylesheets/_footer.scss +54 -0
  21. data/app/assets/stylesheets/_forms.scss +710 -0
  22. data/app/assets/stylesheets/_grid.scss +28 -0
  23. data/app/assets/stylesheets/_input-prepend-append.scss +138 -0
  24. data/app/assets/stylesheets/_labels.scss +40 -0
  25. data/app/assets/stylesheets/_mixins.scss +76 -0
  26. data/app/assets/stylesheets/_override-variables.scss +1 -0
  27. data/app/assets/stylesheets/_responsive.scss +438 -0
  28. data/app/assets/stylesheets/_ribbon.scss +57 -0
  29. data/app/assets/stylesheets/_type.scss +306 -0
  30. data/app/assets/stylesheets/_utilities.scss +10 -0
  31. data/app/assets/stylesheets/_variables.scss +131 -0
  32. data/app/assets/stylesheets/common.css.scss +82 -0
  33. data/app/assets/stylesheets/console/_application.scss +194 -0
  34. data/app/assets/stylesheets/console/_base.scss +26 -0
  35. data/app/assets/stylesheets/console/_breadcrumbs.scss +32 -0
  36. data/app/assets/stylesheets/console/_buttons.scss +214 -0
  37. data/app/assets/stylesheets/console/_core.scss +1002 -0
  38. data/app/assets/stylesheets/console/_dropdowns.scss +63 -0
  39. data/app/assets/stylesheets/console/_help.scss +54 -0
  40. data/app/assets/stylesheets/console/_mixins.scss +11 -0
  41. data/app/assets/stylesheets/console/_navbar.scss +415 -0
  42. data/app/assets/stylesheets/console/_ribbon.scss +82 -0
  43. data/app/assets/stylesheets/console/_tile.scss +122 -0
  44. data/app/assets/stylesheets/origin.css.scss +37 -0
  45. data/app/controllers/account/dashboard.rb +13 -0
  46. data/app/controllers/account_controller.rb +3 -0
  47. data/app/controllers/application_types_controller.rb +80 -0
  48. data/app/controllers/applications_controller.rb +183 -0
  49. data/app/controllers/building_controller.rb +81 -0
  50. data/app/controllers/capability_aware.rb +18 -0
  51. data/app/controllers/cartridge_types_controller.rb +53 -0
  52. data/app/controllers/cartridges_controller.rb +43 -0
  53. data/app/controllers/console/auth/basic.rb +65 -0
  54. data/app/controllers/console/auth/none.rb +5 -0
  55. data/app/controllers/console/auth/remote_user.rb +69 -0
  56. data/app/controllers/console/rescue.rb +48 -0
  57. data/app/controllers/console_controller.rb +19 -0
  58. data/app/controllers/console_index_controller.rb +14 -0
  59. data/app/controllers/domain_aware.rb +26 -0
  60. data/app/controllers/domain_session_sweeper.rb +29 -0
  61. data/app/controllers/domains_controller.rb +30 -0
  62. data/app/controllers/keys_controller.rb +43 -0
  63. data/app/controllers/scaling_controller.rb +46 -0
  64. data/app/controllers/sshkey_aware.rb +23 -0
  65. data/app/controllers/sshkey_session_sweeper.rb +29 -0
  66. data/app/controllers/user_session_sweeper.rb +29 -0
  67. data/app/helpers/console/community_helper.rb +78 -0
  68. data/app/helpers/console/console_helper.rb +26 -0
  69. data/app/helpers/console/help_helper.rb +270 -0
  70. data/app/helpers/console/html5_boilerplate_helper.rb +63 -0
  71. data/app/helpers/console/layout_helper.rb +277 -0
  72. data/app/helpers/console/model_helper.rb +106 -0
  73. data/app/helpers/console/secured_helper.rb +5 -0
  74. data/app/models/alias.rb +10 -0
  75. data/app/models/application.rb +148 -0
  76. data/app/models/application_associations.rb +36 -0
  77. data/app/models/application_template.rb +90 -0
  78. data/app/models/application_type.rb +258 -0
  79. data/app/models/async_aware.rb +60 -0
  80. data/app/models/capabilities.rb +62 -0
  81. data/app/models/cartridge.rb +122 -0
  82. data/app/models/cartridge_type.rb +140 -0
  83. data/app/models/domain.rb +44 -0
  84. data/app/models/domain_associations.rb +33 -0
  85. data/app/models/embedded.rb +11 -0
  86. data/app/models/gear.rb +13 -0
  87. data/app/models/gear_group.rb +104 -0
  88. data/app/models/key.rb +87 -0
  89. data/app/models/quickstart.rb +135 -0
  90. data/app/models/rest_api.rb +130 -0
  91. data/app/models/rest_api/base.rb +781 -0
  92. data/app/models/rest_api/cacheable.rb +91 -0
  93. data/app/models/rest_api/environment.rb +13 -0
  94. data/app/models/rest_api/info.rb +34 -0
  95. data/app/models/rest_api/log_subscriber.rb +29 -0
  96. data/app/models/rest_api/railties/controller_runtime.rb +37 -0
  97. data/app/models/user.rb +27 -0
  98. data/app/models/user_associations.rb +6 -0
  99. data/app/views/account/_domain.html.haml +14 -0
  100. data/app/views/account/_keys.html.haml +20 -0
  101. data/app/views/account/_user.html.haml +5 -0
  102. data/app/views/account/show.html.haml +15 -0
  103. data/app/views/application_templates/_application_template.html.haml +5 -0
  104. data/app/views/application_types/_application_type.html.haml +19 -0
  105. data/app/views/application_types/_custom.html.haml +19 -0
  106. data/app/views/application_types/_persisted.html.haml +26 -0
  107. data/app/views/application_types/_tile.html.haml +9 -0
  108. data/app/views/application_types/index.html.haml +87 -0
  109. data/app/views/application_types/search.html.haml +67 -0
  110. data/app/views/application_types/show.html.haml +219 -0
  111. data/app/views/applications/_application.html.haml +34 -0
  112. data/app/views/applications/_applications_filter.html.haml +8 -0
  113. data/app/views/applications/_footer.html.haml +0 -0
  114. data/app/views/applications/_name.html.haml +28 -0
  115. data/app/views/applications/delete.html.haml +19 -0
  116. data/app/views/applications/get_started.html.haml +145 -0
  117. data/app/views/applications/index.html.haml +55 -0
  118. data/app/views/applications/show.html.haml +193 -0
  119. data/app/views/building/delete.html.haml +22 -0
  120. data/app/views/building/new.html.haml +57 -0
  121. data/app/views/building/show.html.haml +12 -0
  122. data/app/views/cartridge_types/_cartridge_type.html.haml +61 -0
  123. data/app/views/cartridge_types/index.html.haml +37 -0
  124. data/app/views/cartridge_types/show.html.haml +21 -0
  125. data/app/views/cartridges/next_steps.html.haml +58 -0
  126. data/app/views/cartridges/show.html.haml +1 -0
  127. data/app/views/console/error.html.haml +58 -0
  128. data/app/views/console/help.html.haml +90 -0
  129. data/app/views/console/not_found.html.haml +69 -0
  130. data/app/views/console/unauthorized.html.haml +7 -0
  131. data/app/views/domains/_domain.html.haml +14 -0
  132. data/app/views/domains/_form.html.haml +13 -0
  133. data/app/views/domains/edit.html.haml +5 -0
  134. data/app/views/domains/new.html.haml +6 -0
  135. data/app/views/keys/_form.html.haml +14 -0
  136. data/app/views/keys/_simple_form.html.haml +14 -0
  137. data/app/views/keys/new.html.haml +2 -0
  138. data/app/views/layouts/_footer.html.haml +38 -0
  139. data/app/views/layouts/_head.html.haml +35 -0
  140. data/app/views/layouts/console.html.haml +60 -0
  141. data/app/views/layouts/console/_header.html.haml +44 -0
  142. data/app/views/layouts/console/_identity.html.haml +7 -0
  143. data/app/views/layouts/console/_javascripts.html.haml +5 -0
  144. data/app/views/layouts/console/_stylesheets.html.haml +6 -0
  145. data/app/views/scaling/delete.html.haml +17 -0
  146. data/app/views/scaling/new.html.haml +24 -0
  147. data/app/views/scaling/show.html.haml +81 -0
  148. data/app/views/shared/_tracking.html.haml +0 -0
  149. data/conf/console.conf.example +108 -0
  150. data/conf/openshift_console.conf +10 -0
  151. data/config/cartridge_types.yml +54 -0
  152. data/config/initializers/barista_config.rb +86 -0
  153. data/config/initializers/cartridge_types.rb +5 -0
  154. data/config/initializers/console_security.rb +1 -0
  155. data/config/initializers/date_helper.rb +5 -0
  156. data/config/initializers/extended_logger.rb +51 -0
  157. data/config/initializers/formtastic.rb +100 -0
  158. data/config/initializers/inflections.rb +38 -0
  159. data/config/initializers/rdiscount.rb +8 -0
  160. data/config/initializers/rest_api.rb +22 -0
  161. data/config/initializers/sass.rb +30 -0
  162. data/config/initializers/session_trace.rb +32 -0
  163. data/config/initializers/x_frame_options.rb +53 -0
  164. data/config/locales/en.yml +12 -0
  165. data/lib/active_resource/associations.rb +107 -0
  166. data/lib/active_resource/associations/builder/association.rb +35 -0
  167. data/lib/active_resource/associations/builder/belongs_to.rb +5 -0
  168. data/lib/active_resource/associations/builder/has_many.rb +5 -0
  169. data/lib/active_resource/associations/builder/has_one.rb +5 -0
  170. data/lib/active_resource/persistent_connection.rb +341 -0
  171. data/lib/active_resource/persistent_http_mock.rb +68 -0
  172. data/lib/active_resource/reflection.rb +78 -0
  173. data/lib/console.rb +8 -0
  174. data/lib/console/config_file.rb +13 -0
  175. data/lib/console/configuration.rb +163 -0
  176. data/lib/console/engine.rb +28 -0
  177. data/lib/console/formtastic/bootstrap_form_builder.rb +369 -0
  178. data/lib/console/rails/app_redirector.rb +40 -0
  179. data/lib/console/rails/filter_hash.rb +15 -0
  180. data/lib/console/rails/routes.rb +51 -0
  181. data/lib/console/version.rb +5 -0
  182. data/lib/tasks/assets.rake +79 -0
  183. data/lib/tasks/stats.rake +18 -0
  184. data/lib/tasks/test_suites.rake +73 -0
  185. data/test/coverage_helper.rb +27 -0
  186. data/test/fixtures/cartridges.json +1 -0
  187. data/test/fixtures/quickstarts.csv +3 -0
  188. data/test/functional/account_controller_test.rb +14 -0
  189. data/test/functional/application_types_controller_test.rb +251 -0
  190. data/test/functional/applications_controller_sanity_test.rb +26 -0
  191. data/test/functional/applications_controller_test.rb +365 -0
  192. data/test/functional/building_controller_test.rb +203 -0
  193. data/test/functional/cartridge_types_controller_isolation_test.rb +68 -0
  194. data/test/functional/cartridge_types_controller_test.rb +48 -0
  195. data/test/functional/cartridges_controller_test.rb +83 -0
  196. data/test/functional/console_auth_basic_controller_test.rb +82 -0
  197. data/test/functional/console_auth_remote_user_controller_test.rb +90 -0
  198. data/test/functional/console_index_controller_test.rb +22 -0
  199. data/test/functional/domains_controller_test.rb +194 -0
  200. data/test/functional/keys_controller_test.rb +163 -0
  201. data/test/functional/quickstarts.json +18 -0
  202. data/test/functional/scaling_controller_test.rb +153 -0
  203. data/test/integration/assets_test.rb +34 -0
  204. data/test/integration/help_link_test.rb +43 -0
  205. data/test/integration/quickstarts_test.rb +24 -0
  206. data/test/integration/rescue_from_test.rb +25 -0
  207. data/test/integration/rest_api/application_test.rb +115 -0
  208. data/test/integration/rest_api/cartridge_test.rb +44 -0
  209. data/test/integration/rest_api/cartridge_type_test.rb +143 -0
  210. data/test/integration/rest_api/domain_test.rb +91 -0
  211. data/test/integration/rest_api/info_test.rb +9 -0
  212. data/test/integration/rest_api/key_test.rb +85 -0
  213. data/test/integration/static_pages_test.rb +44 -0
  214. data/test/rails_app/Rakefile +7 -0
  215. data/test/rails_app/app/controllers/application_controller.rb +5 -0
  216. data/test/rails_app/config.ru +4 -0
  217. data/test/rails_app/config/application.rb +48 -0
  218. data/test/rails_app/config/boot.rb +10 -0
  219. data/test/rails_app/config/database.yml +25 -0
  220. data/test/rails_app/config/environment.rb +5 -0
  221. data/test/rails_app/config/environments/development.rb +38 -0
  222. data/test/rails_app/config/environments/production.rb +70 -0
  223. data/test/rails_app/config/environments/test.rb +43 -0
  224. data/test/rails_app/config/initializers/auth.rb +0 -0
  225. data/test/rails_app/config/initializers/backtrace_silencers.rb +7 -0
  226. data/test/rails_app/config/initializers/inflections.rb +10 -0
  227. data/test/rails_app/config/initializers/mime_types.rb +5 -0
  228. data/test/rails_app/config/initializers/secret_token.rb +7 -0
  229. data/test/rails_app/config/initializers/session_store.rb +8 -0
  230. data/test/rails_app/config/locales/en.yml +5 -0
  231. data/test/rails_app/config/routes.rb +4 -0
  232. data/test/rails_app/script/rails +6 -0
  233. data/test/support/auth.rb +111 -0
  234. data/test/support/base.rb +142 -0
  235. data/test/support/errors.rb +28 -0
  236. data/test/support/rest_api.rb +189 -0
  237. data/test/test_helper.rb +14 -0
  238. data/test/unit/active_model_compliance_test.rb +23 -0
  239. data/test/unit/async_aware_test.rb +55 -0
  240. data/test/unit/configuration_test.rb +158 -0
  241. data/test/unit/filter_hash_test.rb +64 -0
  242. data/test/unit/helpers/model_helper_test.rb +61 -0
  243. data/test/unit/overrides_test.rb +9 -0
  244. data/test/unit/rest_api_test.rb +1590 -0
  245. data/vendor/assets/javascripts/MIT-LICENSE.txt +20 -0
  246. data/vendor/assets/javascripts/bootstrap-collapse.js +157 -0
  247. data/vendor/assets/javascripts/bootstrap-dropdown.js +100 -0
  248. data/vendor/assets/javascripts/bootstrap-tab.js +135 -0
  249. data/vendor/assets/javascripts/bootstrap-transition.js +61 -0
  250. data/vendor/assets/javascripts/jquery.spin.js +47 -0
  251. data/vendor/assets/javascripts/jquery.ui.widget.js +16 -0
  252. data/vendor/assets/javascripts/jquery_cookie.js +41 -0
  253. data/vendor/assets/javascripts/jquery_validate_min.js +51 -0
  254. data/vendor/assets/javascripts/modernizr.min.js +2 -0
  255. data/vendor/assets/javascripts/plugins.js +16 -0
  256. data/vendor/assets/stylesheets/bootstrap/_accordion.scss +28 -0
  257. data/vendor/assets/stylesheets/bootstrap/_alerts.scss +70 -0
  258. data/vendor/assets/stylesheets/bootstrap/_breadcrumbs.scss +22 -0
  259. data/vendor/assets/stylesheets/bootstrap/_button-groups.scss +147 -0
  260. data/vendor/assets/stylesheets/bootstrap/_buttons.scss +183 -0
  261. data/vendor/assets/stylesheets/bootstrap/_carousel.scss +121 -0
  262. data/vendor/assets/stylesheets/bootstrap/_close.scss +18 -0
  263. data/vendor/assets/stylesheets/bootstrap/_code.scss +57 -0
  264. data/vendor/assets/stylesheets/bootstrap/_component-animations.scss +18 -0
  265. data/vendor/assets/stylesheets/bootstrap/_dropdowns.scss +130 -0
  266. data/vendor/assets/stylesheets/bootstrap/_forms.scss +522 -0
  267. data/vendor/assets/stylesheets/bootstrap/_grid.scss +8 -0
  268. data/vendor/assets/stylesheets/bootstrap/_hero-unit.scss +20 -0
  269. data/vendor/assets/stylesheets/bootstrap/_labels.scss +32 -0
  270. data/vendor/assets/stylesheets/bootstrap/_layouts.scss +17 -0
  271. data/vendor/assets/stylesheets/bootstrap/_mixins.scss +602 -0
  272. data/vendor/assets/stylesheets/bootstrap/_modals.scss +84 -0
  273. data/vendor/assets/stylesheets/bootstrap/_navbar.scss +299 -0
  274. data/vendor/assets/stylesheets/bootstrap/_navs.scss +353 -0
  275. data/vendor/assets/stylesheets/bootstrap/_pager.scss +30 -0
  276. data/vendor/assets/stylesheets/bootstrap/_pagination.scss +55 -0
  277. data/vendor/assets/stylesheets/bootstrap/_popovers.scss +49 -0
  278. data/vendor/assets/stylesheets/bootstrap/_progress-bars.scss +95 -0
  279. data/vendor/assets/stylesheets/bootstrap/_reset.scss +126 -0
  280. data/vendor/assets/stylesheets/bootstrap/_scaffolding.scss +33 -0
  281. data/vendor/assets/stylesheets/bootstrap/_sprites.scss +158 -0
  282. data/vendor/assets/stylesheets/bootstrap/_tables.scss +150 -0
  283. data/vendor/assets/stylesheets/bootstrap/_thumbnails.scss +35 -0
  284. data/vendor/assets/stylesheets/bootstrap/_tooltip.scss +35 -0
  285. data/vendor/assets/stylesheets/bootstrap/_type.scss +218 -0
  286. data/vendor/assets/stylesheets/bootstrap/_utilities.scss +23 -0
  287. data/vendor/assets/stylesheets/bootstrap/_variables.scss +107 -0
  288. data/vendor/assets/stylesheets/bootstrap/_wells.scss +17 -0
  289. data/vendor/assets/stylesheets/bootstrap/bootstrap.scss +66 -0
  290. data/vendor/assets/stylesheets/bootstrap/responsive.scss +334 -0
  291. metadata +506 -0
@@ -0,0 +1,84 @@
1
+ // MODALS
2
+ // ------
3
+
4
+ // Recalculate z-index where appropriate
5
+ .modal-open {
6
+ .dropdown-menu { z-index: $zindexDropdown + $zindexModal; }
7
+ .dropdown.open { *z-index: $zindexDropdown + $zindexModal; }
8
+ .popover { z-index: $zindexPopover + $zindexModal; }
9
+ .tooltip { z-index: $zindexTooltip + $zindexModal; }
10
+ }
11
+
12
+ // Background
13
+ .modal-backdrop {
14
+ position: fixed;
15
+ top: 0;
16
+ right: 0;
17
+ bottom: 0;
18
+ left: 0;
19
+ z-index: $zindexModalBackdrop;
20
+ background-color: $black;
21
+ // Fade for backdrop
22
+ &.fade { opacity: 0; }
23
+ }
24
+
25
+ .modal-backdrop,
26
+ .modal-backdrop.fade.in {
27
+ @include opacity(80);
28
+ }
29
+
30
+ // Base modal
31
+ .modal {
32
+ position: fixed;
33
+ top: 50%;
34
+ left: 50%;
35
+ z-index: $zindexModal;
36
+ max-height: 500px;
37
+ overflow: auto;
38
+ width: 560px;
39
+ margin: -250px 0 0 -280px;
40
+ background-color: $white;
41
+ border: 1px solid #999;
42
+ border: 1px solid rgba(0,0,0,.3);
43
+ *border: 1px solid #999; /* IE6-7 */
44
+ @include border-radius(6px);
45
+ @include box-shadow(0 3px 7px rgba(0,0,0,0.3));
46
+ @include background-clip(padding-box);
47
+ &.fade {
48
+ @include transition(opacity .3s linear);
49
+ // @include transition(top .3s ease-out);
50
+ top: -25%;
51
+ }
52
+ &.fade.in { top: 50%; }
53
+ }
54
+ .modal-header {
55
+ padding: 9px 15px;
56
+ border-bottom: 1px solid #eee;
57
+ // Close icon
58
+ .close { margin-top: 2px; }
59
+ }
60
+
61
+ // Body (where all modal content resises)
62
+ .modal-body {
63
+ padding: 15px;
64
+ }
65
+ // Remove bottom margin if need be
66
+ .modal-body .modal-form {
67
+ margin-bottom: 0;
68
+ }
69
+
70
+ // Footer (for actions)
71
+ .modal-footer {
72
+ padding: 14px 15px 15px;
73
+ margin-bottom: 0;
74
+ background-color: #f5f5f5;
75
+ border-top: 1px solid #ddd;
76
+ @include border-radius(0 0 6px 6px);
77
+ @include box-shadow(inset 0 1px 0 $white);
78
+ @include clearfix();
79
+ .btn {
80
+ float: right;
81
+ margin-left: 5px;
82
+ margin-bottom: 0; // account for input[type="submit"] which gets the bottom margin like all other inputs
83
+ }
84
+ }
@@ -0,0 +1,299 @@
1
+ // NAVBAR (FIXED AND STATIC)
2
+ // -------------------------
3
+
4
+
5
+ // COMMON STYLES
6
+ // -------------
7
+
8
+ .navbar {
9
+ overflow: visible;
10
+ margin-bottom: $baseLineHeight;
11
+ }
12
+
13
+ // Gradient is applied to it's own element because overflow visible is not honored by IE when filter is present
14
+ .navbar-inner {
15
+ padding-left: 20px;
16
+ padding-right: 20px;
17
+ @include gradient-vertical($navbarBackgroundHighlight, $navbarBackground);
18
+ @include border-radius(4px);
19
+ $shadow: 0 1px 3px rgba(0,0,0,.25), inset 0 -1px 0 rgba(0,0,0,.1);
20
+ @include box-shadow($shadow);
21
+ }
22
+
23
+ // Navbar button for toggling navbar items in responsive layouts
24
+ .btn-navbar {
25
+ display: none;
26
+ float: right;
27
+ padding: 7px 10px;
28
+ margin-left: 5px;
29
+ margin-right: 5px;
30
+ @include buttonBackground($navbarBackgroundHighlight, $navbarBackground);
31
+ $shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 1px 0 rgba(255,255,255,.075);
32
+ @include box-shadow($shadow);
33
+ }
34
+ .btn-navbar .icon-bar {
35
+ display: block;
36
+ width: 18px;
37
+ height: 2px;
38
+ background-color: #f5f5f5;
39
+ @include border-radius(1px);
40
+ @include box-shadow(0 1px 0 rgba(0,0,0,.25));
41
+ }
42
+ .btn-navbar .icon-bar + .icon-bar {
43
+ margin-top: 3px;
44
+ }
45
+ // Override the default collapsed state
46
+ .nav-collapse.collapse {
47
+ height: auto;
48
+ }
49
+
50
+
51
+ // Brand, links, text, and buttons
52
+ .navbar {
53
+ // Hover and active states
54
+ .brand:hover {
55
+ text-decoration: none;
56
+ }
57
+ // Website or project name
58
+ .brand {
59
+ float: left;
60
+ display: block;
61
+ padding: 8px 20px 12px;
62
+ margin-left: -20px; // negative indent to left-align the text down the page
63
+ font-size: 20px;
64
+ font-weight: 200;
65
+ line-height: 1;
66
+ color: $white;
67
+ }
68
+ // Plain text in topbar
69
+ .navbar-text {
70
+ margin-bottom: 0;
71
+ line-height: 40px;
72
+ color: $navbarText;
73
+ a:hover {
74
+ color: $white;
75
+ background-color: transparent;
76
+ }
77
+ }
78
+ // Buttons in navbar
79
+ .btn,
80
+ .btn-group {
81
+ margin-top: 5px; // make buttons vertically centered in navbar
82
+ }
83
+ .btn-group .btn {
84
+ margin-top: 0; // then undo the margin here so we don't accidentally double it
85
+ }
86
+ }
87
+
88
+ // Navbar forms
89
+ .navbar-form {
90
+ margin-bottom: 0; // remove default bottom margin
91
+ @include clearfix();
92
+ input,
93
+ select {
94
+ display: inline-block;
95
+ margin-top: 5px;
96
+ margin-bottom: 0;
97
+ }
98
+ .radio,
99
+ .checkbox {
100
+ margin-top: 5px;
101
+ }
102
+ input[type="image"],
103
+ input[type="checkbox"],
104
+ input[type="radio"] {
105
+ margin-top: 3px;
106
+ }
107
+ .input-append,
108
+ .input-prepend {
109
+ margin-top: 6px;
110
+ white-space: nowrap; // preven two items from separating within a .navbar-form that has .pull-left
111
+ input {
112
+ margin-top: 0; // remove the margin on top since it's on the parent
113
+ }
114
+ }
115
+ }
116
+
117
+ // Navbar search
118
+ .navbar-search {
119
+ position: relative;
120
+ float: left;
121
+ margin-top: 6px;
122
+ margin-bottom: 0;
123
+ .search-query {
124
+ padding: 4px 9px;
125
+ @include font-sans-serif(13px, normal, 1);
126
+ color: $white;
127
+ color: rgba(255,255,255,.75);
128
+ background: #666;
129
+ background: rgba(255,255,255,.3);
130
+ border: 1px solid #111;
131
+ $shadow: inset 0 1px 2px rgba(0,0,0,.1), 0 1px 0px rgba(255,255,255,.15);
132
+ @include box-shadow($shadow);
133
+ @include transition(none);
134
+
135
+ // Placeholder text gets special styles; can't be bundled together though for some reason
136
+ @include placeholder($grayLighter);
137
+
138
+ // Hover states
139
+ &:hover {
140
+ color: $white;
141
+ background-color: $grayLight;
142
+ background-color: rgba(255,255,255,.5);
143
+ }
144
+ // Focus states (we use .focused since IE7-8 and down doesn't support :focus)
145
+ &:focus,
146
+ &.focused {
147
+ padding: 5px 10px;
148
+ color: $grayDark;
149
+ text-shadow: 0 1px 0 $white;
150
+ background-color: $white;
151
+ border: 0;
152
+ @include box-shadow(0 0 3px rgba(0,0,0,.15));
153
+ outline: 0;
154
+ }
155
+ }
156
+ }
157
+
158
+
159
+ // FIXED NAVBAR
160
+ // ------------
161
+
162
+ .navbar-fixed-top {
163
+ position: fixed;
164
+ top: 0;
165
+ right: 0;
166
+ left: 0;
167
+ z-index: $zindexFixedNavbar;
168
+ }
169
+ .navbar-fixed-top .navbar-inner {
170
+ padding-left: 0;
171
+ padding-right: 0;
172
+ @include border-radius(0);
173
+ }
174
+
175
+
176
+ // NAVIGATION
177
+ // ----------
178
+
179
+ .navbar .nav {
180
+ position: relative;
181
+ left: 0;
182
+ display: block;
183
+ float: left;
184
+ margin: 0 10px 0 0;
185
+ }
186
+ .navbar .nav.pull-right {
187
+ float: right; // redeclare due to specificity
188
+ }
189
+ .navbar .nav > li {
190
+ display: block;
191
+ float: left;
192
+ }
193
+
194
+ // Links
195
+ .navbar .nav > li > a {
196
+ float: none;
197
+ padding: 10px 10px 11px;
198
+ line-height: 19px;
199
+ color: $navbarLinkColor;
200
+ text-decoration: none;
201
+ text-shadow: 0 -1px 0 rgba(0,0,0,.25);
202
+ }
203
+ // Hover
204
+ .navbar .nav > li > a:hover {
205
+ background-color: $navbarLinkBackgroundHover; // "transparent" is default to differentiate :hover from .active
206
+ color: $navbarLinkColorHover;
207
+ text-decoration: none;
208
+ }
209
+
210
+ // Active nav items
211
+ .navbar .nav .active > a,
212
+ .navbar .nav .active > a:hover {
213
+ color: $navbarLinkColorHover;
214
+ text-decoration: none;
215
+ background-color: $navbarBackground;
216
+ }
217
+
218
+ // Dividers (basically a vertical hr)
219
+ .navbar .divider-vertical {
220
+ height: $navbarHeight;
221
+ width: 1px;
222
+ margin: 0 9px;
223
+ overflow: hidden;
224
+ background-color: $navbarBackground;
225
+ border-right: 1px solid $navbarBackgroundHighlight;
226
+ }
227
+
228
+ // Secondary (floated right) nav in topbar
229
+ .navbar .nav.pull-right {
230
+ margin-left: 10px;
231
+ margin-right: 0;
232
+ }
233
+
234
+
235
+
236
+ // Dropdown menus
237
+ // --------------
238
+
239
+ // Menu position and menu carets
240
+ .navbar .dropdown-menu {
241
+ margin-top: 1px;
242
+ @include border-radius(4px);
243
+ &:before {
244
+ content: '';
245
+ display: inline-block;
246
+ border-left: 7px solid transparent;
247
+ border-right: 7px solid transparent;
248
+ border-bottom: 7px solid #ccc;
249
+ border-bottom-color: rgba(0,0,0,.2);
250
+ position: absolute;
251
+ top: -7px;
252
+ left: 9px;
253
+ }
254
+ &:after {
255
+ content: '';
256
+ display: inline-block;
257
+ border-left: 6px solid transparent;
258
+ border-right: 6px solid transparent;
259
+ border-bottom: 6px solid $white;
260
+ position: absolute;
261
+ top: -6px;
262
+ left: 10px;
263
+ }
264
+ }
265
+
266
+ // Dropdown toggle caret
267
+ .navbar .nav .dropdown-toggle .caret,
268
+ .navbar .nav .open.dropdown .caret {
269
+ border-top-color: $white;
270
+ }
271
+ .navbar .nav .active .caret {
272
+ @include opacity(100);
273
+ }
274
+
275
+ // Remove background color from open dropdown
276
+ .navbar .nav .open > .dropdown-toggle,
277
+ .navbar .nav .active > .dropdown-toggle,
278
+ .navbar .nav .open.active > .dropdown-toggle {
279
+ background-color: transparent;
280
+ }
281
+
282
+ // Dropdown link on hover
283
+ .navbar .nav .active > .dropdown-toggle:hover {
284
+ color: $white;
285
+ }
286
+
287
+ // Right aligned menus need alt position
288
+ .navbar .nav.pull-right .dropdown-menu {
289
+ left: auto;
290
+ right: 0;
291
+ &:before {
292
+ left: auto;
293
+ right: 12px;
294
+ }
295
+ &:after {
296
+ left: auto;
297
+ right: 13px;
298
+ }
299
+ }
@@ -0,0 +1,353 @@
1
+ // NAVIGATIONS
2
+ // -----------
3
+
4
+
5
+
6
+ // BASE CLASS
7
+ // ----------
8
+
9
+ .nav {
10
+ margin-left: 0;
11
+ margin-bottom: $baseLineHeight;
12
+ list-style: none;
13
+ }
14
+
15
+ // Make links block level
16
+ .nav > li > a {
17
+ display: block;
18
+ }
19
+ .nav > li > a:hover {
20
+ text-decoration: none;
21
+ background-color: $grayLighter;
22
+ }
23
+
24
+ // Nav headers (for dropdowns and lists)
25
+ .nav .nav-header {
26
+ display: block;
27
+ padding: 3px 15px;
28
+ font-size: 11px;
29
+ font-weight: bold;
30
+ line-height: $baseLineHeight;
31
+ color: $grayLight;
32
+ text-shadow: 0 1px 0 rgba(255,255,255,.5);
33
+ text-transform: uppercase;
34
+ }
35
+ // Space them out when they follow another list item (link)
36
+ .nav li + .nav-header {
37
+ margin-top: 9px;
38
+ }
39
+
40
+
41
+ // NAV LIST
42
+ // --------
43
+
44
+ .nav-list {
45
+ padding-left: 14px;
46
+ padding-right: 14px;
47
+ margin-bottom: 0;
48
+ }
49
+ .nav-list > li > a,
50
+ .nav-list .nav-header {
51
+ margin-left: -15px;
52
+ margin-right: -15px;
53
+ text-shadow: 0 1px 0 rgba(255,255,255,.5);
54
+ }
55
+ .nav-list > li > a {
56
+ padding: 3px 15px;
57
+ }
58
+ .nav-list .active > a,
59
+ .nav-list .active > a:hover {
60
+ color: $white;
61
+ text-shadow: 0 -1px 0 rgba(0,0,0,.2);
62
+ background-color: $linkColor;
63
+ }
64
+ .nav-list [class^="icon-"] {
65
+ margin-right: 2px;
66
+ }
67
+
68
+
69
+
70
+ // TABS AND PILLS
71
+ // -------------
72
+
73
+ // Common styles
74
+ .nav-tabs,
75
+ .nav-pills {
76
+ @include clearfix();
77
+ }
78
+ .nav-tabs > li,
79
+ .nav-pills > li {
80
+ float: left;
81
+ }
82
+ .nav-tabs > li > a,
83
+ .nav-pills > li > a {
84
+ padding-right: 12px;
85
+ padding-left: 12px;
86
+ margin-right: 2px;
87
+ line-height: 14px; // keeps the overall height an even number
88
+ }
89
+
90
+ // TABS
91
+ // ----
92
+
93
+ // Give the tabs something to sit on
94
+ .nav-tabs {
95
+ border-bottom: 1px solid #ddd;
96
+ }
97
+
98
+ // Make the list-items overlay the bottom border
99
+ .nav-tabs > li {
100
+ margin-bottom: -1px;
101
+ }
102
+
103
+ // Actual tabs (as links)
104
+ .nav-tabs > li > a {
105
+ padding-top: 9px;
106
+ padding-bottom: 9px;
107
+ border: 1px solid transparent;
108
+ @include border-radius(4px 4px 0 0);
109
+ &:hover {
110
+ border-color: $grayLighter $grayLighter #ddd;
111
+ }
112
+ }
113
+ // Active state, and it's :hover to override normal :hover
114
+ .nav-tabs > .active > a,
115
+ .nav-tabs > .active > a:hover {
116
+ color: $gray;
117
+ background-color: $white;
118
+ border: 1px solid #ddd;
119
+ border-bottom-color: transparent;
120
+ cursor: default;
121
+ }
122
+
123
+ // PILLS
124
+ // -----
125
+
126
+ // Links rendered as pills
127
+ .nav-pills > li > a {
128
+ padding-top: 8px;
129
+ padding-bottom: 8px;
130
+ margin-top: 2px;
131
+ margin-bottom: 2px;
132
+ @include border-radius(5px);
133
+ }
134
+
135
+ // Active state
136
+ .nav-pills .active > a,
137
+ .nav-pills .active > a:hover {
138
+ color: $white;
139
+ background-color: $linkColor;
140
+ }
141
+
142
+
143
+
144
+ // STACKED NAV
145
+ // -----------
146
+
147
+ // Stacked tabs and pills
148
+ .nav-stacked > li {
149
+ float: none;
150
+ }
151
+ .nav-stacked > li > a {
152
+ margin-right: 0; // no need for the gap between nav items
153
+ }
154
+
155
+ // Tabs
156
+ .nav-tabs.nav-stacked {
157
+ border-bottom: 0;
158
+ }
159
+ .nav-tabs.nav-stacked > li > a {
160
+ border: 1px solid #ddd;
161
+ @include border-radius(0);
162
+ }
163
+ .nav-tabs.nav-stacked > li:first-child > a {
164
+ @include border-radius(4px 4px 0 0);
165
+ }
166
+ .nav-tabs.nav-stacked > li:last-child > a {
167
+ @include border-radius(0 0 4px 4px);
168
+ }
169
+ .nav-tabs.nav-stacked > li > a:hover {
170
+ border-color: #ddd;
171
+ z-index: 2;
172
+ }
173
+
174
+ // Pills
175
+ .nav-pills.nav-stacked > li > a {
176
+ margin-bottom: 3px;
177
+ }
178
+ .nav-pills.nav-stacked > li:last-child > a {
179
+ margin-bottom: 1px; // decrease margin to match sizing of stacked tabs
180
+ }
181
+
182
+
183
+
184
+ // DROPDOWNS
185
+ // ---------
186
+
187
+ // Position the menu
188
+ .nav-tabs .dropdown-menu,
189
+ .nav-pills .dropdown-menu {
190
+ margin-top: 1px;
191
+ border-width: 1px;
192
+ }
193
+ .nav-pills .dropdown-menu {
194
+ @include border-radius(4px);
195
+ }
196
+
197
+ // Default dropdown links
198
+ // -------------------------
199
+ // Make carets use linkColor to start
200
+ .nav-tabs .dropdown-toggle .caret,
201
+ .nav-pills .dropdown-toggle .caret {
202
+ border-top-color: $linkColor;
203
+ margin-top: 6px;
204
+ }
205
+ .nav-tabs .dropdown-toggle:hover .caret,
206
+ .nav-pills .dropdown-toggle:hover .caret {
207
+ border-top-color: $linkColorHover;
208
+ }
209
+
210
+ // Active dropdown links
211
+ // -------------------------
212
+ .nav-tabs .active .dropdown-toggle .caret,
213
+ .nav-pills .active .dropdown-toggle .caret {
214
+ border-top-color: $grayDark;
215
+ }
216
+
217
+ // Active:hover dropdown links
218
+ // -------------------------
219
+ .nav > .dropdown.active > a:hover {
220
+ color: $black;
221
+ cursor: pointer;
222
+ }
223
+
224
+ // Open dropdowns
225
+ // -------------------------
226
+ .nav-tabs .open .dropdown-toggle,
227
+ .nav-pills .open .dropdown-toggle,
228
+ .nav > .open.active > a:hover {
229
+ color: $white;
230
+ background-color: $grayLight;
231
+ border-color: $grayLight;
232
+ }
233
+ .nav .open .caret,
234
+ .nav .open.active .caret,
235
+ .nav .open a:hover .caret {
236
+ border-top-color: $white;
237
+ @include opacity(100);
238
+ }
239
+
240
+ // Dropdowns in stacked tabs
241
+ .tabs-stacked .open > a:hover {
242
+ border-color: $grayLight;
243
+ }
244
+
245
+
246
+
247
+ // TABBABLE
248
+ // --------
249
+
250
+
251
+ // COMMON STYLES
252
+ // -------------
253
+
254
+ // Clear any floats
255
+ .tabbable {
256
+ @include clearfix();
257
+ }
258
+ .tab-content {
259
+ overflow: hidden; // prevent content from running below tabs
260
+ }
261
+
262
+ // Remove border on bottom, left, right
263
+ .tabs-below .nav-tabs,
264
+ .tabs-right .nav-tabs,
265
+ .tabs-left .nav-tabs {
266
+ border-bottom: 0;
267
+ }
268
+
269
+ // Show/hide tabbable areas
270
+ .tab-content > .tab-pane,
271
+ .pill-content > .pill-pane {
272
+ display: none;
273
+ }
274
+ .tab-content > .active,
275
+ .pill-content > .active {
276
+ display: block;
277
+ }
278
+
279
+
280
+ // BOTTOM
281
+ // ------
282
+
283
+ .tabs-below .nav-tabs {
284
+ border-top: 1px solid #ddd;
285
+ }
286
+ .tabs-below .nav-tabs > li {
287
+ margin-top: -1px;
288
+ margin-bottom: 0;
289
+ }
290
+ .tabs-below .nav-tabs > li > a {
291
+ @include border-radius(0 0 4px 4px);
292
+ &:hover {
293
+ border-bottom-color: transparent;
294
+ border-top-color: #ddd;
295
+ }
296
+ }
297
+ .tabs-below .nav-tabs .active > a,
298
+ .tabs-below .nav-tabs .active > a:hover {
299
+ border-color: transparent #ddd #ddd #ddd;
300
+ }
301
+
302
+ // LEFT & RIGHT
303
+ // ------------
304
+
305
+ // Common styles
306
+ .tabs-left .nav-tabs > li,
307
+ .tabs-right .nav-tabs > li {
308
+ float: none;
309
+ }
310
+ .tabs-left .nav-tabs > li > a,
311
+ .tabs-right .nav-tabs > li > a {
312
+ min-width: 74px;
313
+ margin-right: 0;
314
+ margin-bottom: 3px;
315
+ }
316
+
317
+ // Tabs on the left
318
+ .tabs-left .nav-tabs {
319
+ float: left;
320
+ margin-right: 19px;
321
+ border-right: 1px solid #ddd;
322
+ }
323
+ .tabs-left .nav-tabs > li > a {
324
+ margin-right: -1px;
325
+ @include border-radius(4px 0 0 4px);
326
+ }
327
+ .tabs-left .nav-tabs > li > a:hover {
328
+ border-color: $grayLighter #ddd $grayLighter $grayLighter;
329
+ }
330
+ .tabs-left .nav-tabs .active > a,
331
+ .tabs-left .nav-tabs .active > a:hover {
332
+ border-color: #ddd transparent #ddd #ddd;
333
+ *border-right-color: $white;
334
+ }
335
+
336
+ // Tabs on the right
337
+ .tabs-right .nav-tabs {
338
+ float: right;
339
+ margin-left: 19px;
340
+ border-left: 1px solid #ddd;
341
+ }
342
+ .tabs-right .nav-tabs > li > a {
343
+ margin-left: -1px;
344
+ @include border-radius(0 4px 4px 0);
345
+ }
346
+ .tabs-right .nav-tabs > li > a:hover {
347
+ border-color: $grayLighter $grayLighter $grayLighter #ddd;
348
+ }
349
+ .tabs-right .nav-tabs .active > a,
350
+ .tabs-right .nav-tabs .active > a:hover {
351
+ border-color: #ddd #ddd #ddd transparent;
352
+ *border-left-color: $white;
353
+ }