flipper-ui 0.2.0.beta2 → 0.2.0.beta3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (218) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +12 -11
  3. data/README.md +5 -7
  4. data/examples/basic.ru +27 -26
  5. data/flipper-ui.gemspec +5 -3
  6. data/lib/flipper-ui.rb +1 -0
  7. data/lib/flipper/ui.rb +11 -2
  8. data/lib/flipper/ui/action.rb +45 -4
  9. data/lib/flipper/ui/actions/actors_gate.rb +48 -0
  10. data/lib/flipper/ui/actions/add_feature.rb +20 -0
  11. data/lib/flipper/ui/actions/boolean_gate.rb +26 -0
  12. data/lib/flipper/ui/actions/feature.rb +32 -0
  13. data/lib/flipper/ui/actions/features.rb +23 -3
  14. data/lib/flipper/ui/actions/file.rb +1 -1
  15. data/lib/flipper/ui/actions/gate.rb +11 -117
  16. data/lib/flipper/ui/actions/groups_gate.rb +43 -0
  17. data/lib/flipper/ui/actions/{index.rb → home.rb} +3 -3
  18. data/lib/flipper/ui/actions/percentage_of_actors_gate.rb +27 -0
  19. data/lib/flipper/ui/actions/percentage_of_time_gate.rb +27 -0
  20. data/lib/flipper/ui/actor.rb +13 -0
  21. data/lib/flipper/ui/assets/javascripts/application.coffee +0 -305
  22. data/lib/flipper/ui/assets/stylesheets/_bootstrap-compass.scss +9 -0
  23. data/lib/flipper/ui/assets/stylesheets/_bootstrap-mincer.scss +19 -0
  24. data/lib/flipper/ui/assets/stylesheets/_bootstrap-sprockets.scss +9 -0
  25. data/lib/flipper/ui/assets/stylesheets/_bootstrap.scss +50 -0
  26. data/lib/flipper/ui/assets/stylesheets/application.scss +33 -216
  27. data/lib/flipper/ui/assets/stylesheets/bootstrap/_alerts.scss +73 -0
  28. data/lib/flipper/ui/assets/stylesheets/bootstrap/_badges.scss +68 -0
  29. data/lib/flipper/ui/assets/stylesheets/bootstrap/_breadcrumbs.scss +26 -0
  30. data/lib/flipper/ui/assets/stylesheets/bootstrap/_button-groups.scss +243 -0
  31. data/lib/flipper/ui/assets/stylesheets/bootstrap/_buttons.scss +160 -0
  32. data/lib/flipper/ui/assets/stylesheets/bootstrap/_carousel.scss +269 -0
  33. data/lib/flipper/ui/assets/stylesheets/bootstrap/_close.scss +36 -0
  34. data/lib/flipper/ui/assets/stylesheets/bootstrap/_code.scss +69 -0
  35. data/lib/flipper/ui/assets/stylesheets/bootstrap/_component-animations.scss +37 -0
  36. data/lib/flipper/ui/assets/stylesheets/bootstrap/_dropdowns.scss +214 -0
  37. data/lib/flipper/ui/assets/stylesheets/bootstrap/_forms.scss +578 -0
  38. data/lib/flipper/ui/assets/stylesheets/bootstrap/_glyphicons.scss +305 -0
  39. data/lib/flipper/ui/assets/stylesheets/bootstrap/_grid.scss +84 -0
  40. data/lib/flipper/ui/assets/stylesheets/bootstrap/_input-groups.scss +166 -0
  41. data/lib/flipper/ui/assets/stylesheets/bootstrap/_jumbotron.scss +50 -0
  42. data/lib/flipper/ui/assets/stylesheets/bootstrap/_labels.scss +66 -0
  43. data/lib/flipper/ui/assets/stylesheets/bootstrap/_list-group.scss +124 -0
  44. data/lib/flipper/ui/assets/stylesheets/bootstrap/_media.scss +61 -0
  45. data/lib/flipper/ui/assets/stylesheets/bootstrap/_mixins.scss +39 -0
  46. data/lib/flipper/ui/assets/stylesheets/bootstrap/_modals.scss +150 -0
  47. data/lib/flipper/ui/assets/stylesheets/bootstrap/_navbar.scss +662 -0
  48. data/lib/flipper/ui/assets/stylesheets/bootstrap/_navs.scss +242 -0
  49. data/lib/flipper/ui/assets/stylesheets/bootstrap/_normalize.scss +427 -0
  50. data/lib/flipper/ui/assets/stylesheets/bootstrap/_pager.scss +54 -0
  51. data/lib/flipper/ui/assets/stylesheets/bootstrap/_pagination.scss +88 -0
  52. data/lib/flipper/ui/assets/stylesheets/bootstrap/_panels.scss +265 -0
  53. data/lib/flipper/ui/assets/stylesheets/bootstrap/_popovers.scss +135 -0
  54. data/lib/flipper/ui/assets/stylesheets/bootstrap/_print.scss +107 -0
  55. data/lib/flipper/ui/assets/stylesheets/bootstrap/_progress-bars.scss +87 -0
  56. data/lib/flipper/ui/assets/stylesheets/bootstrap/_responsive-embed.scss +35 -0
  57. data/lib/flipper/ui/assets/stylesheets/bootstrap/_responsive-utilities.scss +177 -0
  58. data/lib/flipper/ui/assets/stylesheets/bootstrap/_scaffolding.scss +162 -0
  59. data/lib/flipper/ui/assets/stylesheets/bootstrap/_tables.scss +234 -0
  60. data/lib/flipper/ui/assets/stylesheets/bootstrap/_theme.scss +273 -0
  61. data/lib/flipper/ui/assets/stylesheets/bootstrap/_thumbnails.scss +38 -0
  62. data/lib/flipper/ui/assets/stylesheets/bootstrap/_tooltip.scss +102 -0
  63. data/lib/flipper/ui/assets/stylesheets/bootstrap/_type.scss +298 -0
  64. data/lib/flipper/ui/assets/stylesheets/bootstrap/_utilities.scss +55 -0
  65. data/lib/flipper/ui/assets/stylesheets/bootstrap/_variables.scss +866 -0
  66. data/lib/flipper/ui/assets/stylesheets/bootstrap/_wells.scss +29 -0
  67. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_alerts.scss +14 -0
  68. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_background-variant.scss +11 -0
  69. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_border-radius.scss +18 -0
  70. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_buttons.scss +52 -0
  71. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_center-block.scss +7 -0
  72. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_clearfix.scss +22 -0
  73. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_forms.scss +88 -0
  74. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_gradients.scss +58 -0
  75. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +81 -0
  76. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_grid.scss +122 -0
  77. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_hide-text.scss +21 -0
  78. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_image.scss +33 -0
  79. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_labels.scss +12 -0
  80. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_list-group.scss +31 -0
  81. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +10 -0
  82. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_nav-vertical-align.scss +9 -0
  83. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_opacity.scss +8 -0
  84. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_pagination.scss +23 -0
  85. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_panels.scss +24 -0
  86. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_progress-bar.scss +10 -0
  87. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_reset-filter.scss +8 -0
  88. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_resize.scss +6 -0
  89. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_responsive-visibility.scss +21 -0
  90. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_size.scss +10 -0
  91. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_tab-focus.scss +9 -0
  92. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_table-row.scss +28 -0
  93. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +11 -0
  94. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_text-overflow.scss +8 -0
  95. data/lib/flipper/ui/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +222 -0
  96. data/lib/flipper/ui/assets/stylesheets/primer/.scss-lint.yml +446 -0
  97. data/lib/flipper/ui/assets/stylesheets/primer/_alerts.scss +106 -0
  98. data/lib/flipper/ui/assets/stylesheets/primer/_avatars.scss +36 -0
  99. data/lib/flipper/ui/assets/stylesheets/primer/_base.scss +40 -0
  100. data/lib/flipper/ui/assets/stylesheets/primer/_blankslate.scss +96 -0
  101. data/lib/flipper/ui/assets/stylesheets/primer/_buttons.scss +404 -0
  102. data/lib/flipper/ui/assets/stylesheets/primer/_counter.scss +10 -0
  103. data/lib/flipper/ui/assets/stylesheets/primer/_filter-list.scss +68 -0
  104. data/lib/flipper/ui/assets/stylesheets/primer/_flex-table.scss +20 -0
  105. data/lib/flipper/ui/assets/stylesheets/primer/_forms.scss +756 -0
  106. data/lib/flipper/ui/assets/stylesheets/primer/_layout.scss +69 -0
  107. data/lib/flipper/ui/assets/stylesheets/primer/_menu.scss +113 -0
  108. data/lib/flipper/ui/assets/stylesheets/primer/_mixins.scss +53 -0
  109. data/lib/flipper/ui/assets/stylesheets/primer/_normalize.scss +425 -0
  110. data/lib/flipper/ui/assets/stylesheets/primer/_states.scss +32 -0
  111. data/lib/flipper/ui/assets/stylesheets/primer/_tabnav.scss +65 -0
  112. data/lib/flipper/ui/assets/stylesheets/primer/_tooltips.scss +255 -0
  113. data/lib/flipper/ui/assets/stylesheets/primer/_truncate.scss +27 -0
  114. data/lib/flipper/ui/assets/stylesheets/primer/_type.scss +92 -0
  115. data/lib/flipper/ui/assets/stylesheets/primer/_utility.scss +73 -0
  116. data/lib/flipper/ui/assets/stylesheets/primer/_variables.scss +34 -0
  117. data/lib/flipper/ui/assets/stylesheets/primer/primer.scss +39 -0
  118. data/lib/flipper/ui/decorators/feature.rb +37 -4
  119. data/lib/flipper/ui/middleware.rb +12 -3
  120. data/lib/flipper/ui/public/css/application.css +2563 -144
  121. data/lib/flipper/ui/public/css/primer.css +1 -0
  122. data/lib/flipper/ui/public/css/primer/primer.css +1933 -0
  123. data/lib/flipper/ui/public/css/scss/primer.css +1933 -0
  124. data/lib/flipper/ui/public/fonts/bootstrap/glyphicons-halflings-regular.eot +0 -0
  125. data/lib/flipper/ui/public/fonts/bootstrap/glyphicons-halflings-regular.svg +288 -0
  126. data/lib/flipper/ui/public/fonts/bootstrap/glyphicons-halflings-regular.ttf +0 -0
  127. data/lib/flipper/ui/public/fonts/bootstrap/glyphicons-halflings-regular.woff +0 -0
  128. data/lib/flipper/ui/public/fonts/bootstrap/glyphicons-halflings-regular.woff2 +0 -0
  129. data/lib/flipper/ui/public/js/application.js +0 -539
  130. data/lib/flipper/ui/public/js/bootstrap-sprockets.js +12 -0
  131. data/lib/flipper/ui/public/js/bootstrap.js +2317 -0
  132. data/lib/flipper/ui/public/js/bootstrap.min.js +7 -0
  133. data/lib/flipper/ui/public/js/bootstrap/affix.js +162 -0
  134. data/lib/flipper/ui/public/js/bootstrap/alert.js +94 -0
  135. data/lib/flipper/ui/public/js/bootstrap/button.js +116 -0
  136. data/lib/flipper/ui/public/js/bootstrap/carousel.js +237 -0
  137. data/lib/flipper/ui/public/js/bootstrap/collapse.js +211 -0
  138. data/lib/flipper/ui/public/js/bootstrap/dropdown.js +161 -0
  139. data/lib/flipper/ui/public/js/bootstrap/modal.js +339 -0
  140. data/lib/flipper/ui/public/js/bootstrap/popover.js +108 -0
  141. data/lib/flipper/ui/public/js/bootstrap/scrollspy.js +172 -0
  142. data/lib/flipper/ui/public/js/bootstrap/tab.js +153 -0
  143. data/lib/flipper/ui/public/js/bootstrap/tooltip.js +476 -0
  144. data/lib/flipper/ui/public/js/bootstrap/transition.js +59 -0
  145. data/lib/flipper/ui/public/octicons/LICENSE.txt +9 -0
  146. data/lib/flipper/ui/public/octicons/README.md +1 -0
  147. data/lib/flipper/ui/public/octicons/octicons-local.ttf +0 -0
  148. data/lib/flipper/ui/public/octicons/octicons.css +236 -0
  149. data/lib/flipper/ui/public/octicons/octicons.eot +0 -0
  150. data/lib/flipper/ui/public/octicons/octicons.less +235 -0
  151. data/lib/flipper/ui/public/octicons/octicons.svg +200 -0
  152. data/lib/flipper/ui/public/octicons/octicons.ttf +0 -0
  153. data/lib/flipper/ui/public/octicons/octicons.woff +0 -0
  154. data/lib/flipper/ui/public/octicons/sprockets-octicons.scss +232 -0
  155. data/lib/flipper/ui/util.rb +4 -0
  156. data/lib/flipper/ui/version.rb +1 -1
  157. data/lib/flipper/ui/views/add_actor.erb +22 -0
  158. data/lib/flipper/ui/views/add_feature.erb +18 -0
  159. data/lib/flipper/ui/views/add_group.erb +31 -0
  160. data/lib/flipper/ui/views/feature.erb +209 -0
  161. data/lib/flipper/ui/views/features.erb +46 -0
  162. data/lib/flipper/ui/views/layout.erb +31 -149
  163. data/script/release +15 -0
  164. data/spec/flipper/ui/actions/actors_gate_spec.rb +68 -0
  165. data/spec/flipper/ui/actions/add_feature_spec.rb +17 -0
  166. data/spec/flipper/ui/actions/boolean_gate_spec.rb +41 -0
  167. data/spec/flipper/ui/actions/feature_spec.rb +59 -0
  168. data/spec/flipper/ui/actions/features_spec.rb +37 -0
  169. data/spec/flipper/ui/actions/file_spec.rb +43 -0
  170. data/spec/flipper/ui/actions/gate_spec.rb +24 -0
  171. data/spec/flipper/ui/actions/groups_gate_spec.rb +80 -0
  172. data/spec/flipper/ui/actions/home_spec.rb +16 -0
  173. data/spec/flipper/ui/actions/percentage_of_actors_gate_spec.rb +40 -0
  174. data/spec/flipper/ui/actions/percentage_of_time_gate_spec.rb +39 -0
  175. data/spec/flipper/ui/decorators/feature_spec.rb +38 -1
  176. data/spec/flipper/ui/decorators/gate_spec.rb +1 -1
  177. data/spec/flipper/ui_spec.rb +18 -441
  178. data/spec/helper.rb +22 -7
  179. metadata +199 -52
  180. data/examples/flipper.html +0 -14
  181. data/examples/flipper.png +0 -0
  182. data/lib/flipper/ui/assets/javascripts/spine/ajax.coffee +0 -223
  183. data/lib/flipper/ui/assets/javascripts/spine/list.coffee +0 -43
  184. data/lib/flipper/ui/assets/javascripts/spine/local.coffee +0 -16
  185. data/lib/flipper/ui/assets/javascripts/spine/manager.coffee +0 -83
  186. data/lib/flipper/ui/assets/javascripts/spine/relation.coffee +0 -148
  187. data/lib/flipper/ui/assets/javascripts/spine/route.coffee +0 -146
  188. data/lib/flipper/ui/assets/javascripts/spine/spine.coffee +0 -542
  189. data/lib/flipper/ui/assets/javascripts/spine/version +0 -1
  190. data/lib/flipper/ui/public/css/images/animated-overlay.gif +0 -0
  191. data/lib/flipper/ui/public/css/images/ui-bg_diagonals-thick_18_b81900_40x40.png +0 -0
  192. data/lib/flipper/ui/public/css/images/ui-bg_diagonals-thick_20_666666_40x40.png +0 -0
  193. data/lib/flipper/ui/public/css/images/ui-bg_flat_10_000000_40x100.png +0 -0
  194. data/lib/flipper/ui/public/css/images/ui-bg_glass_100_f6f6f6_1x400.png +0 -0
  195. data/lib/flipper/ui/public/css/images/ui-bg_glass_100_fdf5ce_1x400.png +0 -0
  196. data/lib/flipper/ui/public/css/images/ui-bg_glass_65_ffffff_1x400.png +0 -0
  197. data/lib/flipper/ui/public/css/images/ui-bg_gloss-wave_35_f6a828_500x100.png +0 -0
  198. data/lib/flipper/ui/public/css/images/ui-bg_highlight-soft_100_eeeeee_1x100.png +0 -0
  199. data/lib/flipper/ui/public/css/images/ui-bg_highlight-soft_75_ffe45c_1x100.png +0 -0
  200. data/lib/flipper/ui/public/css/images/ui-icons_222222_256x240.png +0 -0
  201. data/lib/flipper/ui/public/css/images/ui-icons_228ef1_256x240.png +0 -0
  202. data/lib/flipper/ui/public/css/images/ui-icons_ef8c08_256x240.png +0 -0
  203. data/lib/flipper/ui/public/css/images/ui-icons_ffd27a_256x240.png +0 -0
  204. data/lib/flipper/ui/public/css/images/ui-icons_ffffff_256x240.png +0 -0
  205. data/lib/flipper/ui/public/css/jquery-ui-1.10.3.slider.min.css +0 -5
  206. data/lib/flipper/ui/public/js/handlebars.js +0 -1992
  207. data/lib/flipper/ui/public/js/jquery-ui-1.10.3.slider.min.js +0 -6
  208. data/lib/flipper/ui/public/js/jquery.js +0 -9555
  209. data/lib/flipper/ui/public/js/jquery.min.js +0 -4
  210. data/lib/flipper/ui/public/js/jquery.min.map +0 -1
  211. data/lib/flipper/ui/public/js/spine/ajax.js +0 -320
  212. data/lib/flipper/ui/public/js/spine/list.js +0 -72
  213. data/lib/flipper/ui/public/js/spine/local.js +0 -29
  214. data/lib/flipper/ui/public/js/spine/manager.js +0 -157
  215. data/lib/flipper/ui/public/js/spine/relation.js +0 -260
  216. data/lib/flipper/ui/public/js/spine/route.js +0 -223
  217. data/lib/flipper/ui/public/js/spine/spine.js +0 -927
  218. data/lib/flipper/ui/views/index.erb +0 -9
@@ -0,0 +1,234 @@
1
+ //
2
+ // Tables
3
+ // --------------------------------------------------
4
+
5
+
6
+ table {
7
+ background-color: $table-bg;
8
+ }
9
+ caption {
10
+ padding-top: $table-cell-padding;
11
+ padding-bottom: $table-cell-padding;
12
+ color: $text-muted;
13
+ text-align: left;
14
+ }
15
+ th {
16
+ text-align: left;
17
+ }
18
+
19
+
20
+ // Baseline styles
21
+
22
+ .table {
23
+ width: 100%;
24
+ max-width: 100%;
25
+ margin-bottom: $line-height-computed;
26
+ // Cells
27
+ > thead,
28
+ > tbody,
29
+ > tfoot {
30
+ > tr {
31
+ > th,
32
+ > td {
33
+ padding: $table-cell-padding;
34
+ line-height: $line-height-base;
35
+ vertical-align: top;
36
+ border-top: 1px solid $table-border-color;
37
+ }
38
+ }
39
+ }
40
+ // Bottom align for column headings
41
+ > thead > tr > th {
42
+ vertical-align: bottom;
43
+ border-bottom: 2px solid $table-border-color;
44
+ }
45
+ // Remove top border from thead by default
46
+ > caption + thead,
47
+ > colgroup + thead,
48
+ > thead:first-child {
49
+ > tr:first-child {
50
+ > th,
51
+ > td {
52
+ border-top: 0;
53
+ }
54
+ }
55
+ }
56
+ // Account for multiple tbody instances
57
+ > tbody + tbody {
58
+ border-top: 2px solid $table-border-color;
59
+ }
60
+
61
+ // Nesting
62
+ .table {
63
+ background-color: $body-bg;
64
+ }
65
+ }
66
+
67
+
68
+ // Condensed table w/ half padding
69
+
70
+ .table-condensed {
71
+ > thead,
72
+ > tbody,
73
+ > tfoot {
74
+ > tr {
75
+ > th,
76
+ > td {
77
+ padding: $table-condensed-cell-padding;
78
+ }
79
+ }
80
+ }
81
+ }
82
+
83
+
84
+ // Bordered version
85
+ //
86
+ // Add borders all around the table and between all the columns.
87
+
88
+ .table-bordered {
89
+ border: 1px solid $table-border-color;
90
+ > thead,
91
+ > tbody,
92
+ > tfoot {
93
+ > tr {
94
+ > th,
95
+ > td {
96
+ border: 1px solid $table-border-color;
97
+ }
98
+ }
99
+ }
100
+ > thead > tr {
101
+ > th,
102
+ > td {
103
+ border-bottom-width: 2px;
104
+ }
105
+ }
106
+ }
107
+
108
+
109
+ // Zebra-striping
110
+ //
111
+ // Default zebra-stripe styles (alternating gray and transparent backgrounds)
112
+
113
+ .table-striped {
114
+ > tbody > tr:nth-of-type(odd) {
115
+ background-color: $table-bg-accent;
116
+ }
117
+ }
118
+
119
+
120
+ // Hover effect
121
+ //
122
+ // Placed here since it has to come after the potential zebra striping
123
+
124
+ .table-hover {
125
+ > tbody > tr:hover {
126
+ background-color: $table-bg-hover;
127
+ }
128
+ }
129
+
130
+
131
+ // Table cell sizing
132
+ //
133
+ // Reset default table behavior
134
+
135
+ table col[class*="col-"] {
136
+ position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
137
+ float: none;
138
+ display: table-column;
139
+ }
140
+ table {
141
+ td,
142
+ th {
143
+ &[class*="col-"] {
144
+ position: static; // Prevent border hiding in Firefox and IE9-11 (see https://github.com/twbs/bootstrap/issues/11623)
145
+ float: none;
146
+ display: table-cell;
147
+ }
148
+ }
149
+ }
150
+
151
+
152
+ // Table backgrounds
153
+ //
154
+ // Exact selectors below required to override `.table-striped` and prevent
155
+ // inheritance to nested tables.
156
+
157
+ // Generate the contextual variants
158
+ @include table-row-variant('active', $table-bg-active);
159
+ @include table-row-variant('success', $state-success-bg);
160
+ @include table-row-variant('info', $state-info-bg);
161
+ @include table-row-variant('warning', $state-warning-bg);
162
+ @include table-row-variant('danger', $state-danger-bg);
163
+
164
+
165
+ // Responsive tables
166
+ //
167
+ // Wrap your tables in `.table-responsive` and we'll make them mobile friendly
168
+ // by enabling horizontal scrolling. Only applies <768px. Everything above that
169
+ // will display normally.
170
+
171
+ .table-responsive {
172
+ overflow-x: auto;
173
+ min-height: 0.01%; // Workaround for IE9 bug (see https://github.com/twbs/bootstrap/issues/14837)
174
+
175
+ @media screen and (max-width: $screen-xs-max) {
176
+ width: 100%;
177
+ margin-bottom: ($line-height-computed * 0.75);
178
+ overflow-y: hidden;
179
+ -ms-overflow-style: -ms-autohiding-scrollbar;
180
+ border: 1px solid $table-border-color;
181
+
182
+ // Tighten up spacing
183
+ > .table {
184
+ margin-bottom: 0;
185
+
186
+ // Ensure the content doesn't wrap
187
+ > thead,
188
+ > tbody,
189
+ > tfoot {
190
+ > tr {
191
+ > th,
192
+ > td {
193
+ white-space: nowrap;
194
+ }
195
+ }
196
+ }
197
+ }
198
+
199
+ // Special overrides for the bordered tables
200
+ > .table-bordered {
201
+ border: 0;
202
+
203
+ // Nuke the appropriate borders so that the parent can handle them
204
+ > thead,
205
+ > tbody,
206
+ > tfoot {
207
+ > tr {
208
+ > th:first-child,
209
+ > td:first-child {
210
+ border-left: 0;
211
+ }
212
+ > th:last-child,
213
+ > td:last-child {
214
+ border-right: 0;
215
+ }
216
+ }
217
+ }
218
+
219
+ // Only nuke the last row's bottom-border in `tbody` and `tfoot` since
220
+ // chances are there will be only one `tr` in a `thead` and that would
221
+ // remove the border altogether.
222
+ > tbody,
223
+ > tfoot {
224
+ > tr:last-child {
225
+ > th,
226
+ > td {
227
+ border-bottom: 0;
228
+ }
229
+ }
230
+ }
231
+
232
+ }
233
+ }
234
+ }
@@ -0,0 +1,273 @@
1
+
2
+ //
3
+ // Load core variables and mixins
4
+ // --------------------------------------------------
5
+
6
+ @import "variables";
7
+ @import "mixins";
8
+
9
+
10
+ //
11
+ // Buttons
12
+ // --------------------------------------------------
13
+
14
+ // Common styles
15
+ .btn-default,
16
+ .btn-primary,
17
+ .btn-success,
18
+ .btn-info,
19
+ .btn-warning,
20
+ .btn-danger {
21
+ text-shadow: 0 -1px 0 rgba(0,0,0,.2);
22
+ $shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 1px rgba(0,0,0,.075);
23
+ @include box-shadow($shadow);
24
+
25
+ // Reset the shadow
26
+ &:active,
27
+ &.active {
28
+ @include box-shadow(inset 0 3px 5px rgba(0,0,0,.125));
29
+ }
30
+
31
+ .badge {
32
+ text-shadow: none;
33
+ }
34
+ }
35
+
36
+ // Mixin for generating new styles
37
+ @mixin btn-styles($btn-color: #555) {
38
+ @include gradient-vertical($start-color: $btn-color, $end-color: darken($btn-color, 12%));
39
+ @include reset-filter; // Disable gradients for IE9 because filter bleeds through rounded corners; see https://github.com/twbs/bootstrap/issues/10620
40
+ background-repeat: repeat-x;
41
+ border-color: darken($btn-color, 14%);
42
+
43
+ &:hover,
44
+ &:focus {
45
+ background-color: darken($btn-color, 12%);
46
+ background-position: 0 -15px;
47
+ }
48
+
49
+ &:active,
50
+ &.active {
51
+ background-color: darken($btn-color, 12%);
52
+ border-color: darken($btn-color, 14%);
53
+ }
54
+
55
+ &.disabled,
56
+ &:disabled,
57
+ &[disabled] {
58
+ background-color: darken($btn-color, 12%);
59
+ background-image: none;
60
+ }
61
+ }
62
+
63
+ // Common styles
64
+ .btn {
65
+ // Remove the gradient for the pressed/active state
66
+ &:active,
67
+ &.active {
68
+ background-image: none;
69
+ }
70
+ }
71
+
72
+ // Apply the mixin to the buttons
73
+ .btn-default { @include btn-styles($btn-default-bg); text-shadow: 0 1px 0 #fff; border-color: #ccc; }
74
+ .btn-primary { @include btn-styles($btn-primary-bg); }
75
+ .btn-success { @include btn-styles($btn-success-bg); }
76
+ .btn-info { @include btn-styles($btn-info-bg); }
77
+ .btn-warning { @include btn-styles($btn-warning-bg); }
78
+ .btn-danger { @include btn-styles($btn-danger-bg); }
79
+
80
+
81
+ //
82
+ // Images
83
+ // --------------------------------------------------
84
+
85
+ .thumbnail,
86
+ .img-thumbnail {
87
+ @include box-shadow(0 1px 2px rgba(0,0,0,.075));
88
+ }
89
+
90
+
91
+ //
92
+ // Dropdowns
93
+ // --------------------------------------------------
94
+
95
+ .dropdown-menu > li > a:hover,
96
+ .dropdown-menu > li > a:focus {
97
+ @include gradient-vertical($start-color: $dropdown-link-hover-bg, $end-color: darken($dropdown-link-hover-bg, 5%));
98
+ background-color: darken($dropdown-link-hover-bg, 5%);
99
+ }
100
+ .dropdown-menu > .active > a,
101
+ .dropdown-menu > .active > a:hover,
102
+ .dropdown-menu > .active > a:focus {
103
+ @include gradient-vertical($start-color: $dropdown-link-active-bg, $end-color: darken($dropdown-link-active-bg, 5%));
104
+ background-color: darken($dropdown-link-active-bg, 5%);
105
+ }
106
+
107
+
108
+ //
109
+ // Navbar
110
+ // --------------------------------------------------
111
+
112
+ // Default navbar
113
+ .navbar-default {
114
+ @include gradient-vertical($start-color: lighten($navbar-default-bg, 10%), $end-color: $navbar-default-bg);
115
+ @include reset-filter; // Remove gradient in IE<10 to fix bug where dropdowns don't get triggered
116
+ border-radius: $navbar-border-radius;
117
+ $shadow: inset 0 1px 0 rgba(255,255,255,.15), 0 1px 5px rgba(0,0,0,.075);
118
+ @include box-shadow($shadow);
119
+
120
+ .navbar-nav > .open > a,
121
+ .navbar-nav > .active > a {
122
+ @include gradient-vertical($start-color: darken($navbar-default-link-active-bg, 5%), $end-color: darken($navbar-default-link-active-bg, 2%));
123
+ @include box-shadow(inset 0 3px 9px rgba(0,0,0,.075));
124
+ }
125
+ }
126
+ .navbar-brand,
127
+ .navbar-nav > li > a {
128
+ text-shadow: 0 1px 0 rgba(255,255,255,.25);
129
+ }
130
+
131
+ // Inverted navbar
132
+ .navbar-inverse {
133
+ @include gradient-vertical($start-color: lighten($navbar-inverse-bg, 10%), $end-color: $navbar-inverse-bg);
134
+ @include reset-filter; // Remove gradient in IE<10 to fix bug where dropdowns don't get triggered; see https://github.com/twbs/bootstrap/issues/10257
135
+
136
+ .navbar-nav > .open > a,
137
+ .navbar-nav > .active > a {
138
+ @include gradient-vertical($start-color: $navbar-inverse-link-active-bg, $end-color: lighten($navbar-inverse-link-active-bg, 2.5%));
139
+ @include box-shadow(inset 0 3px 9px rgba(0,0,0,.25));
140
+ }
141
+
142
+ .navbar-brand,
143
+ .navbar-nav > li > a {
144
+ text-shadow: 0 -1px 0 rgba(0,0,0,.25);
145
+ }
146
+ }
147
+
148
+ // Undo rounded corners in static and fixed navbars
149
+ .navbar-static-top,
150
+ .navbar-fixed-top,
151
+ .navbar-fixed-bottom {
152
+ border-radius: 0;
153
+ }
154
+
155
+ // Fix active state of dropdown items in collapsed mode
156
+ @media (max-width: $grid-float-breakpoint-max) {
157
+ .navbar .navbar-nav .open .dropdown-menu > .active > a {
158
+ &,
159
+ &:hover,
160
+ &:focus {
161
+ color: #fff;
162
+ @include gradient-vertical($start-color: $dropdown-link-active-bg, $end-color: darken($dropdown-link-active-bg, 5%));
163
+ }
164
+ }
165
+ }
166
+
167
+
168
+ //
169
+ // Alerts
170
+ // --------------------------------------------------
171
+
172
+ // Common styles
173
+ .alert {
174
+ text-shadow: 0 1px 0 rgba(255,255,255,.2);
175
+ $shadow: inset 0 1px 0 rgba(255,255,255,.25), 0 1px 2px rgba(0,0,0,.05);
176
+ @include box-shadow($shadow);
177
+ }
178
+
179
+ // Mixin for generating new styles
180
+ @mixin alert-styles($color) {
181
+ @include gradient-vertical($start-color: $color, $end-color: darken($color, 7.5%));
182
+ border-color: darken($color, 15%);
183
+ }
184
+
185
+ // Apply the mixin to the alerts
186
+ .alert-success { @include alert-styles($alert-success-bg); }
187
+ .alert-info { @include alert-styles($alert-info-bg); }
188
+ .alert-warning { @include alert-styles($alert-warning-bg); }
189
+ .alert-danger { @include alert-styles($alert-danger-bg); }
190
+
191
+
192
+ //
193
+ // Progress bars
194
+ // --------------------------------------------------
195
+
196
+ // Give the progress background some depth
197
+ .progress {
198
+ @include gradient-vertical($start-color: darken($progress-bg, 4%), $end-color: $progress-bg)
199
+ }
200
+
201
+ // Mixin for generating new styles
202
+ @mixin progress-bar-styles($color) {
203
+ @include gradient-vertical($start-color: $color, $end-color: darken($color, 10%));
204
+ }
205
+
206
+ // Apply the mixin to the progress bars
207
+ .progress-bar { @include progress-bar-styles($progress-bar-bg); }
208
+ .progress-bar-success { @include progress-bar-styles($progress-bar-success-bg); }
209
+ .progress-bar-info { @include progress-bar-styles($progress-bar-info-bg); }
210
+ .progress-bar-warning { @include progress-bar-styles($progress-bar-warning-bg); }
211
+ .progress-bar-danger { @include progress-bar-styles($progress-bar-danger-bg); }
212
+
213
+ // Reset the striped class because our mixins don't do multiple gradients and
214
+ // the above custom styles override the new `.progress-bar-striped` in v3.2.0.
215
+ .progress-bar-striped {
216
+ @include gradient-striped;
217
+ }
218
+
219
+
220
+ //
221
+ // List groups
222
+ // --------------------------------------------------
223
+
224
+ .list-group {
225
+ border-radius: $border-radius-base;
226
+ @include box-shadow(0 1px 2px rgba(0,0,0,.075));
227
+ }
228
+ .list-group-item.active,
229
+ .list-group-item.active:hover,
230
+ .list-group-item.active:focus {
231
+ text-shadow: 0 -1px 0 darken($list-group-active-bg, 10%);
232
+ @include gradient-vertical($start-color: $list-group-active-bg, $end-color: darken($list-group-active-bg, 7.5%));
233
+ border-color: darken($list-group-active-border, 7.5%);
234
+
235
+ .badge {
236
+ text-shadow: none;
237
+ }
238
+ }
239
+
240
+
241
+ //
242
+ // Panels
243
+ // --------------------------------------------------
244
+
245
+ // Common styles
246
+ .panel {
247
+ @include box-shadow(0 1px 2px rgba(0,0,0,.05));
248
+ }
249
+
250
+ // Mixin for generating new styles
251
+ @mixin panel-heading-styles($color) {
252
+ @include gradient-vertical($start-color: $color, $end-color: darken($color, 5%));
253
+ }
254
+
255
+ // Apply the mixin to the panel headings only
256
+ .panel-default > .panel-heading { @include panel-heading-styles($panel-default-heading-bg); }
257
+ .panel-primary > .panel-heading { @include panel-heading-styles($panel-primary-heading-bg); }
258
+ .panel-success > .panel-heading { @include panel-heading-styles($panel-success-heading-bg); }
259
+ .panel-info > .panel-heading { @include panel-heading-styles($panel-info-heading-bg); }
260
+ .panel-warning > .panel-heading { @include panel-heading-styles($panel-warning-heading-bg); }
261
+ .panel-danger > .panel-heading { @include panel-heading-styles($panel-danger-heading-bg); }
262
+
263
+
264
+ //
265
+ // Wells
266
+ // --------------------------------------------------
267
+
268
+ .well {
269
+ @include gradient-vertical($start-color: darken($well-bg, 5%), $end-color: $well-bg);
270
+ border-color: darken($well-bg, 10%);
271
+ $shadow: inset 0 1px 3px rgba(0,0,0,.05), 0 1px 0 rgba(255,255,255,.1);
272
+ @include box-shadow($shadow);
273
+ }