You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Select.css 11KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2021 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. .Select {
  21. position: relative;
  22. display: inline-block;
  23. vertical-align: middle;
  24. font-size: var(--smallFontSize);
  25. text-align: left;
  26. }
  27. .Select,
  28. .Select div,
  29. .Select input,
  30. .Select span {
  31. box-sizing: border-box;
  32. }
  33. .Select.is-disabled > .Select-control {
  34. background-color: var(--disableGrayBg) !important;
  35. border-color: var(--disableGrayBorder) !important;
  36. }
  37. .Select.is-disabled > .Select-control:hover {
  38. box-shadow: none !important;
  39. }
  40. .Select.is-disabled .Select-arrow-zone {
  41. cursor: not-allowed !important;
  42. pointer-events: none !important;
  43. }
  44. .Select.is-disabled .Select-placeholder,
  45. .Select.is-disabled .Select-value {
  46. color: var(--disableGrayText) !important;
  47. }
  48. .Select-control {
  49. position: relative;
  50. display: table;
  51. width: 100%;
  52. height: var(--controlHeight);
  53. line-height: calc(var(--controlHeight) - 2px);
  54. border: 1px solid var(--gray80);
  55. border-collapse: separate;
  56. border-radius: 2px;
  57. background-color: #fff;
  58. color: var(--baseFontColor);
  59. cursor: default;
  60. outline: none;
  61. overflow: hidden;
  62. }
  63. .is-searchable.is-open > .Select-control {
  64. cursor: text;
  65. }
  66. .is-open > .Select-control {
  67. border-bottom-right-radius: 0;
  68. border-bottom-left-radius: 0;
  69. background: #fff;
  70. }
  71. .is-open > .Select-control > .Select-arrow {
  72. border-color: transparent transparent #999;
  73. border-width: 0 5px 5px;
  74. }
  75. .is-searchable.is-focused:not(.is-open) > .Select-control {
  76. cursor: text;
  77. }
  78. .is-focused:not(.is-open) > .Select-control {
  79. border-color: var(--blue);
  80. }
  81. .Select-placeholder {
  82. color: var(--secondFontColor);
  83. }
  84. .Select-placeholder,
  85. :not(.Select--multi) > .Select-control .Select-value {
  86. bottom: 0;
  87. left: 0;
  88. line-height: 23px;
  89. padding-left: 8px;
  90. padding-right: 24px;
  91. position: absolute;
  92. right: 0;
  93. top: 0;
  94. max-width: 100%;
  95. overflow: hidden;
  96. text-overflow: ellipsis;
  97. white-space: nowrap;
  98. }
  99. .Select-value [class^='icon-'] {
  100. padding-top: 5px;
  101. }
  102. .Select-value svg,
  103. .Select-value img {
  104. padding-top: 3px;
  105. }
  106. .Select-option svg,
  107. .Select-option img,
  108. .Select-option [class^='icon-'] {
  109. padding-top: 2px;
  110. }
  111. .has-value:not(.Select--multi) > .Select-control > .Select-value .Select-value-label,
  112. .has-value.is-pseudo-focused:not(.Select--multi)
  113. > .Select-control
  114. > .Select-value
  115. .Select-value-label {
  116. color: var(--baseFontColor);
  117. }
  118. .has-value:not(.Select--multi) > .Select-control > .Select-value a.Select-value-label,
  119. .has-value.is-pseudo-focused:not(.Select--multi)
  120. > .Select-control
  121. > .Select-value
  122. a.Select-value-label {
  123. cursor: pointer;
  124. text-decoration: none;
  125. }
  126. .has-value:not(.Select--multi) > .Select-control > .Select-value a.Select-value-label:hover,
  127. .has-value.is-pseudo-focused:not(.Select--multi)
  128. > .Select-control
  129. > .Select-value
  130. a.Select-value-label:hover,
  131. .has-value:not(.Select--multi) > .Select-control > .Select-value a.Select-value-label:focus,
  132. .has-value.is-pseudo-focused:not(.Select--multi)
  133. > .Select-control
  134. > .Select-value
  135. a.Select-value-label:focus {
  136. color: #007eff;
  137. outline: none;
  138. text-decoration: underline;
  139. }
  140. .Select-input {
  141. vertical-align: top;
  142. height: 22px;
  143. padding-left: 8px;
  144. padding-right: 8px;
  145. outline: none;
  146. }
  147. .Select-input > input {
  148. background: none transparent;
  149. border: 0 none;
  150. cursor: default;
  151. display: inline-block;
  152. font-family: inherit;
  153. font-size: var(--smallFontSize);
  154. height: 22px;
  155. margin: 0;
  156. outline: none;
  157. padding: 0;
  158. box-shadow: none;
  159. -webkit-appearance: none;
  160. }
  161. .is-focused .Select-input > input {
  162. cursor: text;
  163. }
  164. .has-value.is-pseudo-focused .Select-input {
  165. opacity: 0;
  166. }
  167. .Select-control:not(.is-searchable) > .Select-input {
  168. outline: none;
  169. }
  170. .Select-loading-zone {
  171. cursor: pointer;
  172. display: table-cell;
  173. position: relative;
  174. text-align: center;
  175. vertical-align: middle;
  176. width: 16px;
  177. }
  178. .Select-loading {
  179. -webkit-animation: Select-animation-spin 400ms infinite linear;
  180. -o-animation: Select-animation-spin 400ms infinite linear;
  181. animation: Select-animation-spin 400ms infinite linear;
  182. width: 16px;
  183. height: 16px;
  184. box-sizing: border-box;
  185. border-radius: 50%;
  186. border: 2px solid #ccc;
  187. border-right-color: var(--baseFontColor);
  188. display: inline-block;
  189. position: relative;
  190. vertical-align: middle;
  191. }
  192. .Select-clear-zone {
  193. -webkit-animation: Select-animation-fadeIn 200ms;
  194. -o-animation: Select-animation-fadeIn 200ms;
  195. animation: Select-animation-fadeIn 200ms;
  196. color: #999;
  197. cursor: pointer;
  198. display: table-cell;
  199. position: relative;
  200. text-align: center;
  201. vertical-align: middle;
  202. width: 16px;
  203. height: 16px;
  204. padding-right: 4px;
  205. }
  206. .Select-clear-zone:hover .Select-clear {
  207. background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIHZpZXdCb3g9IjAgMCAxNCAxNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3BhY2U9InByZXNlcnZlIiBzdHlsZT0iZmlsbC1ydWxlOmV2ZW5vZGQ7Y2xpcC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlLWxpbmVqb2luOnJvdW5kO3N0cm9rZS1taXRlcmxpbWl0OjEuNDE0MjE7Ij4gICAgPGcgdHJhbnNmb3JtPSJtYXRyaXgoMC4wMjM0Mzc1LDAsMCwwLjAyMzQzNzUsLTUuMDE1NjIsLTUuMDE1NjIpIj4gICAgICAgIDxwYXRoIGQ9Ik04MTAsMjc0TDU3Miw1MTJMODEwLDc1MEw3NTAsODEwTDUxMiw1NzJMMjc0LDgxMEwyMTQsNzUwTDQ1Miw1MTJMMjE0LDI3NEwyNzQsMjE0TDUxMiw0NTJMNzUwLDIxNEw4MTAsMjc0WiIgc3R5bGU9ImZpbGw6cmdiKDIzMSwyMCw1Nik7ZmlsbC1ydWxlOm5vbnplcm87Ii8+ICAgIDwvZz48L3N2Zz4=);
  208. }
  209. .Select-clear {
  210. display: block;
  211. width: 9px;
  212. height: 9px;
  213. background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiIHN0YW5kYWxvbmU9Im5vIj8+PCFET0NUWVBFIHN2ZyBQVUJMSUMgIi0vL1czQy8vRFREIFNWRyAxLjEvL0VOIiAiaHR0cDovL3d3dy53My5vcmcvR3JhcGhpY3MvU1ZHLzEuMS9EVEQvc3ZnMTEuZHRkIj48c3ZnIHdpZHRoPSIxMDAlIiBoZWlnaHQ9IjEwMCUiIHZpZXdCb3g9IjAgMCAxNCAxNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHhtbG5zOnhsaW5rPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5L3hsaW5rIiB4bWw6c3BhY2U9InByZXNlcnZlIiBzdHlsZT0iZmlsbC1ydWxlOmV2ZW5vZGQ7Y2xpcC1ydWxlOmV2ZW5vZGQ7c3Ryb2tlLWxpbmVqb2luOnJvdW5kO3N0cm9rZS1taXRlcmxpbWl0OjEuNDE0MjE7Ij4gICAgPGcgdHJhbnNmb3JtPSJtYXRyaXgoMC4wMjM0Mzc1LDAsMCwwLjAyMzQzNzUsLTUuMDE1NjIsLTUuMDE1NjIpIj4gICAgICAgIDxwYXRoIGQ9Ik04MTAsMjc0TDU3Miw1MTJMODEwLDc1MEw3NTAsODEwTDUxMiw1NzJMMjc0LDgxMEwyMTQsNzUwTDQ1Miw1MTJMMjE0LDI3NEwyNzQsMjE0TDUxMiw0NTJMNzUwLDIxNEw4MTAsMjc0WiIgc3R5bGU9ImZpbGw6cmdiKDE1MywxNTMsMTUzKTtmaWxsLXJ1bGU6bm9uemVybzsiLz4gICAgPC9nPjwvc3ZnPg==);
  214. background-size: 9px 9px;
  215. text-indent: -9999px;
  216. }
  217. .Select--multi .Select-clear-zone {
  218. width: 17px;
  219. }
  220. .Select-arrow-zone {
  221. cursor: pointer;
  222. display: table-cell;
  223. position: relative;
  224. text-align: center;
  225. vertical-align: middle;
  226. width: 20px;
  227. padding-right: 5px;
  228. }
  229. .Select-arrow {
  230. border-color: #999 transparent transparent;
  231. border-style: solid;
  232. border-width: 4px 4px 2px;
  233. display: inline-block;
  234. height: 0;
  235. width: 0;
  236. }
  237. .is-open .Select-arrow,
  238. .Select-arrow-zone:hover > .Select-arrow {
  239. border-top-color: #666;
  240. }
  241. @-webkit-keyframes Select-animation-fadeIn {
  242. from {
  243. opacity: 0;
  244. }
  245. to {
  246. opacity: 1;
  247. }
  248. }
  249. @keyframes Select-animation-fadeIn {
  250. from {
  251. opacity: 0;
  252. }
  253. to {
  254. opacity: 1;
  255. }
  256. }
  257. .Select-menu-outer {
  258. border-bottom-right-radius: 4px;
  259. border-bottom-left-radius: 4px;
  260. background-color: #fff;
  261. border: 1px solid #ccc;
  262. border-top-color: var(--barBorderColor);
  263. box-sizing: border-box;
  264. margin-top: -1px;
  265. max-height: 200px;
  266. position: absolute;
  267. top: 100%;
  268. width: 100%;
  269. z-index: var(--dropdownMenuZIndex);
  270. -webkit-overflow-scrolling: touch;
  271. box-shadow: var(--defaultShadow);
  272. }
  273. .Select-menu {
  274. max-height: 198px;
  275. padding: 5px 0;
  276. overflow-y: auto;
  277. }
  278. .Select-option {
  279. display: block;
  280. line-height: 20px;
  281. padding: 0 8px;
  282. box-sizing: border-box;
  283. color: var(--baseFontColor);
  284. font-size: var(--smallFontSize);
  285. cursor: pointer;
  286. white-space: nowrap;
  287. overflow: hidden;
  288. text-overflow: ellipsis;
  289. }
  290. .Select-option:last-child {
  291. border-bottom-right-radius: 2px;
  292. border-bottom-left-radius: 2px;
  293. }
  294. .Select-option.is-focused {
  295. background-color: var(--barBackgroundColor);
  296. }
  297. .Select-option.is-disabled {
  298. cursor: default;
  299. opacity: 0.4;
  300. font-style: italic;
  301. }
  302. .Select-noresults {
  303. box-sizing: border-box;
  304. color: var(--gray60);
  305. cursor: default;
  306. display: block;
  307. padding: 8px 10px;
  308. }
  309. .Select--multi .Select-value {
  310. background-color: rgba(0, 126, 255, 0.08);
  311. border-radius: 2px;
  312. border: 1px solid rgba(0, 126, 255, 0.24);
  313. color: var(--baseFontColor);
  314. display: inline-block;
  315. font-size: var(--smallFontSize);
  316. line-height: 14px;
  317. margin: 1px 4px 1px 1px;
  318. vertical-align: top;
  319. }
  320. .Select-value-label {
  321. font-size: var(--smallFontSize);
  322. }
  323. .is-searchable.is-open .Select-value-label {
  324. opacity: 0.5;
  325. }
  326. .Select-big .Select-control {
  327. padding-top: 4px;
  328. padding-bottom: 4px;
  329. }
  330. .Select-big .Select-placeholder {
  331. margin-top: 4px;
  332. margin-bottom: 4px;
  333. }
  334. .Select-big .Select-value-label {
  335. display: inline-block;
  336. margin-top: 7px;
  337. line-height: 16px;
  338. }
  339. .Select-big .Select-option {
  340. padding: 7px 8px;
  341. line-height: 16px;
  342. }
  343. .Select-big img,
  344. .Select-big svg {
  345. padding-top: 0;
  346. }
  347. .Select--multi .Select-value-icon,
  348. .Select--multi .Select-value-label {
  349. display: inline-block;
  350. vertical-align: middle;
  351. }
  352. .Select--multi .Select-value-label {
  353. display: inline-block;
  354. max-width: 200px;
  355. border-bottom-right-radius: 2px;
  356. border-top-right-radius: 2px;
  357. cursor: default;
  358. padding: 2px 5px;
  359. overflow: hidden;
  360. text-overflow: ellipsis;
  361. white-space: nowrap;
  362. }
  363. .Select--multi a.Select-value-label {
  364. color: #007eff;
  365. cursor: pointer;
  366. text-decoration: none;
  367. }
  368. .Select--multi a.Select-value-label:hover {
  369. text-decoration: underline;
  370. }
  371. .Select--multi .Select-value-icon {
  372. cursor: pointer;
  373. border-bottom-left-radius: 2px;
  374. border-top-left-radius: 2px;
  375. border-right: 1px solid rgba(0, 126, 255, 0.24);
  376. padding: 1px 5px;
  377. }
  378. .Select--multi .Select-value-icon:hover,
  379. .Select--multi .Select-value-icon:focus {
  380. background-color: rgba(0, 113, 230, 0.08);
  381. color: #0071e6;
  382. }
  383. .Select--multi .Select-value-icon:active {
  384. background-color: rgba(0, 126, 255, 0.24);
  385. }
  386. .Select--multi.is-disabled .Select-value {
  387. background-color: #fcfcfc;
  388. border: 1px solid #e3e3e3;
  389. color: var(--baseFontColor);
  390. }
  391. .Select--multi.is-disabled .Select-value-icon {
  392. cursor: not-allowed;
  393. border-right: 1px solid #e3e3e3;
  394. }
  395. .Select--multi.is-disabled .Select-value-icon:hover,
  396. .Select--multi.is-disabled .Select-value-icon:focus,
  397. .Select--multi.is-disabled .Select-value-icon:active {
  398. background-color: #fcfcfc;
  399. }
  400. .Select-aria-only {
  401. display: none;
  402. }
  403. @keyframes Select-animation-spin {
  404. to {
  405. transform: rotate(1turn);
  406. }
  407. }
  408. @-webkit-keyframes Select-animation-spin {
  409. to {
  410. -webkit-transform: rotate(1turn);
  411. }
  412. }