_icon-bar.scss 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  1. // Foundation by ZURB
  2. // foundation.zurb.com
  3. // Licensed under MIT Open Source
  4. @import 'global';
  5. // @name
  6. // @dependencies _global.scss
  7. $include-html-icon-bar-classes: $include-html-classes !default;
  8. // @variables
  9. // We use these to style the icon-bar and items
  10. $icon-bar-bg: $oil !default;
  11. $icon-bar-font-color: $white !default;
  12. $icon-bar-font-color-hover: $icon-bar-font-color !default;
  13. $icon-bar-font-size: 1rem !default;
  14. $icon-bar-hover-color: $primary-color !default;
  15. $icon-bar-icon-color: $white !default;
  16. $icon-bar-icon-color-hover: $icon-bar-icon-color !default;
  17. $icon-bar-icon-size: 1.875rem !default;
  18. $icon-bar-image-width: 1.875rem !default;
  19. $icon-bar-image-height: 1.875rem !default;
  20. $icon-bar-active-color: $primary-color !default;
  21. $icon-bar-item-padding: 1.25rem !default;
  22. // We use this to set default opacity and cursor for disabled icons.
  23. $icon-bar-disabled-opacity: .7 !default;
  24. $icon-bar-disabled-cursor: $cursor-disabled-value !default;
  25. //
  26. // @mixins
  27. //
  28. // We use this mixin to create the base styles for our Icon bar element.
  29. //
  30. @mixin icon-bar-base() {
  31. display: inline-block;
  32. font-size: 0;
  33. width: 100%;
  34. > * {
  35. display: block;
  36. float: left;
  37. font-size: $icon-bar-font-size;
  38. margin: 0 auto;
  39. padding: $icon-bar-item-padding;
  40. text-align: center;
  41. width: 25%;
  42. i, img {
  43. display: block;
  44. margin: 0 auto;
  45. & + label {
  46. margin-top: .0625rem;
  47. }
  48. }
  49. i {
  50. font-size: $icon-bar-icon-size;
  51. vertical-align: middle;
  52. }
  53. img {
  54. height: $icon-bar-image-height;
  55. width: $icon-bar-image-width;
  56. }
  57. }
  58. &.label-right > * {
  59. i, img {
  60. display: inline-block;
  61. margin: 0 .0625rem 0 0;
  62. & + label {
  63. margin-top: 0;
  64. }
  65. }
  66. label { display: inline-block; }
  67. }
  68. &.vertical.label-right > * {
  69. text-align: left;
  70. }
  71. &.vertical, &.small-vertical{
  72. height: 100%;
  73. width: auto;
  74. .item {
  75. float: none;
  76. margin: auto;
  77. width: auto;
  78. }
  79. }
  80. &.medium-vertical {
  81. @media #{$medium-up} {
  82. height: 100%;
  83. width: auto;
  84. .item {
  85. float: none;
  86. margin: auto;
  87. width: auto;
  88. }
  89. }
  90. }
  91. &.large-vertical {
  92. @media #{$large-up} {
  93. height: 100%;
  94. width: auto;
  95. .item {
  96. float: none;
  97. margin: auto;
  98. width: auto;
  99. }
  100. }
  101. }
  102. }
  103. // We use this mixin to create the size styles for icon bars.
  104. @mixin icon-bar-size(
  105. $padding: $icon-bar-item-padding,
  106. $font-size: $icon-bar-font-size,
  107. $icon-size: $icon-bar-icon-size,
  108. $image-width: $icon-bar-image-width,
  109. $image-height: $icon-bar-image-height) {
  110. > * {
  111. font-size: $font-size;
  112. padding: $padding;
  113. i, img {
  114. & + label {
  115. margin-top: .0625rem;
  116. font-size: $font-size;
  117. }
  118. }
  119. i {
  120. font-size: $icon-size;
  121. }
  122. img {
  123. height: $image-height;
  124. width: $image-width;
  125. }
  126. }
  127. }
  128. @mixin icon-bar-style(
  129. $bar-bg:$icon-bar-bg,
  130. $bar-font-color:$icon-bar-font-color,
  131. $bar-font-color-hover:$icon-bar-font-color-hover,
  132. $bar-hover-color:$icon-bar-hover-color,
  133. $bar-icon-color:$icon-bar-icon-color,
  134. $bar-icon-color-hover:$icon-bar-icon-color-hover,
  135. $bar-active-color:$icon-bar-active-color,
  136. $base-style:true,
  137. $disabled:false) {
  138. @if $base-style {
  139. background: $bar-bg;
  140. > * {
  141. label { color: $bar-font-color; }
  142. i { color: $bar-icon-color; }
  143. }
  144. > a:hover {
  145. background: $bar-hover-color;
  146. label { color: $bar-font-color-hover; }
  147. i { color: $bar-icon-color-hover; }
  148. }
  149. > a.active {
  150. background: $bar-active-color;
  151. label { color: $bar-font-color-hover; }
  152. i { color: $bar-icon-color-hover; }
  153. }
  154. }
  155. @if $disabled {
  156. .item.disabled {
  157. cursor: $icon-bar-disabled-cursor;
  158. opacity: $icon-bar-disabled-opacity;
  159. pointer-events: none;
  160. >* {
  161. opacity: $icon-bar-disabled-opacity;
  162. cursor: $icon-bar-disabled-cursor;
  163. }
  164. }
  165. }
  166. }
  167. // We use this to quickly create icon bars with a single mixin
  168. // $height - The overall calculated height of the icon bar (horizontal)
  169. // $bar-bg - the background color of the bar
  170. // $bar-font-color - the font color
  171. // $bar-hover-color - okay these are pretty obvious variables
  172. // $bar-icon-color - maybe we could skip explaining them all? Okay this one does change icon color if you use an icon font
  173. // $bar-active-color - the color of an active / hover state
  174. // $base-style - Apply base styles? Default: true.
  175. // $disabled - Allow disabled icons? Default: false.
  176. @mixin icon-bar(
  177. $bar-bg:$icon-bar-bg,
  178. $bar-font-color:$icon-bar-font-color,
  179. $bar-font-color-hover:$icon-bar-font-color-hover,
  180. $bar-hover-color:$icon-bar-hover-color,
  181. $bar-icon-color:$icon-bar-icon-color,
  182. $bar-icon-color-hover:$icon-bar-icon-color-hover,
  183. $bar-active-color:$icon-bar-active-color,
  184. $padding: $icon-bar-item-padding,
  185. $font-size: $icon-bar-font-size,
  186. $icon-size: $icon-bar-icon-size,
  187. $image-width: $icon-bar-image-width,
  188. $image-height: $icon-bar-image-height,
  189. $base-style:true,
  190. $disabled:true) {
  191. @include icon-bar-base();
  192. @include icon-bar-size($padding, $font-size, $icon-size, $image-width, $image-height);
  193. @include icon-bar-style($bar-bg, $bar-font-color, $bar-font-color-hover, $bar-hover-color, $bar-icon-color, $bar-icon-color-hover, $bar-active-color, $base-style, $disabled);
  194. // Counts
  195. &.two-up {
  196. .item { width: 50%; }
  197. &.vertical .item, &.small-vertical .item { width: auto; }
  198. &.medium-vertical .item {
  199. @media #{$medium-up} {
  200. width: auto;
  201. }
  202. }
  203. &.large-vertical .item {
  204. @media #{$large-up} {
  205. width: auto;
  206. }
  207. }
  208. }
  209. &.three-up {
  210. .item { width: 33.3333%; }
  211. &.vertical .item, &.small-vertical .item { width: auto; }
  212. &.medium-vertical .item {
  213. @media #{$medium-up} {
  214. width: auto;
  215. }
  216. }
  217. &.large-vertical .item {
  218. @media #{$large-up} {
  219. width: auto;
  220. }
  221. }
  222. }
  223. &.four-up {
  224. .item { width: 25%; }
  225. &.vertical .item, &.small-vertical .item { width: auto; }
  226. &.medium-vertical .item {
  227. @media #{$medium-up} {
  228. width: auto;
  229. }
  230. }
  231. &.large-vertical .item {
  232. @media #{$large-up} {
  233. width: auto;
  234. }
  235. }
  236. }
  237. &.five-up {
  238. .item { width: 20%; }
  239. &.vertical .item, &.small-vertical .item { width: auto; }
  240. &.medium-vertical .item {
  241. @media #{$medium-up} {
  242. width: auto;
  243. }
  244. }
  245. &.large-vertical .item {
  246. @media #{$large-up} {
  247. width: auto;
  248. }
  249. }
  250. }
  251. &.six-up {
  252. .item { width: 16.66667%; }
  253. &.vertical .item, &.small-vertical .item { width: auto; }
  254. &.medium-vertical .item {
  255. @media #{$medium-up} {
  256. width: auto;
  257. }
  258. }
  259. &.large-vertical .item {
  260. @media #{$large-up} {
  261. width: auto;
  262. }
  263. }
  264. }
  265. &.seven-up {
  266. .item { width: 14.28571%; }
  267. &.vertical .item, &.small-vertical .item { width: auto; }
  268. &.medium-vertical .item {
  269. @media #{$medium-up} {
  270. width: auto;
  271. }
  272. }
  273. &.large-vertical .item {
  274. @media #{$large-up} {
  275. width: auto;
  276. }
  277. }
  278. }
  279. &.eight-up {
  280. .item { width: 12.5%; }
  281. &.vertical .item, &.small-vertical .item { width: auto; }
  282. &.medium-vertical .item {
  283. @media #{$medium-up} {
  284. width: auto;
  285. }
  286. }
  287. &.large-vertical .item {
  288. @media #{$large-up} {
  289. width: auto;
  290. }
  291. }
  292. }
  293. }
  294. @include exports("icon-bar") {
  295. @if $include-html-icon-bar-classes {
  296. .icon-bar {
  297. @include icon-bar;
  298. }
  299. }
  300. }
  301. @if $include-html-icon-bar-classes {
  302. // toolbar styles
  303. .icon-bar {
  304. // Counts
  305. &.two-up {
  306. .item { width: 50%; }
  307. &.vertical .item, &.small-vertical .item { width: auto; }
  308. &.medium-vertical .item {
  309. @media #{$medium-up} {
  310. width: auto;
  311. }
  312. }
  313. &.large-vertical .item {
  314. @media #{$large-up} {
  315. width: auto;
  316. }
  317. }
  318. }
  319. &.three-up {
  320. .item { width: 33.3333%; }
  321. &.vertical .item, &.small-vertical .item { width: auto; }
  322. &.medium-vertical .item {
  323. @media #{$medium-up} {
  324. width: auto;
  325. }
  326. }
  327. &.large-vertical .item {
  328. @media #{$large-up} {
  329. width: auto;
  330. }
  331. }
  332. }
  333. &.four-up {
  334. .item { width: 25%; }
  335. &.vertical .item, &.small-vertical .item { width: auto; }
  336. &.medium-vertical .item {
  337. @media #{$medium-up} {
  338. width: auto;
  339. }
  340. }
  341. &.large-vertical .item {
  342. @media #{$large-up} {
  343. width: auto;
  344. }
  345. }
  346. }
  347. &.five-up {
  348. .item { width: 20%; }
  349. &.vertical .item, &.small-vertical .item { width: auto; }
  350. &.medium-vertical .item {
  351. @media #{$medium-up} {
  352. width: auto;
  353. }
  354. }
  355. &.large-vertical .item {
  356. @media #{$large-up} {
  357. width: auto;
  358. }
  359. }
  360. }
  361. &.six-up {
  362. .item { width: 16.66667%; }
  363. &.vertical .item, &.small-vertical .item { width: auto; }
  364. &.medium-vertical .item {
  365. @media #{$medium-up} {
  366. width: auto;
  367. }
  368. }
  369. &.large-vertical .item {
  370. @media #{$large-up} {
  371. width: auto;
  372. }
  373. }
  374. }
  375. &.seven-up {
  376. .item { width: 14.28571%; }
  377. &.vertical .item, &.small-vertical .item { width: auto; }
  378. &.medium-vertical .item {
  379. @media #{$medium-up} {
  380. width: auto;
  381. }
  382. }
  383. &.large-vertical .item {
  384. @media #{$large-up} {
  385. width: auto;
  386. }
  387. }
  388. }
  389. &.eight-up {
  390. .item { width: 12.5%; }
  391. &.vertical .item, &.small-vertical .item { width: auto; }
  392. &.medium-vertical .item {
  393. @media #{$medium-up} {
  394. width: auto;
  395. }
  396. }
  397. &.large-vertical .item {
  398. @media #{$large-up} {
  399. width: auto;
  400. }
  401. }
  402. }
  403. }
  404. }