all repos — NoPaste @ 4d5201f1a9fd36bf5ab4e04de97fc70c12081b9a

Resurrected - The PussTheCat.org fork of NoPaste

style/microtip.css (view raw)

  1/* -------------------------------------------------------------------
  2  Microtip
  3
  4  Modern, lightweight css-only tooltips
  5  Just 1kb minified and gzipped
  6
  7  @author Ghosh
  8  @package Microtip
  9
 10----------------------------------------------------------------------
 11  1. Base Styles
 12  2. Direction Modifiers
 13  3. Position Modifiers
 14--------------------------------------------------------------------*/
 15
 16
 17/* ------------------------------------------------
 18  [1] Base Styles
 19-------------------------------------------------*/
 20
 21[aria-label][role~="tooltip"] {
 22  position: relative;
 23}
 24
 25[aria-label][role~="tooltip"]::before,
 26[aria-label][role~="tooltip"]::after {
 27  transform: translate3d(0, 0, 0);
 28  -webkit-backface-visibility: hidden;
 29  backface-visibility: hidden;
 30  will-change: transform;
 31  opacity: 0;
 32  pointer-events: none;
 33  transition: all var(--microtip-transition-duration, .18s) var(--microtip-transition-easing, ease-in-out) var(--microtip-transition-delay, 0s);
 34  position: absolute;
 35  box-sizing: border-box;
 36  z-index: 10;
 37  transform-origin: top;
 38}
 39
 40[aria-label][role~="tooltip"]::before {
 41  background-size: 100% auto !important;
 42  content: "";
 43}
 44
 45[aria-label][role~="tooltip"]::after {
 46  background: rgba(17, 17, 17, .9);
 47  border-radius: 4px;
 48  color: #ffffff;
 49  content: attr(aria-label);
 50  font-size: var(--microtip-font-size, 13px);
 51  font-weight: var(--microtip-font-weight, normal);
 52  text-transform: var(--microtip-text-transform, none);
 53  padding: .5em 1em;
 54  white-space: nowrap;
 55  box-sizing: content-box;
 56}
 57
 58[aria-label][role~="tooltip"]:hover::before,
 59[aria-label][role~="tooltip"]:hover::after,
 60[aria-label][role~="tooltip"]:focus::before,
 61[aria-label][role~="tooltip"]:focus::after {
 62  opacity: 1;
 63  pointer-events: auto;
 64}
 65
 66
 67
 68/* ------------------------------------------------
 69  [2] Position Modifiers
 70-------------------------------------------------*/
 71
 72[role~="tooltip"][data-microtip-position|="top"]::before {
 73  background: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2236px%22%20height%3D%2212px%22%3E%3Cpath%20fill%3D%22rgba%2817,%2017,%2017,%200.9%29%22%20transform%3D%22rotate%280%29%22%20d%3D%22M2.658,0.000%20C-13.615,0.000%2050.938,0.000%2034.662,0.000%20C28.662,0.000%2023.035,12.002%2018.660,12.002%20C14.285,12.002%208.594,0.000%202.658,0.000%20Z%22/%3E%3C/svg%3E") no-repeat;
 74  height: 6px;
 75  width: 18px;
 76  margin-bottom: 5px;
 77}
 78
 79[role~="tooltip"][data-microtip-position|="top"]::after {
 80  margin-bottom: 11px;
 81}
 82
 83[role~="tooltip"][data-microtip-position|="top"]::before {
 84  transform: translate3d(-50%, 0, 0);
 85  bottom: 100%;
 86  left: 50%;
 87}
 88
 89[role~="tooltip"][data-microtip-position|="top"]:hover::before {
 90  transform: translate3d(-50%, -5px, 0);
 91}
 92
 93[role~="tooltip"][data-microtip-position|="top"]::after {
 94  transform: translate3d(-50%, 0, 0);
 95  bottom: 100%;
 96  left: 50%;
 97}
 98
 99[role~="tooltip"][data-microtip-position="top"]:hover::after {
100  transform: translate3d(-50%, -5px, 0);
101}
102
103/* ------------------------------------------------
104  [2.1] Top Left
105-------------------------------------------------*/
106[role~="tooltip"][data-microtip-position="top-left"]::after {
107  transform: translate3d(calc(-100% + 16px), 0, 0);
108  bottom: 100%;
109}
110
111[role~="tooltip"][data-microtip-position="top-left"]:hover::after {
112  transform: translate3d(calc(-100% + 16px), -5px, 0);
113}
114
115
116/* ------------------------------------------------
117  [2.2] Top Right
118-------------------------------------------------*/
119[role~="tooltip"][data-microtip-position="top-right"]::after {
120  transform: translate3d(calc(0% + -16px), 0, 0);
121  bottom: 100%;
122}
123
124[role~="tooltip"][data-microtip-position="top-right"]:hover::after {
125  transform: translate3d(calc(0% + -16px), -5px, 0);
126}
127
128
129/* ------------------------------------------------
130  [2.3] Bottom
131-------------------------------------------------*/
132[role~="tooltip"][data-microtip-position|="bottom"]::before {
133  background: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2236px%22%20height%3D%2212px%22%3E%3Cpath%20fill%3D%22rgba%2817,%2017,%2017,%200.9%29%22%20transform%3D%22rotate%28180%2018%206%29%22%20d%3D%22M2.658,0.000%20C-13.615,0.000%2050.938,0.000%2034.662,0.000%20C28.662,0.000%2023.035,12.002%2018.660,12.002%20C14.285,12.002%208.594,0.000%202.658,0.000%20Z%22/%3E%3C/svg%3E") no-repeat;
134  height: 6px;
135  width: 18px;
136  margin-top: 5px;
137  margin-bottom: 0;
138}
139
140[role~="tooltip"][data-microtip-position|="bottom"]::after {
141  margin-top: 11px;
142}
143
144[role~="tooltip"][data-microtip-position|="bottom"]::before {
145  transform: translate3d(-50%, -10px, 0);
146  bottom: auto;
147  left: 50%;
148  top: 100%;
149}
150
151[role~="tooltip"][data-microtip-position|="bottom"]:hover::before {
152  transform: translate3d(-50%, 0, 0);
153}
154
155[role~="tooltip"][data-microtip-position|="bottom"]::after {
156  transform: translate3d(-50%, -10px, 0);
157  top: 100%;
158  left: 50%;
159}
160
161[role~="tooltip"][data-microtip-position="bottom"]:hover::after {
162  transform: translate3d(-50%, 0, 0);
163}
164
165
166/* ------------------------------------------------
167  [2.4] Bottom Left
168-------------------------------------------------*/
169[role~="tooltip"][data-microtip-position="bottom-left"]::after {
170  transform: translate3d(calc(-100% + 16px), -10px, 0);
171  top: 100%;
172}
173
174[role~="tooltip"][data-microtip-position="bottom-left"]:hover::after {
175  transform: translate3d(calc(-100% + 16px), 0, 0);
176}
177
178
179/* ------------------------------------------------
180  [2.5] Bottom Right
181-------------------------------------------------*/
182[role~="tooltip"][data-microtip-position="bottom-right"]::after {
183  transform: translate3d(calc(0% + -16px), -10px, 0);
184  top: 100%;
185}
186
187[role~="tooltip"][data-microtip-position="bottom-right"]:hover::after {
188  transform: translate3d(calc(0% + -16px), 0, 0);
189}
190
191
192/* ------------------------------------------------
193  [2.6] Left
194-------------------------------------------------*/
195[role~="tooltip"][data-microtip-position="left"]::before,
196[role~="tooltip"][data-microtip-position="left"]::after {
197  bottom: auto;
198  left: auto;
199  right: 100%;
200  top: 50%;
201  transform: translate3d(10px, -50%, 0);
202}
203
204[role~="tooltip"][data-microtip-position="left"]::before {
205  background: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2212px%22%20height%3D%2236px%22%3E%3Cpath%20fill%3D%22rgba%2817,%2017,%2017,%200.9%29%22%20transform%3D%22rotate%28-90%2018%2018%29%22%20d%3D%22M2.658,0.000%20C-13.615,0.000%2050.938,0.000%2034.662,0.000%20C28.662,0.000%2023.035,12.002%2018.660,12.002%20C14.285,12.002%208.594,0.000%202.658,0.000%20Z%22/%3E%3C/svg%3E") no-repeat;
206  height: 18px;
207  width: 6px;
208  margin-right: 5px;
209  margin-bottom: 0;
210}
211
212[role~="tooltip"][data-microtip-position="left"]::after {
213  margin-right: 11px;
214}
215
216[role~="tooltip"][data-microtip-position="left"]:hover::before,
217[role~="tooltip"][data-microtip-position="left"]:hover::after {
218  transform: translate3d(0, -50%, 0);
219}
220
221
222/* ------------------------------------------------
223  [2.7] Right
224-------------------------------------------------*/
225[role~="tooltip"][data-microtip-position="right"]::before,
226[role~="tooltip"][data-microtip-position="right"]::after {
227  bottom: auto;
228  left: 100%;
229  top: 50%;
230  transform: translate3d(-10px, -50%, 0);
231}
232
233[role~="tooltip"][data-microtip-position="right"]::before {
234  background: url("data:image/svg+xml;charset=utf-8,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%2212px%22%20height%3D%2236px%22%3E%3Cpath%20fill%3D%22rgba%2817,%2017,%2017,%200.9%29%22%20transform%3D%22rotate%2890%206%206%29%22%20d%3D%22M2.658,0.000%20C-13.615,0.000%2050.938,0.000%2034.662,0.000%20C28.662,0.000%2023.035,12.002%2018.660,12.002%20C14.285,12.002%208.594,0.000%202.658,0.000%20Z%22/%3E%3C/svg%3E") no-repeat;
235  height: 18px;
236  width: 6px;
237  margin-bottom: 0;
238  margin-left: 5px;
239}
240
241[role~="tooltip"][data-microtip-position="right"]::after {
242  margin-left: 11px;
243}
244
245[role~="tooltip"][data-microtip-position="right"]:hover::before,
246[role~="tooltip"][data-microtip-position="right"]:hover::after {
247  transform: translate3d(0, -50%, 0);
248}
249
250/* ------------------------------------------------
251  [3] Size
252-------------------------------------------------*/
253[role~="tooltip"][data-microtip-size="small"]::after {
254  white-space: initial;
255  width: 80px;
256}
257
258[role~="tooltip"][data-microtip-size="medium"]::after {
259  white-space: initial;
260  width: 150px;
261}
262
263[role~="tooltip"][data-microtip-size="large"]::after {
264  white-space: initial;
265  width: 260px;
266}