base.css 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596
  1. /* Layout */
  2. * {
  3. margin: 0;
  4. }
  5. html {
  6. overflow-y: scroll;
  7. }
  8. html, body {
  9. height: 100%;
  10. }
  11. body {
  12. padding-top: 70px;
  13. }
  14. .container {
  15. width: auto;
  16. max-width: 1600px;
  17. }
  18. .wrapper {
  19. min-height: 100%;
  20. height: auto !important;
  21. margin: 0 auto -61px; /* the bottom margin is the negative value of the footer's height */
  22. padding-bottom: 30px;
  23. }
  24. .navbar-brand {
  25. padding: 12px 15px 8px;
  26. }
  27. .footer, .push {
  28. height: 60px; /* .push must be the same height as .footer */
  29. }
  30. .footer {
  31. background-color: #f5f5f5;
  32. border-top: 1px solid #d0d0d0;
  33. }
  34. footer p {
  35. margin: 20px 0;
  36. }
  37. /* Hide the username in the navigation menu on displays less than 1400px wide */
  38. @media (max-width: 1399px) {
  39. #navbar_user {
  40. display: none;
  41. }
  42. }
  43. /* Hide the search bar in the navigation menu on displays less than 1250px wide */
  44. @media (max-width: 1249px) {
  45. #navbar_search {
  46. display: none;
  47. }
  48. }
  49. /* Printer friendly CSS class and various fixes for printing. */
  50. @media print {
  51. body {
  52. padding-top: 0px;
  53. }
  54. a[href]:after {
  55. content: none !important;
  56. }
  57. .noprint {
  58. display: none !important;
  59. }
  60. }
  61. /* Collapse the nav menu on displays less than 980px wide */
  62. @media (max-width: 979px) {
  63. .navbar-header {
  64. float: none;
  65. }
  66. .navbar-left,.navbar-right {
  67. float: none !important;
  68. }
  69. .navbar-toggle {
  70. display: block;
  71. }
  72. .navbar-collapse {
  73. border-top: 1px solid transparent;
  74. box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
  75. }
  76. .navbar-fixed-top {
  77. top: 0;
  78. border-width: 0 0 1px;
  79. }
  80. .navbar-collapse.collapse {
  81. display: none!important;
  82. max-height: none;
  83. }
  84. .navbar-nav {
  85. float: none !important;
  86. margin-top: 7.5px;
  87. }
  88. .navbar-nav>li {
  89. float: none;
  90. }
  91. .navbar-nav>li>a {
  92. padding-top: 10px;
  93. padding-bottom: 10px;
  94. }
  95. .collapse.in {
  96. display:block !important;
  97. }
  98. #navbar_user {
  99. display: inline;
  100. }
  101. }
  102. /* Navigation menu */
  103. li.subnav > a {
  104. padding-left: 30px;
  105. }
  106. ul.dropdown-menu {
  107. width: 250px;
  108. }
  109. ul.dropdown-menu div.buttons {
  110. padding-right: 10px;
  111. padding-top: 2px;
  112. }
  113. ul.dropdown-menu div.buttons a {
  114. width: 26px;
  115. }
  116. ul.dropdown-menu > li > a {
  117. clear: left;
  118. }
  119. /* Forms */
  120. label {
  121. font-weight: normal;
  122. }
  123. label.required {
  124. font-weight: bold;
  125. }
  126. input[name="pk"] {
  127. margin-top: 0;
  128. }
  129. /* Color Selections */
  130. .color-selection-aa1409 {
  131. background-color: #aa1409;
  132. color: #ffffff;
  133. }
  134. .color-selection-f44336 {
  135. background-color: #f44336;
  136. color: #ffffff;
  137. }
  138. .color-selection-e91e63 {
  139. background-color: #e91e63;
  140. color: #ffffff;
  141. }
  142. .color-selection-ffe4e1 {
  143. background-color: #ffe4e1;
  144. color: #000000;
  145. }
  146. .color-selection-ff66ff {
  147. background-color: #ff66ff;
  148. color: #ffffff;
  149. }
  150. .color-selection-9c27b0 {
  151. background-color: #9c27b0;
  152. color: #ffffff;
  153. }
  154. .color-selection-673ab7 {
  155. background-color: #673ab7;
  156. color: #ffffff;
  157. }
  158. .color-selection-3f51b5 {
  159. background-color: #3f51b5;
  160. color: #ffffff;
  161. }
  162. .color-selection-2196f3 {
  163. background-color: #2196f3;
  164. color: #ffffff;
  165. }
  166. .color-selection-03a9f4 {
  167. background-color: #03a9f4;
  168. color: #ffffff;
  169. }
  170. .color-selection-00bcd4 {
  171. background-color: #00bcd4;
  172. color: #ffffff;
  173. }
  174. .color-selection-009688 {
  175. background-color: #009688;
  176. color: #ffffff;
  177. }
  178. .color-selection-00ffff {
  179. background-color: #00ffff;
  180. color: #ffffff;
  181. }
  182. .color-selection-2f6a31 {
  183. background-color: #2f6a31;
  184. color: #ffffff;
  185. }
  186. .color-selection-4caf50 {
  187. background-color: #4caf50;
  188. color: #ffffff;
  189. }
  190. .color-selection-8bc34a {
  191. background-color: #8bc34a;
  192. color: #ffffff;
  193. }
  194. .color-selection-cddc39 {
  195. background-color: #cddc39;
  196. color: #000000;
  197. }
  198. .color-selection-ffeb3b {
  199. background-color: #ffeb3b;
  200. color: #000000;
  201. }
  202. .color-selection-ffc107 {
  203. background-color: #ffc107;
  204. color: #000000;
  205. }
  206. .color-selection-ff9800 {
  207. background-color: #ff9800;
  208. color: #ffffff;
  209. }
  210. .color-selection-ff5722 {
  211. background-color: #ff5722;
  212. color: #ffffff;
  213. }
  214. .color-selection-795548 {
  215. background-color: #795548;
  216. color: #ffffff;
  217. }
  218. .color-selection-c0c0c0 {
  219. background-color: #c0c0c0;
  220. color: #000000;
  221. }
  222. .color-selection-9e9e9e {
  223. background-color: #9e9e9e;
  224. color: #ffffff;
  225. }
  226. .color-selection-607d8b {
  227. background-color: #607d8b;
  228. color: #ffffff;
  229. }
  230. .color-selection-111111 {
  231. background-color: #111111;
  232. color: #ffffff;
  233. }
  234. .color-selection-ffffff {
  235. background-color: #ffffff;
  236. color: #000000;
  237. }
  238. /* Tables */
  239. th.pk, td.pk {
  240. padding-bottom: 6px;
  241. padding-top: 10px;
  242. width: 30px;
  243. }
  244. tfoot td {
  245. font-weight: bold;
  246. }
  247. table.attr-table td:nth-child(1) {
  248. width: 25%;
  249. }
  250. .table-headings th {
  251. background-color: #f5f5f5;
  252. }
  253. /* Paginator */
  254. div.paginator {
  255. margin-bottom: 20px;
  256. }
  257. div.paginator form {
  258. margin-bottom: 6px;
  259. }
  260. nav ul.pagination {
  261. margin-top: 0;
  262. margin-bottom: 8px !important;
  263. }
  264. /* Racks */
  265. div.rack_header {
  266. margin-left: 36px;
  267. text-align: center;
  268. width: 230px;
  269. }
  270. ul.rack_legend {
  271. float: left;
  272. list-style-type: none;
  273. margin-right: 6px;
  274. padding: 0;
  275. width: 30px;
  276. }
  277. ul.rack_legend li {
  278. color: #c0c0c0;
  279. display: block;
  280. font-size: 10px;
  281. height: 20px;
  282. overflow: hidden;
  283. padding: 5px 0;
  284. text-align: right;
  285. }
  286. div.rack_frame {
  287. float: left;
  288. position: relative;
  289. }
  290. ul.rack {
  291. border: 2px solid #404040;
  292. float: left;
  293. list-style-type: none;
  294. padding: 0;
  295. position: absolute;
  296. width: 230px;
  297. }
  298. ul.rack li {
  299. border-top: 1px solid #e0e0e0;
  300. display: block;
  301. font-size: 13px;
  302. height: 20px;
  303. overflow: hidden;
  304. text-align: center;
  305. }
  306. ul.rack li.h2u { height: 40px; }
  307. ul.rack li.h2u a, ul.rack li.h2u span { padding: 10px 0; }
  308. ul.rack li.h3u { height: 60px; }
  309. ul.rack li.h3u a, ul.rack li.h3u span { padding: 20px 0; }
  310. ul.rack li.h4u { height: 80px; }
  311. ul.rack li.h4u a, ul.rack li.h4u span { padding: 30px 0; }
  312. ul.rack li.h5u { height: 100px; }
  313. ul.rack li.h5u a, ul.rack li.h5u span { padding: 40px 0; }
  314. ul.rack li.h6u { height: 120px; }
  315. ul.rack li.h6u a, ul.rack li.h6u span { padding: 50px 0; }
  316. ul.rack li.h7u { height: 140px; }
  317. ul.rack li.h7u a, ul.rack li.h7u span { padding: 60px 0; }
  318. ul.rack li.h8u { height: 160px; }
  319. ul.rack li.h8u a, ul.rack li.h8u span { padding: 70px 0; }
  320. ul.rack li.h9u { height: 180px; }
  321. ul.rack li.h9u a, ul.rack li.h9u span { padding: 80px 0; }
  322. ul.rack li.h10u { height: 200px; }
  323. ul.rack li.h10u a, ul.rack li.h10u span { padding: 90px 0; }
  324. ul.rack li.h11u { height: 220px; }
  325. ul.rack li.h11u a, ul.rack li.h11u span { padding: 100px 0; }
  326. ul.rack li.h12u { height: 240px; }
  327. ul.rack li.h12u a, ul.rack li.h12u span { padding: 110px 0; }
  328. ul.rack li.h13u { height: 260px; }
  329. ul.rack li.h13u a, ul.rack li.h13u span { padding: 120px 0; }
  330. ul.rack li.h14u { height: 280px; }
  331. ul.rack li.h14u a, ul.rack li.h14u span { padding: 130px 0; }
  332. ul.rack li.h15u { height: 300px; }
  333. ul.rack li.h15u a, ul.rack li.h15u span { padding: 140px 0; }
  334. ul.rack li.h16u { height: 320px; }
  335. ul.rack li.h16u a, ul.rack li.h16u span { padding: 150px 0; }
  336. ul.rack li.h17u { height: 340px; }
  337. ul.rack li.h17u a, ul.rack li.h17u span { padding: 160px 0; }
  338. ul.rack li.h18u { height: 360px; }
  339. ul.rack li.h18u a, ul.rack li.h18u span { padding: 170px 0; }
  340. ul.rack li.h19u { height: 380px; }
  341. ul.rack li.h19u a, ul.rack li.h19u span { padding: 180px 0; }
  342. ul.rack li.h20u { height: 400px; }
  343. ul.rack li.h20u a, ul.rack li.h20u span { padding: 190px 0; }
  344. ul.rack li.h21u { height: 420px; }
  345. ul.rack li.h21u a, ul.rack li.h21u span { padding: 200px 0; }
  346. ul.rack li.h22u { height: 440px; }
  347. ul.rack li.h22u a, ul.rack li.h22u span { padding: 210px 0; }
  348. ul.rack li.h23u { height: 460px; }
  349. ul.rack li.h23u a, ul.rack li.h23u span { padding: 220px 0; }
  350. ul.rack li.h24u { height: 480px; }
  351. ul.rack li.h24u a, ul.rack li.h24u span { padding: 230px 0; }
  352. ul.rack li.h25u { height: 500px; }
  353. ul.rack li.h25u a, ul.rack li.h25u span { padding: 240px 0; }
  354. ul.rack li.h26u { height: 520px; }
  355. ul.rack li.h26u a, ul.rack li.h26u span { padding: 250px 0; }
  356. ul.rack li.h27u { height: 540px; }
  357. ul.rack li.h27u a, ul.rack li.h27u span { padding: 260px 0; }
  358. ul.rack li.h28u { height: 560px; }
  359. ul.rack li.h28u a, ul.rack li.h28u span { padding: 270px 0; }
  360. ul.rack li.h29u { height: 580px; }
  361. ul.rack li.h29u a, ul.rack li.h29u span { padding: 280px 0; }
  362. ul.rack li.h30u { height: 600px; }
  363. ul.rack li.h30u a, ul.rack li.h30u span { padding: 290px 0; }
  364. ul.rack li.h31u { height: 620px; }
  365. ul.rack li.h31u a, ul.rack li.h31u span { padding: 300px 0; }
  366. ul.rack li.h32u { height: 640px; }
  367. ul.rack li.h32u a, ul.rack li.h32u span { padding: 310px 0; }
  368. ul.rack li.h33u { height: 660px; }
  369. ul.rack li.h33u a, ul.rack li.h33u span { padding: 320px 0; }
  370. ul.rack li.h34u { height: 680px; }
  371. ul.rack li.h34u a, ul.rack li.h34u span { padding: 330px 0; }
  372. ul.rack li.h35u { height: 700px; }
  373. ul.rack li.h35u a, ul.rack li.h35u span { padding: 340px 0; }
  374. ul.rack li.h36u { height: 720px; }
  375. ul.rack li.h36u a, ul.rack li.h36u span { padding: 350px 0; }
  376. ul.rack li.h37u { height: 740px; }
  377. ul.rack li.h37u a, ul.rack li.h37u span { padding: 360px 0; }
  378. ul.rack li.h38u { height: 760px; }
  379. ul.rack li.h38u a, ul.rack li.h38u span { padding: 370px 0; }
  380. ul.rack li.h39u { height: 780px; }
  381. ul.rack li.h39u a, ul.rack li.h39u span { padding: 380px 0; }
  382. ul.rack li.h40u { height: 800px; }
  383. ul.rack li.h40u a, ul.rack li.h40u span { padding: 390px 0; }
  384. ul.rack li.h41u { height: 820px; }
  385. ul.rack li.h41u a, ul.rack li.h41u span { padding: 400px 0; }
  386. ul.rack li.h42u { height: 840px; }
  387. ul.rack li.h42u a, ul.rack li.h42u span { padding: 410px 0; }
  388. ul.rack li.h43u { height: 860px; }
  389. ul.rack li.h43u a, ul.rack li.h43u span { padding: 420px 0; }
  390. ul.rack li.h44u { height: 880px; }
  391. ul.rack li.h44u a, ul.rack li.h44u span { padding: 430px 0; }
  392. ul.rack li.h45u { height: 900px; }
  393. ul.rack li.h45u a, ul.rack li.h45u span { padding: 440px 0; }
  394. ul.rack li.h46u { height: 920px; }
  395. ul.rack li.h46u a, ul.rack li.h46u span { padding: 450px 0; }
  396. ul.rack li.h47u { height: 940px; }
  397. ul.rack li.h47u a, ul.rack li.h47u span { padding: 460px 0; }
  398. ul.rack li.h48u { height: 960px; }
  399. ul.rack li.h48u a, ul.rack li.h48u span { padding: 470px 0; }
  400. ul.rack li.h49u { height: 980px; }
  401. ul.rack li.h49u a, ul.rack li.h49u span { padding: 480px 0; }
  402. ul.rack li.h50u { height: 1000px; }
  403. ul.rack li.h50u a, ul.rack li.h50u span { padding: 490px 0; }
  404. ul.rack_far_face {
  405. background-color: #f7f7f7;
  406. z-index: 100;
  407. }
  408. ul.rack_far_face li.occupied {
  409. background: repeating-linear-gradient(
  410. 45deg,
  411. #f7f7f7,
  412. #f7f7f7 7px,
  413. #f0f0f0 7px,
  414. #f0f0f0 14px
  415. );
  416. }
  417. ul.rack_far_face li.blocked {
  418. background: repeating-linear-gradient(
  419. 45deg,
  420. #f7f7f7,
  421. #f7f7f7 7px,
  422. #ffc7c7 7px,
  423. #ffc7c7 14px
  424. );
  425. }
  426. ul.rack_near_face li.reserved {
  427. background: repeating-linear-gradient(
  428. 45deg,
  429. #f7f7f7,
  430. #f7f7f7 7px,
  431. #c7c7ff 7px,
  432. #c7c7ff 14px
  433. );
  434. }
  435. ul.rack_near_face {
  436. z-index: 200;
  437. }
  438. ul.rack_near_face li.occupied {
  439. border-top: 1px solid #474747;
  440. color: #474747;
  441. }
  442. ul.rack_near_face li.occupied:hover {
  443. background-image: url('../img/tint_20.png');
  444. }
  445. ul.rack_near_face li:first-child {
  446. border-top: 0;
  447. }
  448. ul.rack_near_face li.available a {
  449. color: #0000ff;
  450. display: none;
  451. text-decoration: none;
  452. }
  453. ul.rack_near_face li.available:hover {
  454. background-color: #ffffff;
  455. }
  456. ul.rack_near_face li.available:hover a {
  457. display: block;
  458. }
  459. ul.rack li.occupied a {
  460. color: #ffffff;
  461. display: block;
  462. font-weight: bold;
  463. }
  464. ul.rack li.occupied a:hover {
  465. text-decoration: none;
  466. }
  467. ul.rack li.occupied span {
  468. cursor: default;
  469. display: block;
  470. }
  471. li.occupied + li.available {
  472. border-top: 1px solid #474747;
  473. }
  474. /* Devices */
  475. table.component-list td.subtable {
  476. padding: 0;
  477. padding-left: 16px;
  478. }
  479. table.component-list td.subtable td {
  480. border: none;
  481. padding-bottom: 6px;
  482. padding-top: 6px;
  483. }
  484. table.interface-ips th {
  485. font-size: 80%;
  486. font-weight: normal;
  487. }
  488. /* Reports */
  489. table.reports td.method {
  490. font-family: monospace;
  491. padding-left: 30px;
  492. }
  493. td.report-stats label {
  494. display: inline-block;
  495. line-height: 14px;
  496. margin-bottom: 0;
  497. min-width: 40px;
  498. }
  499. table.report th {
  500. position: relative;
  501. }
  502. table.report th a {
  503. position: absolute;
  504. top: -51px;
  505. }
  506. /* Rendered Markdown */
  507. .rendered-markdown table {
  508. width: 100%;
  509. }
  510. .rendered-markdown th {
  511. border-bottom: 2px solid #dddddd;
  512. padding: 8px;
  513. }
  514. .rendered-markdown td {
  515. border-top: 1px solid #dddddd;
  516. padding: 8px;
  517. }
  518. .rendered-markdown :last-child {
  519. margin-bottom: 0;
  520. }
  521. /* AJAX loader */
  522. .loading {
  523. position: fixed;
  524. display: none;
  525. z-index: 999;
  526. height: 2em;
  527. width: 2em;
  528. overflow: show;
  529. margin: auto;
  530. top: 0;
  531. left: 0;
  532. bottom: 0;
  533. right: 0;
  534. }
  535. .loading:before {
  536. content: '';
  537. display: block;
  538. position: fixed;
  539. top: 0;
  540. left: 0;
  541. width: 100%;
  542. height: 100%;
  543. background-color: rgba(0,0,0,0.3);
  544. }
  545. /* Misc */
  546. .color-block {
  547. display: block;
  548. width: 80px;
  549. border: 1px solid grey;
  550. }
  551. .text-nowrap {
  552. white-space: nowrap;
  553. }
  554. .banner-bottom {
  555. margin-bottom: 50px;
  556. }
  557. .panel table {
  558. margin-bottom: 0;
  559. }
  560. .panel .table th {
  561. border-bottom-width: 1px;
  562. }
  563. .panel table tr.even:first-child td {
  564. border-top: 0;
  565. }
  566. .panel .list-group {
  567. max-height: 400px;
  568. overflow: auto;
  569. }
  570. ul.nav-tabs, ul.nav-pills {
  571. margin-bottom: 20px;
  572. }
  573. /* Fix progress bar margin inside table cells */
  574. td .progress {
  575. margin-bottom: 0;
  576. min-width: 100px;
  577. }
  578. textarea {
  579. font-family: Consolas, Lucida Console, monospace;
  580. }