tab-accordion.less 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551
  1. @accordion-border:#CDD8E3;
  2. @accordion-header-text:@ace-blue;
  3. @accordion-header-text-hover:#6EA6CC;
  4. @accordion-header-hover-bg:#F1F8FD;
  5. @accordion-active-bg:#EEF4F9;
  6. .enable_tabs() when(@enable-tabs = true) {
  7. .tab-content {
  8. border: 1px solid @tab-border;
  9. padding: 16px 12px;
  10. position: relative;
  11. //z-index:11;
  12. }
  13. .tab-content.no-padding {
  14. padding:0;
  15. }
  16. .tab-content.no-border {
  17. border:none;
  18. padding:12px;
  19. }
  20. .tab-content {
  21. .tab-paddingX (@index) when (@index >= 0) {
  22. &.padding-@{index} { padding:unit(@index,px) unit(ceil(@index * 0.75),px); }
  23. &.no-border.padding-@{index} { padding:unit(@index,px); }
  24. .tab-paddingX(@index - 2);
  25. }
  26. .tab-paddingX(32);
  27. }
  28. .nav.nav-tabs {
  29. .navtab-paddingX (@index) when (@index > 0) {
  30. &.padding-@{index} { padding-left:unit(@index,px); }
  31. .tabs-right > &.padding-@{index} , .tabs-left > &.padding-@{index} { padding-left:0; padding-top:unit(@index,px); }
  32. .navtab-paddingX(@index - 2);
  33. }
  34. .navtab-paddingX(32);
  35. }
  36. .nav-tabs {
  37. border-color: #C5D0DC;
  38. margin-bottom: 0 !important;//to override .rtl's
  39. margin-left: 0;
  40. position: relative;
  41. top: 1px;
  42. > li {
  43. > a {
  44. padding: 7px 12px 8px;
  45. &,&:focus {
  46. border-radius: 0 !important;
  47. border-color: @tab-border;
  48. background-color: #F9F9F9;
  49. color: #999;
  50. margin-right: -1px;
  51. line-height: 18px;
  52. position:relative;
  53. //z-index:11;
  54. }
  55. &:hover {
  56. background-color: #FFF;
  57. color: @tab-hover-color;
  58. border-color: @tab-border;
  59. }
  60. &:active, &:focus {
  61. outline:none !important;
  62. }
  63. }//a
  64. &:first-child > a {
  65. margin-left:0;
  66. }
  67. &.active > a{
  68. &,&:hover,&:focus {
  69. color: @tab-active-color;
  70. border-color: @tab-border;
  71. border-top: 2px solid @tab-active-border;
  72. border-bottom-color: transparent;
  73. background-color: #FFF;
  74. z-index: 1;
  75. line-height: 18px;
  76. margin-top: -1px;
  77. box-shadow: 0 -2px 3px 0 rgba(0,0,0,0.15);
  78. }
  79. }
  80. }
  81. .enable_tab_positions() when(@enable-tab-positions = true) {
  82. .tabs-below > & {
  83. /* tabs below */
  84. top:auto;
  85. margin-bottom:0;
  86. margin-top:-1px;
  87. border-color:@tab-border;
  88. border-bottom-width:0;
  89. > li {
  90. > a {
  91. &,&:hover,&:focus {
  92. border-color:@tab-border;
  93. }
  94. }
  95. &.active > a {
  96. &,&:hover,&:focus {
  97. border-color:@tab-border;
  98. border-top-width:1px;
  99. border-bottom:2px solid @tab-active-border;
  100. border-top-color:transparent;
  101. margin-top:0;
  102. box-shadow: 0 2px 3px 0 rgba(0,0,0,0.15);
  103. }
  104. }
  105. }
  106. }
  107. .tabs-left > & > li > a, .tabs-right > & > li > a {
  108. //tabs left
  109. min-width:60px;
  110. }
  111. .tabs-left > & {
  112. top:auto;
  113. margin-bottom:0;
  114. border-color:@tab-border;
  115. float: left;
  116. > li {
  117. float: none !important;//to override .rtl's
  118. > a {
  119. &,&:focus,&:hover {
  120. border-color:@tab-border;
  121. margin:0 -1px 0 0;
  122. }
  123. }
  124. &.active {
  125. > a {
  126. & , &:focus , &:hover {
  127. border-color: @tab-border;
  128. border-top-width: 1px;
  129. border-left: 2px solid @tab-active-border;
  130. border-right-color: transparent;
  131. margin: 0 -1px 0 -1px;
  132. .box-shadow(~"-2px 0 3px 0 rgba(0,0,0,0.15)") !important;//to override .rtl's
  133. }
  134. }
  135. }
  136. }
  137. }
  138. .tabs-right > & {
  139. //tabs right
  140. top:auto;
  141. margin-bottom: 0;
  142. border-color: @tab-border;
  143. float: right;
  144. > li {
  145. float: none !important;//to override RTL's
  146. > a {
  147. &,&:focus,&:hover {
  148. border-color: @tab-border;
  149. margin: 0 -1px;
  150. }
  151. }
  152. &.active {
  153. > a {
  154. & , &:focus , &:hover {
  155. border-color: @tab-border;
  156. border-top-width: 1px;
  157. border-right: 2px solid @tab-active-border;
  158. border-left-color: transparent;
  159. margin: 0 -2px 0 -1px;
  160. .box-shadow(~"2px 0 3px 0 rgba(0,0,0,0.15)");//to override .rtl's
  161. }
  162. }
  163. }
  164. }
  165. }
  166. }
  167. .enable_tab_positions();
  168. > li > a {
  169. //icon and badges
  170. > .badge {
  171. padding: 1px 5px;
  172. line-height: 15px;
  173. opacity: 0.75;
  174. }
  175. > .@{icon} {
  176. opacity: 0.75;
  177. }
  178. }
  179. > li.active > a {
  180. > .badge , > .@{icon} {
  181. opacity: 1;
  182. }
  183. }
  184. li .@{icon} {
  185. width:1.25em;
  186. display:inline-block;
  187. text-align:center;
  188. }
  189. > li.open .dropdown-toggle {
  190. //dropdown in tabs
  191. background-color: #4F99C6;
  192. border-color: #4F99C6;
  193. color: #FFF;
  194. > .@{icon} {
  195. color:#FFF !important;
  196. }
  197. }
  198. }
  199. .tabs-left , .tabs-right {
  200. .tab-content {
  201. overflow: auto;
  202. }
  203. }
  204. .nav-pills .open .dropdown-toggle, .nav > li.dropdown.open.active > a:hover, .nav > li.dropdown.open.active > a:focus {
  205. background-color: #4F99C6;
  206. border-color: #4F99C6;
  207. color: #FFFFFF;
  208. > .@{icon} {
  209. color:#FFF !important;
  210. }
  211. }
  212. .enable_tab_options() when (@enable-tab-options = true) {
  213. /* bigger tab buttons */
  214. .nav-tabs > li:not(.active):not(.open) > a:not(:hover) > .@{icon}:first-child.disabled {
  215. color:#909090 !important;
  216. }
  217. /* bigger tab buttons */
  218. .nav-tabs.tab-size-bigger > li > a {
  219. padding-left:14px;
  220. padding-right:14px;
  221. > .@{icon}:first-child {
  222. display:block;
  223. margin-bottom:6px;
  224. width:auto;
  225. }
  226. }
  227. //some tab customizations
  228. //spaced tabs (top & bottom)
  229. .nav-tabs.tab-space-1 > li > a {
  230. margin-right: 1px;
  231. }
  232. .nav-tabs.tab-space-2 > li > a {
  233. margin-right: 2px;
  234. }
  235. .nav-tabs.tab-space-3 > li > a {
  236. margin-right: 3px;
  237. }
  238. .nav-tabs.tab-space-4 > li > a {
  239. margin-right: 4px;
  240. }
  241. //colored tabs
  242. @tab-color-blue:#7DB4D8;
  243. .nav-tabs[class*="tab-color-"] > li > a {
  244. & , &:focus, &:hover {
  245. color: #FFF;
  246. border-color: transparent;
  247. margin-right: 3px;
  248. }
  249. > .badge {
  250. .border-radius(2px);
  251. }
  252. }
  253. .nav-tabs[class*="tab-color-"] > li:not(.active) > a {
  254. &:hover {
  255. opacity:0.85;
  256. border-color:rgba(0,0,0,0.15);
  257. border-bottom-color:transparent;
  258. }
  259. > .@{icon}:first-child{
  260. color:#FFF !important;
  261. }
  262. > .badge{
  263. color:rgba(0,0,0,0.4) !important;
  264. background-color:#FFF !important;
  265. .border-radius(2px);
  266. }
  267. }
  268. .nav-tabs.tab-color-blue > li > a {
  269. & , &:focus {
  270. background-color:@tab-color-blue;
  271. }
  272. }
  273. .nav-tabs[class*="tab-color-"] > li.active > a {
  274. & , &:focus, &:hover {
  275. background-color:#FFF;
  276. color:darken(desaturate(@tab-color-blue, 20%), 20%);
  277. .box-shadow(none) !important;
  278. }
  279. }
  280. .nav-tabs.tab-color-blue > li.active > a {
  281. & , &:focus, &:hover {
  282. color:darken(desaturate(@tab-color-blue, 25%), 25%);
  283. border-color:@tab-color-blue @tab-color-blue transparent;
  284. }
  285. .tabs-below & {
  286. border-color:transparent @tab-color-blue @tab-color-blue;
  287. }
  288. }
  289. .nav-tabs.tab-color-blue {
  290. border-bottom-color:#C5D0DC;
  291. }
  292. /* background for tab links */
  293. .nav-tabs.background-blue {
  294. padding-top:6px;
  295. background-color:#EFF3F8;
  296. border:1px solid #C5D0DC;
  297. }
  298. .tabs-below .nav-tabs.background-blue {
  299. padding-top:0;
  300. padding-bottom:6px;
  301. }
  302. .tabs-below .nav-tabs.tab-color-blue {
  303. border-top:none;
  304. border-bottom-color:#C5D0DC;
  305. }
  306. }
  307. .enable_tab_options();
  308. }
  309. .enable_tabs();
  310. //accordion
  311. .enable_accordion() when(@enable-accordion = true) {
  312. .accordion-style1.panel-group {
  313. .panel {
  314. border-radius: 0;
  315. border-color: @accordion-border;
  316. background-color: #FFF;
  317. box-shadow: none;
  318. &:last-child {
  319. border-bottom-width: 1px;
  320. }
  321. .collapse {
  322. background-color: #FFF;
  323. }
  324. + .panel {
  325. margin-top:2px;
  326. }
  327. }
  328. .panel-heading + .panel-collapse .panel-body {
  329. border-top-color: @accordion-border !important;
  330. }
  331. .panel-heading {
  332. padding:0;
  333. }
  334. .panel-heading .accordion-toggle {
  335. color:@tab-hover-color;
  336. background-color:@accordion-active-bg;
  337. position:relative;
  338. font-weight:bold;
  339. font-size: @font-size-accordion-toggle;
  340. line-height: 1;
  341. padding: 10px;
  342. display:block;
  343. &.collapsed {
  344. color:@accordion-header-text;
  345. font-weight:normal;
  346. background-color:#F9F9F9;
  347. }
  348. &:hover {
  349. color:@accordion-header-text-hover;
  350. background-color:@accordion-header-hover-bg;
  351. text-decoration:none;
  352. }
  353. &:focus,&:active {
  354. outline:none;
  355. text-decoration:none;
  356. }
  357. > .@{icon}:first-child {
  358. width:16px;
  359. }
  360. &:hover > .@{icon}:first-child{
  361. text-decoration:none;
  362. }
  363. }
  364. .panel-body , .collapse.in > .panel-body{
  365. border-top:1px solid @accordion-border;
  366. }
  367. &.no-padding {
  368. padding:0;
  369. }
  370. }
  371. //style2, used in faq, etc...
  372. .enable_accordion_style_2() when (@enable-accordion-style-2 = true) {
  373. .accordion-style2.panel-group {
  374. .panel {
  375. border-width:0;
  376. &:last-child {
  377. border-bottom-width: 0;
  378. }
  379. + .panel {
  380. margin-top:4px;
  381. }
  382. .panel-body {
  383. border-top:none;
  384. }
  385. }
  386. .panel-heading .accordion-toggle {
  387. background-color:#EDF3F7;
  388. border:2px solid #6EAED1;
  389. border-width:0 0 0 2px;
  390. &:hover {
  391. text-decoration:none;
  392. }
  393. &.collapsed {
  394. background-color:#F3F3F3;
  395. color:#606060;
  396. border-width:0 0 0 1px;
  397. border-color:#D9D9D9;
  398. &:hover {
  399. background-color:#F6F6F6;
  400. color:#438EB9;
  401. text-decoration:none;
  402. }
  403. }
  404. }
  405. .panel-body , .collapse.in > .panel-body{
  406. border-top:none;
  407. }
  408. }
  409. //nested questions
  410. .accordion-style2.panel-group .accordion-style2.panel-group {
  411. .panel {
  412. border-bottom:1px dotted #D9D9D9;
  413. &:last-child {
  414. border-bottom:none;
  415. }
  416. .panel-heading , .panel-heading .accordion-toggle {
  417. background-color: transparent;
  418. border-width: 0;
  419. font-size: @font-size-accordion-toggle;
  420. padding-top: 6px;
  421. padding-bottom: 8px;
  422. }
  423. .panel-heading {
  424. padding-top:0; padding-bottom:0;
  425. }
  426. }
  427. }
  428. }
  429. .enable_accordion_style_2();
  430. }
  431. .enable_accordion();