_ItemList.scss 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. @mixin itemList() {
  2. $border: 1px solid $border-color;
  3. .esri-item-list {
  4. width: 100%;
  5. }
  6. .esri-item-list__filter-container {
  7. background: transparent;
  8. position: relative;
  9. display: flex;
  10. padding: $cap-spacing--half $side-spacing--half;
  11. margin: 0 0 $cap-spacing--half;
  12. overflow: hidden;
  13. flex-grow: 1;
  14. }
  15. .esri-item-list__filter-container--sticky {
  16. position: sticky;
  17. top: 0;
  18. }
  19. .esri-item-list__filter-input {
  20. width: 100%;
  21. border: none;
  22. border-bottom: 2px solid $border-color;
  23. background-color: transparent;
  24. padding: $cap-spacing--half 0;
  25. transition: border 250ms ease-in-out;
  26. &:focus {
  27. outline: none;
  28. border-color: $border-color--active;
  29. }
  30. }
  31. .esri-item-list__filter-placeholder {
  32. position: absolute;
  33. display: flex;
  34. justify-content: flex-start;
  35. align-items: center;
  36. top: 0;
  37. left: 0;
  38. bottom: 0;
  39. right: 0;
  40. color: $interactive-font-color;
  41. margin: $cap-spacing--half $side-spacing--half;
  42. padding: 0 $side-spacing--half;
  43. pointer-events: none;
  44. }
  45. .esri-item-list__filter-placeholder-text {
  46. margin: 0 $side-spacing--quarter;
  47. }
  48. .esri-item-list__group {
  49. margin-top: 20px;
  50. }
  51. .esri-item-list__scroller {
  52. overflow-y: auto;
  53. }
  54. .esri-item-list__group__header {
  55. color: var(--calcite-ui-text-2);
  56. font-weight: var(--calcite-font-weight-medium);
  57. }
  58. .esri-item-list__list {
  59. list-style: none;
  60. margin: 0;
  61. padding: 0;
  62. }
  63. .esri-item-list__list-item-container {
  64. display: flex;
  65. margin: 0 $cap-spacing--eighth;
  66. width: 100%;
  67. .esri-item-list__list-item-label {
  68. margin: 0 $side-spacing--half;
  69. }
  70. }
  71. .esri-item-list__list-item {
  72. box-shadow: 0 1px 0 var(--calcite-ui-border-2);
  73. padding: 0 12px;
  74. background-color: var(--calcite-ui-foreground-1);
  75. cursor: pointer;
  76. border: 1px solid transparent;
  77. border-radius: 3px;
  78. margin-bottom: $cap-spacing--half;
  79. min-height: $list-item-height;
  80. transition: border 250ms ease-in-out;
  81. display: flex;
  82. justify-content: space-between;
  83. &:hover,
  84. &:focus {
  85. background-color: var(--calcite-ui-foreground-2);
  86. border-color: var(--calcite-ui-brand);
  87. }
  88. @include icomoonIconSelector("&") {
  89. padding-right: $font-size * 0.2;
  90. }
  91. &#{&}--selected {
  92. border-color: $border-color--active;
  93. }
  94. }
  95. .esri-item-list__list-item-label {
  96. flex: 1;
  97. margin: 0;
  98. display: flex;
  99. align-items: center;
  100. word-break: break-word;
  101. }
  102. .esri-item-list__no-matches-message {
  103. display: flex;
  104. justify-content: center;
  105. align-items: center;
  106. height: $panel-min-height--small;
  107. }
  108. .esri-item-list__no-items-message {
  109. display: flex;
  110. justify-content: center;
  111. align-items: center;
  112. min-height: $list-item-height;
  113. }
  114. .esri-ui .esri-item-list__scroller {
  115. max-height: $panel-max-height--small;
  116. }
  117. }
  118. @if $include_ItemList == true {
  119. @include itemList();
  120. }