@vincentgraul/react-components 1.0.18 → 1.0.20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (237) hide show
  1. package/README.md +2 -0
  2. package/build/language-selector/LanguageSelector.d.ts +12 -0
  3. package/build/language-selector/LanguageSelector.d.ts.map +1 -0
  4. package/build/language-selector/LanguageSelector.js +42 -0
  5. package/build/language-selector/flags/ad.svg +33 -0
  6. package/build/language-selector/flags/ae.svg +8 -0
  7. package/build/language-selector/flags/af.svg +17 -0
  8. package/build/language-selector/flags/ag.svg +12 -0
  9. package/build/language-selector/flags/ai.svg +18 -0
  10. package/build/language-selector/flags/al.svg +6 -0
  11. package/build/language-selector/flags/am.svg +7 -0
  12. package/build/language-selector/flags/ao.svg +10 -0
  13. package/build/language-selector/flags/ar.svg +8 -0
  14. package/build/language-selector/flags/as.svg +20 -0
  15. package/build/language-selector/flags/at.svg +6 -0
  16. package/build/language-selector/flags/au.svg +11 -0
  17. package/build/language-selector/flags/aw.svg +8 -0
  18. package/build/language-selector/flags/az.svg +11 -0
  19. package/build/language-selector/flags/ba.svg +7 -0
  20. package/build/language-selector/flags/bb.svg +8 -0
  21. package/build/language-selector/flags/bd.svg +6 -0
  22. package/build/language-selector/flags/be.svg +7 -0
  23. package/build/language-selector/flags/bf.svg +7 -0
  24. package/build/language-selector/flags/bg.svg +7 -0
  25. package/build/language-selector/flags/bh.svg +6 -0
  26. package/build/language-selector/flags/bi.svg +13 -0
  27. package/build/language-selector/flags/bj.svg +7 -0
  28. package/build/language-selector/flags/bm.svg +38 -0
  29. package/build/language-selector/flags/bo.svg +59 -0
  30. package/build/language-selector/flags/br.svg +8 -0
  31. package/build/language-selector/flags/bs.svg +7 -0
  32. package/build/language-selector/flags/bt.svg +29 -0
  33. package/build/language-selector/flags/bw.svg +7 -0
  34. package/build/language-selector/flags/by.svg +8 -0
  35. package/build/language-selector/flags/bz.svg +86 -0
  36. package/build/language-selector/flags/ca.svg +9 -0
  37. package/build/language-selector/flags/cd.svg +8 -0
  38. package/build/language-selector/flags/cf.svg +10 -0
  39. package/build/language-selector/flags/cg.svg +7 -0
  40. package/build/language-selector/flags/ch.svg +6 -0
  41. package/build/language-selector/flags/ci.svg +7 -0
  42. package/build/language-selector/flags/ck.svg +12 -0
  43. package/build/language-selector/flags/cl.svg +8 -0
  44. package/build/language-selector/flags/cm.svg +7 -0
  45. package/build/language-selector/flags/cn.svg +6 -0
  46. package/build/language-selector/flags/co.svg +7 -0
  47. package/build/language-selector/flags/cr.svg +35 -0
  48. package/build/language-selector/flags/cu.svg +10 -0
  49. package/build/language-selector/flags/cv.svg +8 -0
  50. package/build/language-selector/flags/cw.svg +7 -0
  51. package/build/language-selector/flags/cy.svg +11 -0
  52. package/build/language-selector/flags/cz.svg +7 -0
  53. package/build/language-selector/flags/de.svg +7 -0
  54. package/build/language-selector/flags/dj.svg +8 -0
  55. package/build/language-selector/flags/dk.svg +6 -0
  56. package/build/language-selector/flags/dm.svg +25 -0
  57. package/build/language-selector/flags/do.svg +59 -0
  58. package/build/language-selector/flags/dz.svg +10 -0
  59. package/build/language-selector/flags/ec.svg +46 -0
  60. package/build/language-selector/flags/ee.svg +7 -0
  61. package/build/language-selector/flags/eg.svg +8 -0
  62. package/build/language-selector/flags/er.svg +8 -0
  63. package/build/language-selector/flags/es.svg +42 -0
  64. package/build/language-selector/flags/et.svg +12 -0
  65. package/build/language-selector/flags/fi.svg +6 -0
  66. package/build/language-selector/flags/fj.svg +44 -0
  67. package/build/language-selector/flags/fk.svg +43 -0
  68. package/build/language-selector/flags/fm.svg +6 -0
  69. package/build/language-selector/flags/fo.svg +7 -0
  70. package/build/language-selector/flags/fr.svg +7 -0
  71. package/build/language-selector/flags/ga.svg +7 -0
  72. package/build/language-selector/flags/gb.svg +10 -0
  73. package/build/language-selector/flags/gd.svg +10 -0
  74. package/build/language-selector/flags/ge.svg +9 -0
  75. package/build/language-selector/flags/gg.svg +10 -0
  76. package/build/language-selector/flags/gh.svg +8 -0
  77. package/build/language-selector/flags/gi.svg +8 -0
  78. package/build/language-selector/flags/gl.svg +7 -0
  79. package/build/language-selector/flags/gm.svg +8 -0
  80. package/build/language-selector/flags/gn.svg +7 -0
  81. package/build/language-selector/flags/gq.svg +13 -0
  82. package/build/language-selector/flags/gr.svg +9 -0
  83. package/build/language-selector/flags/gt.svg +40 -0
  84. package/build/language-selector/flags/gu.svg +16 -0
  85. package/build/language-selector/flags/gw.svg +8 -0
  86. package/build/language-selector/flags/hk.svg +10 -0
  87. package/build/language-selector/flags/hn.svg +7 -0
  88. package/build/language-selector/flags/hr.svg +25 -0
  89. package/build/language-selector/flags/ht.svg +6 -0
  90. package/build/language-selector/flags/hu.svg +7 -0
  91. package/build/language-selector/flags/id.svg +6 -0
  92. package/build/language-selector/flags/ie.svg +7 -0
  93. package/build/language-selector/flags/il.svg +7 -0
  94. package/build/language-selector/flags/im.svg +38 -0
  95. package/build/language-selector/flags/in.svg +23 -0
  96. package/build/language-selector/flags/io.svg +17 -0
  97. package/build/language-selector/flags/iq.svg +11 -0
  98. package/build/language-selector/flags/ir.svg +14 -0
  99. package/build/language-selector/flags/is.svg +7 -0
  100. package/build/language-selector/flags/it.svg +7 -0
  101. package/build/language-selector/flags/je.svg +36 -0
  102. package/build/language-selector/flags/jm.svg +7 -0
  103. package/build/language-selector/flags/jo.svg +9 -0
  104. package/build/language-selector/flags/jp.svg +6 -0
  105. package/build/language-selector/flags/ke.svg +18 -0
  106. package/build/language-selector/flags/kg.svg +9 -0
  107. package/build/language-selector/flags/kh.svg +7 -0
  108. package/build/language-selector/flags/ki.svg +12 -0
  109. package/build/language-selector/flags/km.svg +13 -0
  110. package/build/language-selector/flags/kn.svg +9 -0
  111. package/build/language-selector/flags/kp.svg +9 -0
  112. package/build/language-selector/flags/kr.svg +8 -0
  113. package/build/language-selector/flags/kw.svg +8 -0
  114. package/build/language-selector/flags/ky.svg +60 -0
  115. package/build/language-selector/flags/kz.svg +11 -0
  116. package/build/language-selector/flags/la.svg +7 -0
  117. package/build/language-selector/flags/lb.svg +7 -0
  118. package/build/language-selector/flags/li.svg +11 -0
  119. package/build/language-selector/flags/lk.svg +23 -0
  120. package/build/language-selector/flags/lr.svg +17 -0
  121. package/build/language-selector/flags/ls.svg +8 -0
  122. package/build/language-selector/flags/lt.svg +7 -0
  123. package/build/language-selector/flags/lu.svg +7 -0
  124. package/build/language-selector/flags/lv.svg +6 -0
  125. package/build/language-selector/flags/ly.svg +11 -0
  126. package/build/language-selector/flags/ma.svg +6 -0
  127. package/build/language-selector/flags/mc.svg +6 -0
  128. package/build/language-selector/flags/md.svg +47 -0
  129. package/build/language-selector/flags/me.svg +16 -0
  130. package/build/language-selector/flags/mg.svg +7 -0
  131. package/build/language-selector/flags/mh.svg +8 -0
  132. package/build/language-selector/flags/mk.svg +9 -0
  133. package/build/language-selector/flags/ml.svg +7 -0
  134. package/build/language-selector/flags/mm.svg +8 -0
  135. package/build/language-selector/flags/mn.svg +13 -0
  136. package/build/language-selector/flags/mo.svg +10 -0
  137. package/build/language-selector/flags/mp.svg +30 -0
  138. package/build/language-selector/flags/mq.svg +9 -0
  139. package/build/language-selector/flags/mr.svg +9 -0
  140. package/build/language-selector/flags/ms.svg +21 -0
  141. package/build/language-selector/flags/mt.svg +16 -0
  142. package/build/language-selector/flags/mu.svg +8 -0
  143. package/build/language-selector/flags/mv.svg +7 -0
  144. package/build/language-selector/flags/mw.svg +7 -0
  145. package/build/language-selector/flags/mx.svg +30 -0
  146. package/build/language-selector/flags/my.svg +23 -0
  147. package/build/language-selector/flags/mz.svg +19 -0
  148. package/build/language-selector/flags/na.svg +12 -0
  149. package/build/language-selector/flags/nato.svg +6 -0
  150. package/build/language-selector/flags/ne.svg +8 -0
  151. package/build/language-selector/flags/nf.svg +7 -0
  152. package/build/language-selector/flags/ng.svg +7 -0
  153. package/build/language-selector/flags/ni.svg +26 -0
  154. package/build/language-selector/flags/nl.svg +7 -0
  155. package/build/language-selector/flags/no.svg +7 -0
  156. package/build/language-selector/flags/np.svg +8 -0
  157. package/build/language-selector/flags/nr.svg +7 -0
  158. package/build/language-selector/flags/nu.svg +13 -0
  159. package/build/language-selector/flags/nz.svg +17 -0
  160. package/build/language-selector/flags/om.svg +12 -0
  161. package/build/language-selector/flags/pa.svg +8 -0
  162. package/build/language-selector/flags/pe.svg +7 -0
  163. package/build/language-selector/flags/pf.svg +10 -0
  164. package/build/language-selector/flags/pg.svg +8 -0
  165. package/build/language-selector/flags/ph.svg +11 -0
  166. package/build/language-selector/flags/pk.svg +6 -0
  167. package/build/language-selector/flags/pl.svg +6 -0
  168. package/build/language-selector/flags/pn.svg +52 -0
  169. package/build/language-selector/flags/pr.svg +10 -0
  170. package/build/language-selector/flags/ps.svg +8 -0
  171. package/build/language-selector/flags/pt.svg +19 -0
  172. package/build/language-selector/flags/pw.svg +6 -0
  173. package/build/language-selector/flags/py.svg +11 -0
  174. package/build/language-selector/flags/qa.svg +6 -0
  175. package/build/language-selector/flags/ro.svg +7 -0
  176. package/build/language-selector/flags/rs.svg +45 -0
  177. package/build/language-selector/flags/ru.svg +7 -0
  178. package/build/language-selector/flags/rw.svg +11 -0
  179. package/build/language-selector/flags/sa.svg +15 -0
  180. package/build/language-selector/flags/sb.svg +8 -0
  181. package/build/language-selector/flags/sc.svg +9 -0
  182. package/build/language-selector/flags/sd.svg +8 -0
  183. package/build/language-selector/flags/se.svg +6 -0
  184. package/build/language-selector/flags/sg.svg +9 -0
  185. package/build/language-selector/flags/si.svg +13 -0
  186. package/build/language-selector/flags/sk.svg +11 -0
  187. package/build/language-selector/flags/sl.svg +7 -0
  188. package/build/language-selector/flags/sm.svg +67 -0
  189. package/build/language-selector/flags/sn.svg +8 -0
  190. package/build/language-selector/flags/so.svg +6 -0
  191. package/build/language-selector/flags/sq.svg +18 -0
  192. package/build/language-selector/flags/sr.svg +8 -0
  193. package/build/language-selector/flags/ss.svg +10 -0
  194. package/build/language-selector/flags/st.svg +8 -0
  195. package/build/language-selector/flags/sv.svg +55 -0
  196. package/build/language-selector/flags/sx.svg +30 -0
  197. package/build/language-selector/flags/sy.svg +8 -0
  198. package/build/language-selector/flags/sz.svg +19 -0
  199. package/build/language-selector/flags/tc.svg +18 -0
  200. package/build/language-selector/flags/td.svg +7 -0
  201. package/build/language-selector/flags/tg.svg +10 -0
  202. package/build/language-selector/flags/th.svg +9 -0
  203. package/build/language-selector/flags/tibet.svg +135 -0
  204. package/build/language-selector/flags/tj.svg +11 -0
  205. package/build/language-selector/flags/tk.svg +7 -0
  206. package/build/language-selector/flags/tm.svg +30 -0
  207. package/build/language-selector/flags/tn.svg +10 -0
  208. package/build/language-selector/flags/to.svg +7 -0
  209. package/build/language-selector/flags/tr.svg +6 -0
  210. package/build/language-selector/flags/tt.svg +7 -0
  211. package/build/language-selector/flags/tv.svg +12 -0
  212. package/build/language-selector/flags/tw.svg +10 -0
  213. package/build/language-selector/flags/tz.svg +8 -0
  214. package/build/language-selector/flags/ua.svg +6 -0
  215. package/build/language-selector/flags/ug.svg +19 -0
  216. package/build/language-selector/flags/us.svg +8 -0
  217. package/build/language-selector/flags/uy.svg +45 -0
  218. package/build/language-selector/flags/uz.svg +10 -0
  219. package/build/language-selector/flags/ve.svg +8 -0
  220. package/build/language-selector/flags/vi.svg +13 -0
  221. package/build/language-selector/flags/vn.svg +6 -0
  222. package/build/language-selector/flags/vu.svg +12 -0
  223. package/build/language-selector/flags/ws.svg +7 -0
  224. package/build/language-selector/flags/ye.svg +7 -0
  225. package/build/language-selector/flags/za.svg +11 -0
  226. package/build/language-selector/flags/zm.svg +9 -0
  227. package/build/language-selector/flags/zw.svg +18 -0
  228. package/build/outside-alerter/useOutsideAlerter.d.ts +6 -1
  229. package/build/outside-alerter/useOutsideAlerter.d.ts.map +1 -1
  230. package/build/outside-alerter/useOutsideAlerter.js +4 -1
  231. package/build/select/Select.d.ts +287 -0
  232. package/build/select/Select.d.ts.map +1 -0
  233. package/build/select/Select.js +92 -0
  234. package/build/select/icons/arrow-bottom.svg +14 -0
  235. package/build/table/Table.d.ts +831 -3
  236. package/build/table/Table.d.ts.map +1 -1
  237. package/package.json +18 -13
@@ -0,0 +1,287 @@
1
+ import React, { ReactNode } from "react";
2
+ interface Option {
3
+ id: number;
4
+ label: string | ReactNode;
5
+ value: string;
6
+ }
7
+ export type OptionWithoutId = Omit<Option, "id">;
8
+ interface Props {
9
+ options: OptionWithoutId[];
10
+ onChange?: (option: Option) => void;
11
+ }
12
+ export default function Select(props: Props): import("react/jsx-runtime").JSX.Element;
13
+ declare const Option: import("styled-components").IStyledComponent<"web", {
14
+ ref?: React.LegacyRef<HTMLLIElement>;
15
+ key?: React.Key;
16
+ value?: string | number | readonly string[];
17
+ defaultChecked?: boolean;
18
+ defaultValue?: string | number | readonly string[];
19
+ suppressContentEditableWarning?: boolean;
20
+ suppressHydrationWarning?: boolean;
21
+ accessKey?: string;
22
+ autoFocus?: boolean;
23
+ className?: string;
24
+ contentEditable?: "inherit" | (boolean | "true" | "false");
25
+ contextMenu?: string;
26
+ dir?: string;
27
+ draggable?: boolean | "true" | "false";
28
+ hidden?: boolean;
29
+ id?: string;
30
+ lang?: string;
31
+ nonce?: string;
32
+ placeholder?: string;
33
+ slot?: string;
34
+ spellCheck?: boolean | "true" | "false";
35
+ style?: React.CSSProperties;
36
+ tabIndex?: number;
37
+ title?: string;
38
+ translate?: "yes" | "no";
39
+ radioGroup?: string;
40
+ role?: React.AriaRole;
41
+ about?: string;
42
+ content?: string;
43
+ datatype?: string;
44
+ inlist?: any;
45
+ prefix?: string;
46
+ property?: string;
47
+ rel?: string;
48
+ resource?: string;
49
+ rev?: string;
50
+ typeof?: string;
51
+ vocab?: string;
52
+ autoCapitalize?: string;
53
+ autoCorrect?: string;
54
+ autoSave?: string;
55
+ color?: string;
56
+ itemProp?: string;
57
+ itemScope?: boolean;
58
+ itemType?: string;
59
+ itemID?: string;
60
+ itemRef?: string;
61
+ results?: number;
62
+ security?: string;
63
+ unselectable?: "on" | "off";
64
+ inputMode?: "search" | "text" | "none" | "tel" | "url" | "email" | "numeric" | "decimal";
65
+ is?: string;
66
+ 'aria-activedescendant'?: string;
67
+ 'aria-atomic'?: boolean | "true" | "false";
68
+ 'aria-autocomplete'?: "none" | "list" | "inline" | "both";
69
+ 'aria-braillelabel'?: string;
70
+ 'aria-brailleroledescription'?: string;
71
+ 'aria-busy'?: boolean | "true" | "false";
72
+ 'aria-checked'?: boolean | "true" | "false" | "mixed";
73
+ 'aria-colcount'?: number;
74
+ 'aria-colindex'?: number;
75
+ 'aria-colindextext'?: string;
76
+ 'aria-colspan'?: number;
77
+ 'aria-controls'?: string;
78
+ 'aria-current'?: boolean | "time" | "page" | "step" | "true" | "false" | "location" | "date";
79
+ 'aria-describedby'?: string;
80
+ 'aria-description'?: string;
81
+ 'aria-details'?: string;
82
+ 'aria-disabled'?: boolean | "true" | "false";
83
+ 'aria-dropeffect'?: "copy" | "link" | "none" | "execute" | "move" | "popup";
84
+ 'aria-errormessage'?: string;
85
+ 'aria-expanded'?: boolean | "true" | "false";
86
+ 'aria-flowto'?: string;
87
+ 'aria-grabbed'?: boolean | "true" | "false";
88
+ 'aria-haspopup'?: boolean | "dialog" | "menu" | "true" | "false" | "grid" | "listbox" | "tree";
89
+ 'aria-hidden'?: boolean | "true" | "false";
90
+ 'aria-invalid'?: boolean | "true" | "false" | "grammar" | "spelling";
91
+ 'aria-keyshortcuts'?: string;
92
+ 'aria-label'?: string;
93
+ 'aria-labelledby'?: string;
94
+ 'aria-level'?: number;
95
+ 'aria-live'?: "off" | "assertive" | "polite";
96
+ 'aria-modal'?: boolean | "true" | "false";
97
+ 'aria-multiline'?: boolean | "true" | "false";
98
+ 'aria-multiselectable'?: boolean | "true" | "false";
99
+ 'aria-orientation'?: "horizontal" | "vertical";
100
+ 'aria-owns'?: string;
101
+ 'aria-placeholder'?: string;
102
+ 'aria-posinset'?: number;
103
+ 'aria-pressed'?: boolean | "true" | "false" | "mixed";
104
+ 'aria-readonly'?: boolean | "true" | "false";
105
+ 'aria-relevant'?: "text" | "additions" | "additions removals" | "additions text" | "all" | "removals" | "removals additions" | "removals text" | "text additions" | "text removals";
106
+ 'aria-required'?: boolean | "true" | "false";
107
+ 'aria-roledescription'?: string;
108
+ 'aria-rowcount'?: number;
109
+ 'aria-rowindex'?: number;
110
+ 'aria-rowindextext'?: string;
111
+ 'aria-rowspan'?: number;
112
+ 'aria-selected'?: boolean | "true" | "false";
113
+ 'aria-setsize'?: number;
114
+ 'aria-sort'?: "none" | "ascending" | "descending" | "other";
115
+ 'aria-valuemax'?: number;
116
+ 'aria-valuemin'?: number;
117
+ 'aria-valuenow'?: number;
118
+ 'aria-valuetext'?: string;
119
+ children?: React.ReactNode;
120
+ dangerouslySetInnerHTML?: {
121
+ __html: string | TrustedHTML;
122
+ };
123
+ onCopy?: React.ClipboardEventHandler<HTMLLIElement>;
124
+ onCopyCapture?: React.ClipboardEventHandler<HTMLLIElement>;
125
+ onCut?: React.ClipboardEventHandler<HTMLLIElement>;
126
+ onCutCapture?: React.ClipboardEventHandler<HTMLLIElement>;
127
+ onPaste?: React.ClipboardEventHandler<HTMLLIElement>;
128
+ onPasteCapture?: React.ClipboardEventHandler<HTMLLIElement>;
129
+ onCompositionEnd?: React.CompositionEventHandler<HTMLLIElement>;
130
+ onCompositionEndCapture?: React.CompositionEventHandler<HTMLLIElement>;
131
+ onCompositionStart?: React.CompositionEventHandler<HTMLLIElement>;
132
+ onCompositionStartCapture?: React.CompositionEventHandler<HTMLLIElement>;
133
+ onCompositionUpdate?: React.CompositionEventHandler<HTMLLIElement>;
134
+ onCompositionUpdateCapture?: React.CompositionEventHandler<HTMLLIElement>;
135
+ onFocus?: React.FocusEventHandler<HTMLLIElement>;
136
+ onFocusCapture?: React.FocusEventHandler<HTMLLIElement>;
137
+ onBlur?: React.FocusEventHandler<HTMLLIElement>;
138
+ onBlurCapture?: React.FocusEventHandler<HTMLLIElement>;
139
+ onChange?: React.FormEventHandler<HTMLLIElement>;
140
+ onChangeCapture?: React.FormEventHandler<HTMLLIElement>;
141
+ onBeforeInput?: React.FormEventHandler<HTMLLIElement>;
142
+ onBeforeInputCapture?: React.FormEventHandler<HTMLLIElement>;
143
+ onInput?: React.FormEventHandler<HTMLLIElement>;
144
+ onInputCapture?: React.FormEventHandler<HTMLLIElement>;
145
+ onReset?: React.FormEventHandler<HTMLLIElement>;
146
+ onResetCapture?: React.FormEventHandler<HTMLLIElement>;
147
+ onSubmit?: React.FormEventHandler<HTMLLIElement>;
148
+ onSubmitCapture?: React.FormEventHandler<HTMLLIElement>;
149
+ onInvalid?: React.FormEventHandler<HTMLLIElement>;
150
+ onInvalidCapture?: React.FormEventHandler<HTMLLIElement>;
151
+ onLoad?: React.ReactEventHandler<HTMLLIElement>;
152
+ onLoadCapture?: React.ReactEventHandler<HTMLLIElement>;
153
+ onError?: React.ReactEventHandler<HTMLLIElement>;
154
+ onErrorCapture?: React.ReactEventHandler<HTMLLIElement>;
155
+ onKeyDown?: React.KeyboardEventHandler<HTMLLIElement>;
156
+ onKeyDownCapture?: React.KeyboardEventHandler<HTMLLIElement>;
157
+ onKeyPress?: React.KeyboardEventHandler<HTMLLIElement>;
158
+ onKeyPressCapture?: React.KeyboardEventHandler<HTMLLIElement>;
159
+ onKeyUp?: React.KeyboardEventHandler<HTMLLIElement>;
160
+ onKeyUpCapture?: React.KeyboardEventHandler<HTMLLIElement>;
161
+ onAbort?: React.ReactEventHandler<HTMLLIElement>;
162
+ onAbortCapture?: React.ReactEventHandler<HTMLLIElement>;
163
+ onCanPlay?: React.ReactEventHandler<HTMLLIElement>;
164
+ onCanPlayCapture?: React.ReactEventHandler<HTMLLIElement>;
165
+ onCanPlayThrough?: React.ReactEventHandler<HTMLLIElement>;
166
+ onCanPlayThroughCapture?: React.ReactEventHandler<HTMLLIElement>;
167
+ onDurationChange?: React.ReactEventHandler<HTMLLIElement>;
168
+ onDurationChangeCapture?: React.ReactEventHandler<HTMLLIElement>;
169
+ onEmptied?: React.ReactEventHandler<HTMLLIElement>;
170
+ onEmptiedCapture?: React.ReactEventHandler<HTMLLIElement>;
171
+ onEncrypted?: React.ReactEventHandler<HTMLLIElement>;
172
+ onEncryptedCapture?: React.ReactEventHandler<HTMLLIElement>;
173
+ onEnded?: React.ReactEventHandler<HTMLLIElement>;
174
+ onEndedCapture?: React.ReactEventHandler<HTMLLIElement>;
175
+ onLoadedData?: React.ReactEventHandler<HTMLLIElement>;
176
+ onLoadedDataCapture?: React.ReactEventHandler<HTMLLIElement>;
177
+ onLoadedMetadata?: React.ReactEventHandler<HTMLLIElement>;
178
+ onLoadedMetadataCapture?: React.ReactEventHandler<HTMLLIElement>;
179
+ onLoadStart?: React.ReactEventHandler<HTMLLIElement>;
180
+ onLoadStartCapture?: React.ReactEventHandler<HTMLLIElement>;
181
+ onPause?: React.ReactEventHandler<HTMLLIElement>;
182
+ onPauseCapture?: React.ReactEventHandler<HTMLLIElement>;
183
+ onPlay?: React.ReactEventHandler<HTMLLIElement>;
184
+ onPlayCapture?: React.ReactEventHandler<HTMLLIElement>;
185
+ onPlaying?: React.ReactEventHandler<HTMLLIElement>;
186
+ onPlayingCapture?: React.ReactEventHandler<HTMLLIElement>;
187
+ onProgress?: React.ReactEventHandler<HTMLLIElement>;
188
+ onProgressCapture?: React.ReactEventHandler<HTMLLIElement>;
189
+ onRateChange?: React.ReactEventHandler<HTMLLIElement>;
190
+ onRateChangeCapture?: React.ReactEventHandler<HTMLLIElement>;
191
+ onResize?: React.ReactEventHandler<HTMLLIElement>;
192
+ onResizeCapture?: React.ReactEventHandler<HTMLLIElement>;
193
+ onSeeked?: React.ReactEventHandler<HTMLLIElement>;
194
+ onSeekedCapture?: React.ReactEventHandler<HTMLLIElement>;
195
+ onSeeking?: React.ReactEventHandler<HTMLLIElement>;
196
+ onSeekingCapture?: React.ReactEventHandler<HTMLLIElement>;
197
+ onStalled?: React.ReactEventHandler<HTMLLIElement>;
198
+ onStalledCapture?: React.ReactEventHandler<HTMLLIElement>;
199
+ onSuspend?: React.ReactEventHandler<HTMLLIElement>;
200
+ onSuspendCapture?: React.ReactEventHandler<HTMLLIElement>;
201
+ onTimeUpdate?: React.ReactEventHandler<HTMLLIElement>;
202
+ onTimeUpdateCapture?: React.ReactEventHandler<HTMLLIElement>;
203
+ onVolumeChange?: React.ReactEventHandler<HTMLLIElement>;
204
+ onVolumeChangeCapture?: React.ReactEventHandler<HTMLLIElement>;
205
+ onWaiting?: React.ReactEventHandler<HTMLLIElement>;
206
+ onWaitingCapture?: React.ReactEventHandler<HTMLLIElement>;
207
+ onAuxClick?: React.MouseEventHandler<HTMLLIElement>;
208
+ onAuxClickCapture?: React.MouseEventHandler<HTMLLIElement>;
209
+ onClick?: React.MouseEventHandler<HTMLLIElement>;
210
+ onClickCapture?: React.MouseEventHandler<HTMLLIElement>;
211
+ onContextMenu?: React.MouseEventHandler<HTMLLIElement>;
212
+ onContextMenuCapture?: React.MouseEventHandler<HTMLLIElement>;
213
+ onDoubleClick?: React.MouseEventHandler<HTMLLIElement>;
214
+ onDoubleClickCapture?: React.MouseEventHandler<HTMLLIElement>;
215
+ onDrag?: React.DragEventHandler<HTMLLIElement>;
216
+ onDragCapture?: React.DragEventHandler<HTMLLIElement>;
217
+ onDragEnd?: React.DragEventHandler<HTMLLIElement>;
218
+ onDragEndCapture?: React.DragEventHandler<HTMLLIElement>;
219
+ onDragEnter?: React.DragEventHandler<HTMLLIElement>;
220
+ onDragEnterCapture?: React.DragEventHandler<HTMLLIElement>;
221
+ onDragExit?: React.DragEventHandler<HTMLLIElement>;
222
+ onDragExitCapture?: React.DragEventHandler<HTMLLIElement>;
223
+ onDragLeave?: React.DragEventHandler<HTMLLIElement>;
224
+ onDragLeaveCapture?: React.DragEventHandler<HTMLLIElement>;
225
+ onDragOver?: React.DragEventHandler<HTMLLIElement>;
226
+ onDragOverCapture?: React.DragEventHandler<HTMLLIElement>;
227
+ onDragStart?: React.DragEventHandler<HTMLLIElement>;
228
+ onDragStartCapture?: React.DragEventHandler<HTMLLIElement>;
229
+ onDrop?: React.DragEventHandler<HTMLLIElement>;
230
+ onDropCapture?: React.DragEventHandler<HTMLLIElement>;
231
+ onMouseDown?: React.MouseEventHandler<HTMLLIElement>;
232
+ onMouseDownCapture?: React.MouseEventHandler<HTMLLIElement>;
233
+ onMouseEnter?: React.MouseEventHandler<HTMLLIElement>;
234
+ onMouseLeave?: React.MouseEventHandler<HTMLLIElement>;
235
+ onMouseMove?: React.MouseEventHandler<HTMLLIElement>;
236
+ onMouseMoveCapture?: React.MouseEventHandler<HTMLLIElement>;
237
+ onMouseOut?: React.MouseEventHandler<HTMLLIElement>;
238
+ onMouseOutCapture?: React.MouseEventHandler<HTMLLIElement>;
239
+ onMouseOver?: React.MouseEventHandler<HTMLLIElement>;
240
+ onMouseOverCapture?: React.MouseEventHandler<HTMLLIElement>;
241
+ onMouseUp?: React.MouseEventHandler<HTMLLIElement>;
242
+ onMouseUpCapture?: React.MouseEventHandler<HTMLLIElement>;
243
+ onSelect?: React.ReactEventHandler<HTMLLIElement>;
244
+ onSelectCapture?: React.ReactEventHandler<HTMLLIElement>;
245
+ onTouchCancel?: React.TouchEventHandler<HTMLLIElement>;
246
+ onTouchCancelCapture?: React.TouchEventHandler<HTMLLIElement>;
247
+ onTouchEnd?: React.TouchEventHandler<HTMLLIElement>;
248
+ onTouchEndCapture?: React.TouchEventHandler<HTMLLIElement>;
249
+ onTouchMove?: React.TouchEventHandler<HTMLLIElement>;
250
+ onTouchMoveCapture?: React.TouchEventHandler<HTMLLIElement>;
251
+ onTouchStart?: React.TouchEventHandler<HTMLLIElement>;
252
+ onTouchStartCapture?: React.TouchEventHandler<HTMLLIElement>;
253
+ onPointerDown?: React.PointerEventHandler<HTMLLIElement>;
254
+ onPointerDownCapture?: React.PointerEventHandler<HTMLLIElement>;
255
+ onPointerMove?: React.PointerEventHandler<HTMLLIElement>;
256
+ onPointerMoveCapture?: React.PointerEventHandler<HTMLLIElement>;
257
+ onPointerUp?: React.PointerEventHandler<HTMLLIElement>;
258
+ onPointerUpCapture?: React.PointerEventHandler<HTMLLIElement>;
259
+ onPointerCancel?: React.PointerEventHandler<HTMLLIElement>;
260
+ onPointerCancelCapture?: React.PointerEventHandler<HTMLLIElement>;
261
+ onPointerEnter?: React.PointerEventHandler<HTMLLIElement>;
262
+ onPointerEnterCapture?: React.PointerEventHandler<HTMLLIElement>;
263
+ onPointerLeave?: React.PointerEventHandler<HTMLLIElement>;
264
+ onPointerLeaveCapture?: React.PointerEventHandler<HTMLLIElement>;
265
+ onPointerOver?: React.PointerEventHandler<HTMLLIElement>;
266
+ onPointerOverCapture?: React.PointerEventHandler<HTMLLIElement>;
267
+ onPointerOut?: React.PointerEventHandler<HTMLLIElement>;
268
+ onPointerOutCapture?: React.PointerEventHandler<HTMLLIElement>;
269
+ onGotPointerCapture?: React.PointerEventHandler<HTMLLIElement>;
270
+ onGotPointerCaptureCapture?: React.PointerEventHandler<HTMLLIElement>;
271
+ onLostPointerCapture?: React.PointerEventHandler<HTMLLIElement>;
272
+ onLostPointerCaptureCapture?: React.PointerEventHandler<HTMLLIElement>;
273
+ onScroll?: React.UIEventHandler<HTMLLIElement>;
274
+ onScrollCapture?: React.UIEventHandler<HTMLLIElement>;
275
+ onWheel?: React.WheelEventHandler<HTMLLIElement>;
276
+ onWheelCapture?: React.WheelEventHandler<HTMLLIElement>;
277
+ onAnimationStart?: React.AnimationEventHandler<HTMLLIElement>;
278
+ onAnimationStartCapture?: React.AnimationEventHandler<HTMLLIElement>;
279
+ onAnimationEnd?: React.AnimationEventHandler<HTMLLIElement>;
280
+ onAnimationEndCapture?: React.AnimationEventHandler<HTMLLIElement>;
281
+ onAnimationIteration?: React.AnimationEventHandler<HTMLLIElement>;
282
+ onAnimationIterationCapture?: React.AnimationEventHandler<HTMLLIElement>;
283
+ onTransitionEnd?: React.TransitionEventHandler<HTMLLIElement>;
284
+ onTransitionEndCapture?: React.TransitionEventHandler<HTMLLIElement>;
285
+ }>;
286
+ export {};
287
+ //# sourceMappingURL=Select.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Select.d.ts","sourceRoot":"","sources":["../../src/select/Select.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAA+B,MAAM,OAAO,CAAC;AAKtE,UAAU,MAAM;IACd,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,EAAE,MAAM,GAAG,SAAS,CAAC;IAC1B,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,MAAM,eAAe,GAAG,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;AAEjD,UAAU,KAAK;IACb,OAAO,EAAE,eAAe,EAAE,CAAC;IAC3B,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAC;CACrC;AAED,MAAM,CAAC,OAAO,UAAU,MAAM,CAAC,KAAK,EAAE,KAAK,2CAiE1C;AAoCD,QAAA,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAmBX,CAAC"}
@@ -0,0 +1,92 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useEffect, useRef, useState } from "react";
3
+ import styled from "styled-components";
4
+ import Arrow from "./icons/arrow-bottom.svg";
5
+ import useOutsideAlerter from "../outside-alerter/useOutsideAlerter";
6
+ export default function Select(props) {
7
+ const { onChange } = props;
8
+ const [options, setOptions] = useState(null);
9
+ const [isListVisible, setListVisibility] = useState(false);
10
+ const [selectedOption, setSelectedOption] = useState(null);
11
+ const ref = useRef(null);
12
+ const { hasClickedOutside, onReset: onResetOutsideAlerter } = useOutsideAlerter(ref);
13
+ const handleSelectedOptionClick = () => {
14
+ onResetOutsideAlerter();
15
+ setListVisibility(!isListVisible);
16
+ };
17
+ const handleOptionClick = (option) => {
18
+ setSelectedOption(option);
19
+ setListVisibility(false);
20
+ if (onChange) {
21
+ onChange(option);
22
+ }
23
+ };
24
+ useEffect(() => {
25
+ setOptions(props.options.map((option, index) => (Object.assign(Object.assign({}, option), { id: index }))));
26
+ }, [props.options]);
27
+ useEffect(() => {
28
+ if (options) {
29
+ setSelectedOption(options[0]);
30
+ }
31
+ }, [options]);
32
+ useEffect(() => {
33
+ if (hasClickedOutside) {
34
+ setListVisibility(false);
35
+ }
36
+ }, [hasClickedOutside]);
37
+ if (!options || !selectedOption) {
38
+ return null;
39
+ }
40
+ return (_jsxs(Container, { className: "select", ref: ref, children: [_jsxs(SelectedOptionContainer, { onClick: handleSelectedOptionClick, children: [_jsx(SelectedOptionText, { children: selectedOption.label }), _jsx(SelectedOptionArrow, { src: Arrow })] }), isListVisible && (_jsx(OptionsList, { className: "select-options", children: options
41
+ .filter((option) => option.id !== selectedOption.id)
42
+ .map((option) => (_jsx(Option, { onClick: () => handleOptionClick(option), children: option.label }, option.id))) }))] }));
43
+ }
44
+ const Container = styled.div `
45
+ width: fit-content;
46
+ `;
47
+ const SelectedOptionContainer = styled.div `
48
+ display: flex;
49
+ align-items: center;
50
+ cursor: pointer;
51
+ user-select: none;
52
+ padding: 10px;
53
+ background-color: white;
54
+ border-radius: 5px;
55
+ `;
56
+ const SelectedOptionText = styled.span `
57
+ padding-right: 10px;
58
+ border-right: 1px solid black;
59
+ `;
60
+ const SelectedOptionArrow = styled.img `
61
+ width: 15px;
62
+ margin-left: 10px;
63
+ `;
64
+ const OptionsList = styled.ul `
65
+ width: 100%;
66
+ list-style: none;
67
+ padding: 0;
68
+ margin: 10px 0 0 0;
69
+ user-select: none;
70
+ background-color: white;
71
+ border-radius: 5px;
72
+ `;
73
+ const Option = styled.li `
74
+ padding: 10px;
75
+ cursor: pointer;
76
+
77
+ &:hover {
78
+ background-color: #ecf0f1;
79
+
80
+ &:first-child {
81
+ border-radius: 5px 5px 0 0;
82
+ }
83
+
84
+ &:last-child {
85
+ border-radius: 0 0 5px 5px;
86
+ }
87
+
88
+ &:only-child {
89
+ border-radius: 5px;
90
+ }
91
+ }
92
+ `;
@@ -0,0 +1,14 @@
1
+ <?xml version="1.0" encoding="UTF-8"?>
2
+ <svg width="32px" height="18px" viewBox="0 0 32 18" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
3
+ <!-- Generator: Sketch 45 (43475) - http://www.bohemiancoding.com/sketch -->
4
+ <title>arrow-left</title>
5
+ <desc>Created with Sketch.</desc>
6
+ <defs></defs>
7
+ <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
8
+ <g id="arrow-left" transform="translate(16.000000, 9.000000) rotate(-90.000000) translate(-16.000000, -9.000000) translate(7.000000, -7.000000)" fill-rule="nonzero" fill="#171D27">
9
+ <g id="arrow-point-to-right" transform="translate(9.000000, 16.000000) scale(-1, 1) translate(-9.000000, -16.000000) ">
10
+ <path d="M17.3523845,17.2019001 L3.77482194,30.6618545 C2.91112496,31.5185123 1.51078835,31.5185123 0.647510672,30.6618545 C-0.215836891,29.8059588 -0.215836891,28.4177782 0.647510672,27.5619518 L12.6615574,15.6519488 L0.647860092,3.74236142 C-0.21548747,2.8861193 -0.21548747,1.49807731 0.647860092,0.642181593 C1.51120765,-0.214060531 2.91147438,-0.214060531 3.77517136,0.642181593 L17.3527339,14.1023438 C17.7844077,14.5304995 18,15.0910509 18,15.6518795 C18,16.2129851 17.7839884,16.7739522 17.3523845,17.2019001 Z" id="Path"></path>
11
+ </g>
12
+ </g>
13
+ </g>
14
+ </svg>