@foxford/ui 2.89.0-beta-f37e97a-20251217 → 2.89.0

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 (2082) hide show
  1. package/assets/add-reaction.svg +1 -0
  2. package/assets/afghanistan.svg +1 -0
  3. package/assets/airplay.svg +1 -0
  4. package/assets/aland-islands.svg +1 -0
  5. package/assets/alarm-add.svg +1 -0
  6. package/assets/alarm-clock.svg +1 -0
  7. package/assets/alarm-warning.svg +1 -0
  8. package/assets/albania.svg +1 -0
  9. package/assets/algebra.svg +1 -0
  10. package/assets/algeria.svg +1 -0
  11. package/assets/algorithms_color.svg +1 -0
  12. package/assets/align-center-justify.svg +1 -0
  13. package/assets/align-center.svg +1 -0
  14. package/assets/align-justify.svg +1 -0
  15. package/assets/align-left-justify.svg +1 -0
  16. package/assets/align-left.svg +1 -0
  17. package/assets/align-right-justify.svg +1 -0
  18. package/assets/align-right.svg +1 -0
  19. package/assets/american-samoa.svg +1 -0
  20. package/assets/analytics_2_color.svg +1 -0
  21. package/assets/analytics_3_color.svg +1 -0
  22. package/assets/analytics_color.svg +1 -0
  23. package/assets/andorra.svg +1 -0
  24. package/assets/angola.svg +1 -0
  25. package/assets/anguilla.svg +1 -0
  26. package/assets/annotation-user.svg +1 -0
  27. package/assets/annotation.svg +1 -0
  28. package/assets/antigua-and-barbuda.svg +1 -0
  29. package/assets/apple-auth-mono-color.svg +1 -0
  30. package/assets/apple-authorization.svg +1 -0
  31. package/assets/archive.svg +1 -0
  32. package/assets/archive_color.svg +1 -0
  33. package/assets/argentina.svg +1 -0
  34. package/assets/armenia.svg +1 -0
  35. package/assets/arrow-circle-down-fill-tin-fill.svg +1 -0
  36. package/assets/arrow-circle-down-fill.svg +1 -0
  37. package/assets/arrow-circle-down-left-fill-tin-fill.svg +1 -0
  38. package/assets/arrow-circle-down-left-fill.svg +1 -0
  39. package/assets/arrow-circle-down-left.svg +1 -0
  40. package/assets/arrow-circle-down-right-fill-tin-fill.svg +1 -0
  41. package/assets/arrow-circle-down-right-fill.svg +1 -0
  42. package/assets/arrow-circle-down-right.svg +1 -0
  43. package/assets/arrow-circle-down.svg +1 -0
  44. package/assets/arrow-circle-left-fill-tin-fill.svg +1 -0
  45. package/assets/arrow-circle-left-fill.svg +1 -0
  46. package/assets/arrow-circle-left.svg +1 -0
  47. package/assets/arrow-circle-right-fill-tin-fill.svg +1 -0
  48. package/assets/arrow-circle-right-fill.svg +1 -0
  49. package/assets/arrow-circle-right.svg +1 -0
  50. package/assets/arrow-circle-up-fill-tin-fill.svg +1 -0
  51. package/assets/arrow-circle-up-fill.svg +1 -0
  52. package/assets/arrow-circle-up-left-fill-tin-fill.svg +1 -0
  53. package/assets/arrow-circle-up-left-fill.svg +1 -0
  54. package/assets/arrow-circle-up-left.svg +1 -0
  55. package/assets/arrow-circle-up-right-fill-tin-fill.svg +1 -0
  56. package/assets/arrow-circle-up-right-fill.svg +1 -0
  57. package/assets/arrow-circle-up-right.svg +1 -0
  58. package/assets/arrow-circle-up.svg +1 -0
  59. package/assets/arrow-down-arrow-up.svg +1 -0
  60. package/assets/arrow-down-fill.svg +1 -0
  61. package/assets/arrow-down-left-fill.svg +1 -0
  62. package/assets/arrow-down-left.svg +1 -0
  63. package/assets/arrow-down-right-fill.svg +1 -0
  64. package/assets/arrow-down-right.svg +1 -0
  65. package/assets/arrow-down-short-wide.svg +1 -0
  66. package/assets/arrow-down-wide-short.svg +1 -0
  67. package/assets/arrow-down.svg +1 -0
  68. package/assets/arrow-left-fill.svg +1 -0
  69. package/assets/arrow-left.svg +1 -0
  70. package/assets/arrow-narrow-down-fill.svg +1 -0
  71. package/assets/arrow-narrow-down.svg +1 -0
  72. package/assets/arrow-narrow-left-fill.svg +1 -0
  73. package/assets/arrow-narrow-left.svg +1 -0
  74. package/assets/arrow-narrow-right-fill.svg +1 -0
  75. package/assets/arrow-narrow-right.svg +1 -0
  76. package/assets/arrow-narrow-up-fill.svg +1 -0
  77. package/assets/arrow-narrow-up.svg +1 -0
  78. package/assets/arrow-right-fill.svg +1 -0
  79. package/assets/arrow-right.svg +1 -0
  80. package/assets/arrow-sm-down-fill.svg +1 -0
  81. package/assets/arrow-sm-down.svg +1 -0
  82. package/assets/arrow-sm-left-fill.svg +1 -0
  83. package/assets/arrow-sm-left.svg +1 -0
  84. package/assets/arrow-sm-right-fill.svg +1 -0
  85. package/assets/arrow-sm-right.svg +1 -0
  86. package/assets/arrow-sm-up-fill.svg +1 -0
  87. package/assets/arrow-sm-up.svg +1 -0
  88. package/assets/arrow-spin-fill.svg +1 -0
  89. package/assets/arrow-spin.svg +1 -0
  90. package/assets/arrow-square-down-fill.svg +1 -0
  91. package/assets/arrow-square-down-left-fill.svg +1 -0
  92. package/assets/arrow-square-down-left.svg +1 -0
  93. package/assets/arrow-square-down-right-fill.svg +1 -0
  94. package/assets/arrow-square-down-right.svg +1 -0
  95. package/assets/arrow-square-down.svg +1 -0
  96. package/assets/arrow-square-left-fill.svg +1 -0
  97. package/assets/arrow-square-left.svg +1 -0
  98. package/assets/arrow-square-right-fill.svg +1 -0
  99. package/assets/arrow-square-right.svg +1 -0
  100. package/assets/arrow-square-up-fill.svg +1 -0
  101. package/assets/arrow-square-up-left-fill.svg +1 -0
  102. package/assets/arrow-square-up-left.svg +1 -0
  103. package/assets/arrow-square-up-right-fill.svg +1 -0
  104. package/assets/arrow-square-up-right.svg +1 -0
  105. package/assets/arrow-square-up.svg +1 -0
  106. package/assets/arrow-up-1-9.svg +1 -0
  107. package/assets/arrow-up-9-1.svg +1 -0
  108. package/assets/arrow-up-fill.svg +1 -0
  109. package/assets/arrow-up-left-fill.svg +1 -0
  110. package/assets/arrow-up-left.svg +1 -0
  111. package/assets/arrow-up-right-fill.svg +1 -0
  112. package/assets/arrow-up-right.svg +1 -0
  113. package/assets/arrow-up-short-wide.svg +1 -0
  114. package/assets/arrow-up-wide-short.svg +1 -0
  115. package/assets/arrow-up.svg +1 -0
  116. package/assets/arrows-left-right.svg +1 -0
  117. package/assets/arrows-up-down.svg +1 -0
  118. package/assets/art_color.svg +1 -0
  119. package/assets/aruba.svg +1 -0
  120. package/assets/astronomy_color.svg +1 -0
  121. package/assets/at-sign.svg +1 -0
  122. package/assets/australia.svg +1 -0
  123. package/assets/austria.svg +1 -0
  124. package/assets/azerbaijan.svg +1 -0
  125. package/assets/back-arrow.svg +1 -0
  126. package/assets/back-chevron.svg +1 -0
  127. package/assets/badge-check.svg +1 -0
  128. package/assets/badge.svg +1 -0
  129. package/assets/bag-shopping.svg +1 -0
  130. package/assets/bahamas.svg +1 -0
  131. package/assets/bahrain.svg +1 -0
  132. package/assets/ban.svg +1 -0
  133. package/assets/bangladesh.svg +1 -0
  134. package/assets/bank.svg +1 -0
  135. package/assets/barbados.svg +1 -0
  136. package/assets/bars-progress.svg +1 -0
  137. package/assets/basket-shopping.svg +1 -0
  138. package/assets/battery-bolt.svg +1 -0
  139. package/assets/battery-empty.svg +1 -0
  140. package/assets/battery-full.svg +1 -0
  141. package/assets/battery-off.svg +1 -0
  142. package/assets/battery-warning.svg +1 -0
  143. package/assets/belarus.svg +1 -0
  144. package/assets/belgium.svg +1 -0
  145. package/assets/belize.svg +1 -0
  146. package/assets/benin.svg +1 -0
  147. package/assets/bermuda.svg +1 -0
  148. package/assets/bhutan.svg +1 -0
  149. package/assets/biology.svg +1 -0
  150. package/assets/biology_color.svg +1 -0
  151. package/assets/blackBoard_default.svg +1 -0
  152. package/assets/blackboard.svg +1 -0
  153. package/assets/bloger_color.svg +1 -0
  154. package/assets/blogging.svg +1 -0
  155. package/assets/blogging_color.svg +1 -0
  156. package/assets/blueprint_color.svg +1 -0
  157. package/assets/bluetooth-off.svg +1 -0
  158. package/assets/bluetooth-on.svg +1 -0
  159. package/assets/body_human_color.svg +1 -0
  160. package/assets/bold.svg +1 -0
  161. package/assets/bolivia.svg +1 -0
  162. package/assets/bolt-fill.svg +1 -0
  163. package/assets/bolt.svg +1 -0
  164. package/assets/book-fill.svg +1 -0
  165. package/assets/book-open.svg +1 -0
  166. package/assets/book.svg +1 -0
  167. package/assets/book_default.svg +1 -0
  168. package/assets/bookmark-fill.svg +1 -0
  169. package/assets/bookmark-stack.svg +1 -0
  170. package/assets/bookmark.svg +1 -0
  171. package/assets/books.svg +1 -0
  172. package/assets/books_color.svg +1 -0
  173. package/assets/border-bottom.svg +1 -0
  174. package/assets/border-clear.svg +1 -0
  175. package/assets/border-horizontal.svg +1 -0
  176. package/assets/border-inner.svg +1 -0
  177. package/assets/border-left.svg +1 -0
  178. package/assets/border-outer.svg +1 -0
  179. package/assets/border-right.svg +1 -0
  180. package/assets/border-top-left.svg +1 -0
  181. package/assets/border-top.svg +1 -0
  182. package/assets/border-vertical.svg +1 -0
  183. package/assets/bosnia-and-herzegovina.svg +1 -0
  184. package/assets/botswana.svg +1 -0
  185. package/assets/bottom-alignment.svg +1 -0
  186. package/assets/bracket-curly-right.svg +1 -0
  187. package/assets/bracket-curly.svg +1 -0
  188. package/assets/bracket-round-right.svg +1 -0
  189. package/assets/bracket-round.svg +1 -0
  190. package/assets/bracket-square-right.svg +1 -0
  191. package/assets/bracket-square.svg +1 -0
  192. package/assets/brackets-curly.svg +1 -0
  193. package/assets/brackets-round.svg +1 -0
  194. package/assets/brackets-square.svg +1 -0
  195. package/assets/brazil.svg +1 -0
  196. package/assets/bright-full-fill.svg +1 -0
  197. package/assets/bright-low-fill.svg +1 -0
  198. package/assets/briight-full.svg +1 -0
  199. package/assets/briight-low.svg +1 -0
  200. package/assets/british-indian-ocean_territory.svg +1 -0
  201. package/assets/british-virgin-islands.svg +1 -0
  202. package/assets/browser.svg +1 -0
  203. package/assets/brunei.svg +1 -0
  204. package/assets/brush.svg +1 -0
  205. package/assets/building.svg +1 -0
  206. package/assets/bulgaria.svg +1 -0
  207. package/assets/burger_default.svg +1 -0
  208. package/assets/burkina-faso.svg +1 -0
  209. package/assets/burundi.svg +1 -0
  210. package/assets/bus.svg +1 -0
  211. package/assets/calendar-add.svg +1 -0
  212. package/assets/calendar-edit.svg +1 -0
  213. package/assets/calendar-export.svg +1 -0
  214. package/assets/calendar-fill.svg +1 -0
  215. package/assets/calendar-import.svg +1 -0
  216. package/assets/calendar-minus.svg +1 -0
  217. package/assets/calendar-remove.svg +1 -0
  218. package/assets/calendar-tick.svg +1 -0
  219. package/assets/calendar-user.svg +1 -0
  220. package/assets/calendar-warning.svg +1 -0
  221. package/assets/calendar.svg +1 -0
  222. package/assets/calendar_color.svg +1 -0
  223. package/assets/calendar_default.svg +1 -0
  224. package/assets/calendar_simple_default.svg +1 -0
  225. package/assets/calendars.svg +1 -0
  226. package/assets/cambodia.svg +1 -0
  227. package/assets/camera-off.svg +1 -0
  228. package/assets/camera.svg +1 -0
  229. package/assets/cameroon.svg +1 -0
  230. package/assets/camp.svg +1 -0
  231. package/assets/camps_default.svg +1 -0
  232. package/assets/canada.svg +1 -0
  233. package/assets/canary-islands.svg +1 -0
  234. package/assets/cancel_default.svg +1 -0
  235. package/assets/cape-verde.svg +1 -0
  236. package/assets/car.svg +1 -0
  237. package/assets/card-flip.svg +1 -0
  238. package/assets/caret-down-fill.svg +1 -0
  239. package/assets/caret-down.svg +1 -0
  240. package/assets/caret-left-fill.svg +1 -0
  241. package/assets/caret-left-to-line-fill.svg +1 -0
  242. package/assets/caret-left-to-line.svg +1 -0
  243. package/assets/caret-left.svg +1 -0
  244. package/assets/caret-right-fill.svg +1 -0
  245. package/assets/caret-right-to-line-fill.svg +1 -0
  246. package/assets/caret-right-to-line.svg +1 -0
  247. package/assets/caret-right.svg +1 -0
  248. package/assets/caret-up-fill.svg +1 -0
  249. package/assets/caret-up.svg +1 -0
  250. package/assets/cart-arrow-down.svg +1 -0
  251. package/assets/cart-arrow-up.svg +1 -0
  252. package/assets/cart-close.svg +1 -0
  253. package/assets/cart-fast.svg +1 -0
  254. package/assets/cart-minus.svg +1 -0
  255. package/assets/cart-notif.svg +1 -0
  256. package/assets/cart-plus.svg +1 -0
  257. package/assets/cart-tick.svg +1 -0
  258. package/assets/cart.svg +1 -0
  259. package/assets/cart_default.svg +1 -0
  260. package/assets/case_color.svg +1 -0
  261. package/assets/cayman-islands.svg +1 -0
  262. package/assets/central-african-republic.svg +1 -0
  263. package/assets/certificate-check.svg +1 -0
  264. package/assets/certificate.svg +1 -0
  265. package/assets/ceuta.svg +1 -0
  266. package/assets/chad.svg +1 -0
  267. package/assets/chart-area.svg +1 -0
  268. package/assets/chart-bar.svg +1 -0
  269. package/assets/chart-bullet.svg +1 -0
  270. package/assets/chart-column.svg +1 -0
  271. package/assets/chart-gantt.svg +1 -0
  272. package/assets/chart-line-down.svg +1 -0
  273. package/assets/chart-line-up.svg +1 -0
  274. package/assets/chart-line.svg +1 -0
  275. package/assets/chart-mixed.svg +1 -0
  276. package/assets/chart-network.svg +1 -0
  277. package/assets/chart-pie.svg +1 -0
  278. package/assets/chart-pyramid.svg +1 -0
  279. package/assets/chart-radar.svg +1 -0
  280. package/assets/chart-scatter-3d.svg +1 -0
  281. package/assets/chart-scatter-bubble.svg +1 -0
  282. package/assets/chart-scatter.svg +1 -0
  283. package/assets/chart-simple-horizontal.svg +1 -0
  284. package/assets/chart-simple.svg +1 -0
  285. package/assets/chart-tree-map.svg +1 -0
  286. package/assets/chart-user-square.svg +1 -0
  287. package/assets/chart-waterfall.svg +1 -0
  288. package/assets/check-circle-fill.svg +1 -0
  289. package/assets/check-circle.svg +1 -0
  290. package/assets/check-double-fill.svg +1 -0
  291. package/assets/check-double.svg +1 -0
  292. package/assets/check-fill.svg +1 -0
  293. package/assets/check.svg +1 -0
  294. package/assets/checkCircle_default.svg +1 -0
  295. package/assets/check_default.svg +1 -0
  296. package/assets/chemistry.svg +1 -0
  297. package/assets/chemistry_color.svg +1 -0
  298. package/assets/chess_alt_color.svg +1 -0
  299. package/assets/chess_color.svg +1 -0
  300. package/assets/chevron-down-fill.svg +1 -0
  301. package/assets/chevron-down-left-fill.svg +1 -0
  302. package/assets/chevron-down-left.svg +1 -0
  303. package/assets/chevron-down-right-fill.svg +1 -0
  304. package/assets/chevron-down-right.svg +1 -0
  305. package/assets/chevron-down-small-fill.svg +1 -0
  306. package/assets/chevron-down-small.svg +1 -0
  307. package/assets/chevron-down.svg +1 -0
  308. package/assets/chevron-left-fill.svg +1 -0
  309. package/assets/chevron-left-small-fill.svg +1 -0
  310. package/assets/chevron-left-small.svg +1 -0
  311. package/assets/chevron-left.svg +1 -0
  312. package/assets/chevron-right-fill.svg +1 -0
  313. package/assets/chevron-right-small-fill.svg +1 -0
  314. package/assets/chevron-right-small.svg +1 -0
  315. package/assets/chevron-right.svg +1 -0
  316. package/assets/chevron-selector-horizontal.svg +1 -0
  317. package/assets/chevron-selector-vertical.svg +1 -0
  318. package/assets/chevron-up-fill.svg +1 -0
  319. package/assets/chevron-up-left-fill.svg +1 -0
  320. package/assets/chevron-up-left.svg +1 -0
  321. package/assets/chevron-up-right-fill.svg +1 -0
  322. package/assets/chevron-up-right.svg +1 -0
  323. package/assets/chevron-up-small-fill.svg +1 -0
  324. package/assets/chevron-up-small.svg +1 -0
  325. package/assets/chevron-up.svg +1 -0
  326. package/assets/chevronDown_default.svg +1 -0
  327. package/assets/chevronLeft_default.svg +1 -0
  328. package/assets/chevronRight_default.svg +1 -0
  329. package/assets/chevronUp_default.svg +1 -0
  330. package/assets/children.svg +1 -0
  331. package/assets/chile.svg +1 -0
  332. package/assets/china.svg +1 -0
  333. package/assets/chinese_color.svg +1 -0
  334. package/assets/circle-dollar-to-slot.svg +1 -0
  335. package/assets/circle-dollar.svg +1 -0
  336. package/assets/circle-notch.svg +1 -0
  337. package/assets/circle-pause.svg +1 -0
  338. package/assets/circle-play.svg +1 -0
  339. package/assets/circle-quarter.svg +1 -0
  340. package/assets/circle-quarters.svg +1 -0
  341. package/assets/circle-three-quarters.svg +1 -0
  342. package/assets/circle-user-fill.svg +1 -0
  343. package/assets/city.svg +1 -0
  344. package/assets/clipboard-export.svg +1 -0
  345. package/assets/clipboard-import.svg +1 -0
  346. package/assets/clipboard-list-alt.svg +1 -0
  347. package/assets/clipboard-minus.svg +1 -0
  348. package/assets/clipboard-plus.svg +1 -0
  349. package/assets/clipboard-text.svg +1 -0
  350. package/assets/clipboard.svg +1 -0
  351. package/assets/clock-add.svg +1 -0
  352. package/assets/clock-done.svg +1 -0
  353. package/assets/clock-fill.svg +1 -0
  354. package/assets/clock-remove.svg +1 -0
  355. package/assets/clock-warning.svg +1 -0
  356. package/assets/clock.svg +1 -0
  357. package/assets/clockFilled_default.svg +1 -0
  358. package/assets/clock_default.svg +1 -0
  359. package/assets/close-cirlce-fill.svg +1 -0
  360. package/assets/close-cirlce.svg +1 -0
  361. package/assets/close-fill.svg +1 -0
  362. package/assets/close-large-fill.svg +1 -0
  363. package/assets/close-large.svg +1 -0
  364. package/assets/close.svg +1 -0
  365. package/assets/cloud-add.svg +1 -0
  366. package/assets/cloud-bolt.svg +1 -0
  367. package/assets/cloud-done.svg +1 -0
  368. package/assets/cloud-download.svg +1 -0
  369. package/assets/cloud-error.svg +1 -0
  370. package/assets/cloud-export.svg +1 -0
  371. package/assets/cloud-import.svg +1 -0
  372. package/assets/cloud-off.svg +1 -0
  373. package/assets/cloud-question.svg +1 -0
  374. package/assets/cloud-remove.svg +1 -0
  375. package/assets/cloud-upload.svg +1 -0
  376. package/assets/cloud-warning.svg +1 -0
  377. package/assets/cloud.svg +1 -0
  378. package/assets/club.svg +1 -0
  379. package/assets/cocos-island.svg +1 -0
  380. package/assets/code.svg +1 -0
  381. package/assets/coin-vertical.svg +1 -0
  382. package/assets/coin.svg +1 -0
  383. package/assets/coins.svg +1 -0
  384. package/assets/coins_default.svg +1 -0
  385. package/assets/college_color.svg +1 -0
  386. package/assets/colombia.svg +1 -0
  387. package/assets/columns-2.svg +1 -0
  388. package/assets/columns-3.svg +1 -0
  389. package/assets/comoros.svg +1 -0
  390. package/assets/compass.svg +1 -0
  391. package/assets/computer.svg +1 -0
  392. package/assets/constrict.svg +1 -0
  393. package/assets/cook-islands.svg +1 -0
  394. package/assets/copy-fill.svg +1 -0
  395. package/assets/copy.svg +1 -0
  396. package/assets/copy_default.svg +4 -0
  397. package/assets/corner-down-left-fill.svg +1 -0
  398. package/assets/corner-down-left.svg +1 -0
  399. package/assets/corner-down-right-fill.svg +1 -0
  400. package/assets/corner-down-right.svg +1 -0
  401. package/assets/corner-left-down-fill.svg +1 -0
  402. package/assets/corner-left-down.svg +1 -0
  403. package/assets/corner-left-up-fill.svg +1 -0
  404. package/assets/corner-left-up.svg +1 -0
  405. package/assets/corner-right-down-fill.svg +1 -0
  406. package/assets/corner-right-down.svg +1 -0
  407. package/assets/corner-right-up-fill.svg +1 -0
  408. package/assets/corner-right-up.svg +1 -0
  409. package/assets/corner-up-left-fill.svg +1 -0
  410. package/assets/corner-up-left.svg +1 -0
  411. package/assets/corner-up-right-fill.svg +1 -0
  412. package/assets/corner-up-right.svg +1 -0
  413. package/assets/costa-rica.svg +1 -0
  414. package/assets/cource_color.svg +1 -0
  415. package/assets/courses_default.svg +1 -0
  416. package/assets/creativity_color.svg +1 -0
  417. package/assets/credit-card-add.svg +1 -0
  418. package/assets/credit-card-remove.svg +1 -0
  419. package/assets/credit-card-scan.svg +1 -0
  420. package/assets/credit-card.svg +1 -0
  421. package/assets/croatia.svg +1 -0
  422. package/assets/crop.svg +1 -0
  423. package/assets/cross_default.svg +1 -0
  424. package/assets/crown.svg +1 -0
  425. package/assets/cuba.svg +1 -0
  426. package/assets/cube-sharp.svg +1 -0
  427. package/assets/cube-vr.svg +1 -0
  428. package/assets/cube.svg +1 -0
  429. package/assets/curacao.svg +1 -0
  430. package/assets/cursor-fill.svg +1 -0
  431. package/assets/cursor.svg +1 -0
  432. package/assets/cyprus.svg +1 -0
  433. package/assets/czech-republic.svg +1 -0
  434. package/assets/dash.svg +1 -0
  435. package/assets/delete-fill.svg +1 -0
  436. package/assets/delete.svg +1 -0
  437. package/assets/democratic-republic-of_congo.svg +1 -0
  438. package/assets/denmark.svg +1 -0
  439. package/assets/development_1_color.svg +1 -0
  440. package/assets/development_2_color.svg +1 -0
  441. package/assets/diagram-cells.svg +1 -0
  442. package/assets/diagram-lean-canvas.svg +1 -0
  443. package/assets/diagram-nested.svg +1 -0
  444. package/assets/diagram-next.svg +1 -0
  445. package/assets/diagram-predecessor.svg +1 -0
  446. package/assets/diagram-previous.svg +1 -0
  447. package/assets/diagram-project.svg +1 -0
  448. package/assets/diagram-sankey.svg +1 -0
  449. package/assets/diagram-subtask.svg +1 -0
  450. package/assets/diagram-successor.svg +1 -0
  451. package/assets/diagram-venn.svg +1 -0
  452. package/assets/dialog_default.svg +1 -0
  453. package/assets/dialpad-circle.svg +1 -0
  454. package/assets/dialpad-square.svg +1 -0
  455. package/assets/diamond-simple.svg +1 -0
  456. package/assets/diamond.svg +1 -0
  457. package/assets/diamondFilled_default.svg +1 -0
  458. package/assets/diamond_default.svg +1 -0
  459. package/assets/dice-five.svg +1 -0
  460. package/assets/dice-four.svg +1 -0
  461. package/assets/dice-one.svg +1 -0
  462. package/assets/dice-six.svg +1 -0
  463. package/assets/dice-three.svg +1 -0
  464. package/assets/dice-two.svg +1 -0
  465. package/assets/digital_professions_color.svg +1 -0
  466. package/assets/diploma_color.svg +1 -0
  467. package/assets/disc.svg +1 -0
  468. package/assets/discount-badge.svg +1 -0
  469. package/assets/discount-circle.svg +1 -0
  470. package/assets/discount_default.svg +1 -0
  471. package/assets/dislike.svg +1 -0
  472. package/assets/distribute-spacing-horizontal.svg +1 -0
  473. package/assets/distribute-spacing-vertical.svg +1 -0
  474. package/assets/djibouti.svg +1 -0
  475. package/assets/doc.svg +1 -0
  476. package/assets/document-layout-center.svg +1 -0
  477. package/assets/document-layout-left.svg +1 -0
  478. package/assets/document-layout-right.svg +1 -0
  479. package/assets/document_default.svg +1 -0
  480. package/assets/dominica.svg +1 -0
  481. package/assets/dominican-republic.svg +1 -0
  482. package/assets/door-closed.svg +1 -0
  483. package/assets/door-open.svg +1 -0
  484. package/assets/double-xp-fill.svg +1 -0
  485. package/assets/download-fill.svg +1 -0
  486. package/assets/download.svg +1 -0
  487. package/assets/draw-square-t.svg +1 -0
  488. package/assets/draw-square.svg +1 -0
  489. package/assets/drawing-tablet.svg +1 -0
  490. package/assets/drawing_color.svg +1 -0
  491. package/assets/dropDownArrow_default.svg +1 -0
  492. package/assets/early_education_color.svg +1 -0
  493. package/assets/east-timor.svg +1 -0
  494. package/assets/ecology.svg +1 -0
  495. package/assets/ecology_color.svg +1 -0
  496. package/assets/economy_color.svg +1 -0
  497. package/assets/ecuador.svg +1 -0
  498. package/assets/edit-fill.svg +1 -0
  499. package/assets/edit-pen-fill.svg +1 -0
  500. package/assets/edit-pen.svg +1 -0
  501. package/assets/edit.svg +1 -0
  502. package/assets/edit_default.svg +1 -0
  503. package/assets/education_color.svg +1 -0
  504. package/assets/education_program_color.svg +1 -0
  505. package/assets/educont-auth-mono-color.svg +1 -0
  506. package/assets/educont-authorization.svg +1 -0
  507. package/assets/egypt.svg +1 -0
  508. package/assets/el-salvador.svg +1 -0
  509. package/assets/elementary_color.svg +1 -0
  510. package/assets/email_default.svg +1 -0
  511. package/assets/emotional_intelligence_color.svg +1 -0
  512. package/assets/england.svg +1 -0
  513. package/assets/english-to-chinese.svg +1 -0
  514. package/assets/english.svg +1 -0
  515. package/assets/english_color.svg +1 -0
  516. package/assets/enter-fill.svg +1 -0
  517. package/assets/enter.svg +1 -0
  518. package/assets/equatorial-guinea.svg +1 -0
  519. package/assets/eritrea.svg +1 -0
  520. package/assets/estonia.svg +1 -0
  521. package/assets/ethiopia.svg +1 -0
  522. package/assets/european-union.svg +1 -0
  523. package/assets/exam-test_color.svg +1 -0
  524. package/assets/exam_color.svg +1 -0
  525. package/assets/expand.svg +1 -0
  526. package/assets/export-fill.svg +1 -0
  527. package/assets/export.svg +1 -0
  528. package/assets/external-link-fill.svg +1 -0
  529. package/assets/external-link.svg +1 -0
  530. package/assets/externalLink_default.svg +1 -0
  531. package/assets/externat_default.svg +1 -0
  532. package/assets/eye-close-fill.svg +1 -0
  533. package/assets/eye-close.svg +1 -0
  534. package/assets/eye-dropper-full.svg +1 -0
  535. package/assets/eye-dropper-half.svg +1 -0
  536. package/assets/eye-dropper.svg +1 -0
  537. package/assets/eye-fill.svg +1 -0
  538. package/assets/eye-slash-fill.svg +1 -0
  539. package/assets/eye-slash.svg +1 -0
  540. package/assets/eye.svg +1 -0
  541. package/assets/eye_default.svg +1 -0
  542. package/assets/face-frown-fill.svg +1 -0
  543. package/assets/face-frown.svg +1 -0
  544. package/assets/face-id.svg +1 -0
  545. package/assets/face-smile-fill.svg +1 -0
  546. package/assets/face-smile.svg +1 -0
  547. package/assets/facebook-social-color.svg +1 -0
  548. package/assets/facebook-social.svg +1 -0
  549. package/assets/falkland-islands.svg +1 -0
  550. package/assets/family-house.svg +1 -0
  551. package/assets/family.svg +1 -0
  552. package/assets/faroe-islands.svg +1 -0
  553. package/assets/fast-timer.svg +1 -0
  554. package/assets/figma.svg +1 -0
  555. package/assets/fiji.svg +1 -0
  556. package/assets/file-add-alt-1.svg +1 -0
  557. package/assets/file-add.svg +1 -0
  558. package/assets/file-bookmark.svg +1 -0
  559. package/assets/file-dashed-line.svg +1 -0
  560. package/assets/file-download.svg +1 -0
  561. package/assets/file-edit-corner.svg +1 -0
  562. package/assets/file-edit.svg +1 -0
  563. package/assets/file-exclamation-corner.svg +1 -0
  564. package/assets/file-horizontal.svg +1 -0
  565. package/assets/file-import.svg +1 -0
  566. package/assets/file-info-corner.svg +1 -0
  567. package/assets/file-info.svg +1 -0
  568. package/assets/file-link.svg +1 -0
  569. package/assets/file-minus-corner.svg +1 -0
  570. package/assets/file-minus.svg +1 -0
  571. package/assets/file-move.svg +1 -0
  572. package/assets/file-off.svg +1 -0
  573. package/assets/file-pdf.svg +1 -0
  574. package/assets/file-question-corner.svg +1 -0
  575. package/assets/file-question.svg +1 -0
  576. package/assets/file-remove.svg +1 -0
  577. package/assets/file-shredder.svg +1 -0
  578. package/assets/file-text.svg +1 -0
  579. package/assets/file-tick.svg +1 -0
  580. package/assets/file-upload.svg +1 -0
  581. package/assets/file-warning.svg +1 -0
  582. package/assets/file-zipper.svg +1 -0
  583. package/assets/file.svg +1 -0
  584. package/assets/fileBordered_default.svg +1 -0
  585. package/assets/file_default.svg +1 -0
  586. package/assets/files.svg +1 -0
  587. package/assets/filter-fill.svg +1 -0
  588. package/assets/filter.svg +1 -0
  589. package/assets/finance_color.svg +1 -0
  590. package/assets/financial_battle_color.svg +1 -0
  591. package/assets/financial_literature_color.svg +1 -0
  592. package/assets/fingerprint.svg +1 -0
  593. package/assets/finland.svg +1 -0
  594. package/assets/fire-alt.svg +1 -0
  595. package/assets/fire-fill.svg +1 -0
  596. package/assets/fire-small-fill.svg +1 -0
  597. package/assets/fire.svg +1 -0
  598. package/assets/fire_default.svg +1 -0
  599. package/assets/fizra_2_color.svg +1 -0
  600. package/assets/fizra_color.svg +1 -0
  601. package/assets/fizra_elementary_color.svg +1 -0
  602. package/assets/flag.svg +1 -0
  603. package/assets/flash-cards.svg +1 -0
  604. package/assets/flashlight.svg +1 -0
  605. package/assets/folder-add.svg +1 -0
  606. package/assets/folder-export.svg +1 -0
  607. package/assets/folder-import.svg +1 -0
  608. package/assets/folder-info.svg +1 -0
  609. package/assets/folder-minus.svg +1 -0
  610. package/assets/folder-move.svg +1 -0
  611. package/assets/folder-notif.svg +1 -0
  612. package/assets/folder-question.svg +1 -0
  613. package/assets/folder-remove.svg +1 -0
  614. package/assets/folder-tick.svg +1 -0
  615. package/assets/folder-warning.svg +1 -0
  616. package/assets/folder.svg +1 -0
  617. package/assets/folder_color.svg +1 -0
  618. package/assets/font-case.svg +1 -0
  619. package/assets/font.svg +1 -0
  620. package/assets/food_color.svg +1 -0
  621. package/assets/foreign_language_color.svg +1 -0
  622. package/assets/forward-fill.svg +1 -0
  623. package/assets/forward.svg +1 -0
  624. package/assets/fox-coin.svg +1 -0
  625. package/assets/fox-coins.svg +1 -0
  626. package/assets/france.svg +1 -0
  627. package/assets/french-polynesia.svg +1 -0
  628. package/assets/french_color.svg +1 -0
  629. package/assets/gabon.svg +1 -0
  630. package/assets/gallery-thumbnails.svg +1 -0
  631. package/assets/gambia.svg +1 -0
  632. package/assets/game.svg +1 -0
  633. package/assets/game_profession_dev_color.svg +1 -0
  634. package/assets/game_profession_producer_color.svg +1 -0
  635. package/assets/game_profession_screenwriter_color.svg +1 -0
  636. package/assets/games_color.svg +1 -0
  637. package/assets/gem.svg +1 -0
  638. package/assets/geography.svg +1 -0
  639. package/assets/geography_color.svg +1 -0
  640. package/assets/geography_elementary_color.svg +1 -0
  641. package/assets/geometry_color.svg +1 -0
  642. package/assets/georgia.svg +1 -0
  643. package/assets/german_color.svg +1 -0
  644. package/assets/germany.svg +1 -0
  645. package/assets/ghana.svg +1 -0
  646. package/assets/gibraltar.svg +1 -0
  647. package/assets/gift-alt-fill.svg +1 -0
  648. package/assets/gift-box.svg +1 -0
  649. package/assets/gift-card.svg +1 -0
  650. package/assets/gift-fill.svg +1 -0
  651. package/assets/gift.svg +1 -0
  652. package/assets/globe.svg +1 -0
  653. package/assets/goal.svg +1 -0
  654. package/assets/gold.svg +1 -0
  655. package/assets/google-auth-mono-color.svg +1 -0
  656. package/assets/google-authorization.svg +1 -0
  657. package/assets/gps-off.svg +1 -0
  658. package/assets/gps.svg +1 -0
  659. package/assets/greece.svg +1 -0
  660. package/assets/greenland.svg +1 -0
  661. package/assets/grenada.svg +1 -0
  662. package/assets/grid-circle-fill.svg +1 -0
  663. package/assets/grid-circle.svg +1 -0
  664. package/assets/grid-fill.svg +1 -0
  665. package/assets/grid-plus-fill.svg +1 -0
  666. package/assets/grid-plus.svg +1 -0
  667. package/assets/grid.svg +1 -0
  668. package/assets/grip-dots-fill.svg +1 -0
  669. package/assets/grip-dots-vertical-fill.svg +1 -0
  670. package/assets/grip-dots-vertical.svg +1 -0
  671. package/assets/grip-dots.svg +1 -0
  672. package/assets/group_color.svg +1 -0
  673. package/assets/guam.svg +1 -0
  674. package/assets/guatemala.svg +1 -0
  675. package/assets/guernsey.svg +1 -0
  676. package/assets/guinea-bissau.svg +1 -0
  677. package/assets/guinea.svg +1 -0
  678. package/assets/guyana.svg +1 -0
  679. package/assets/h1.svg +1 -0
  680. package/assets/h2.svg +1 -0
  681. package/assets/haiti.svg +1 -0
  682. package/assets/hand-left.svg +1 -0
  683. package/assets/hand-right.svg +1 -0
  684. package/assets/hand-slash.svg +1 -0
  685. package/assets/hard-drive.svg +1 -0
  686. package/assets/hashtag-lock.svg +1 -0
  687. package/assets/hashtag.svg +1 -0
  688. package/assets/hat.svg +1 -0
  689. package/assets/heading.svg +1 -0
  690. package/assets/headphones.svg +1 -0
  691. package/assets/headphones_default.svg +1 -0
  692. package/assets/heart-circle-fill.svg +1 -0
  693. package/assets/heart-circle.svg +1 -0
  694. package/assets/heart-crack.svg +1 -0
  695. package/assets/heart-fill.svg +1 -0
  696. package/assets/heart-half-stroke.svg +1 -0
  697. package/assets/heart-half.svg +1 -0
  698. package/assets/heart.svg +1 -0
  699. package/assets/help-circle-fill.svg +1 -0
  700. package/assets/help-circle.svg +1 -0
  701. package/assets/help-seal-fill.svg +1 -0
  702. package/assets/help-seal.svg +1 -0
  703. package/assets/help.svg +1 -0
  704. package/assets/hexagon.svg +1 -0
  705. package/assets/history.svg +1 -0
  706. package/assets/history_alt_color.svg +1 -0
  707. package/assets/history_color.svg +1 -0
  708. package/assets/home_default.svg +1 -0
  709. package/assets/home_school_color.svg +1 -0
  710. package/assets/honduras.svg +1 -0
  711. package/assets/hong-kong.svg +1 -0
  712. package/assets/horizontal-rule.svg +1 -0
  713. package/assets/hotel.svg +1 -0
  714. package/assets/hourglass-end.svg +1 -0
  715. package/assets/hourglass-half.svg +1 -0
  716. package/assets/hourglass-start.svg +1 -0
  717. package/assets/hourglass.svg +1 -0
  718. package/assets/house-alt-fill.svg +1 -0
  719. package/assets/house-empty.svg +1 -0
  720. package/assets/house-fill.svg +1 -0
  721. package/assets/house.svg +1 -0
  722. package/assets/hungary.svg +1 -0
  723. package/assets/i-cursor.svg +1 -0
  724. package/assets/iceland.svg +1 -0
  725. package/assets/image-add.svg +1 -0
  726. package/assets/image-edit.svg +1 -0
  727. package/assets/image-error.svg +1 -0
  728. package/assets/image-export.svg +1 -0
  729. package/assets/image-import.svg +1 -0
  730. package/assets/image-remove.svg +1 -0
  731. package/assets/image-tick.svg +1 -0
  732. package/assets/image-user.svg +1 -0
  733. package/assets/image.svg +1 -0
  734. package/assets/import-fill.svg +1 -0
  735. package/assets/import.svg +1 -0
  736. package/assets/inbox-add.svg +1 -0
  737. package/assets/inbox-check.svg +1 -0
  738. package/assets/inbox-export.svg +1 -0
  739. package/assets/inbox-import.svg +1 -0
  740. package/assets/inbox-information.svg +1 -0
  741. package/assets/inbox-minus.svg +1 -0
  742. package/assets/inbox-move.svg +1 -0
  743. package/assets/inbox-notif.svg +1 -0
  744. package/assets/inbox-remove.svg +1 -0
  745. package/assets/inbox-warning.svg +1 -0
  746. package/assets/inbox.svg +1 -0
  747. package/assets/income.svg +1 -0
  748. package/assets/indent.svg +1 -0
  749. package/assets/india.svg +1 -0
  750. package/assets/indonesia.svg +1 -0
  751. package/assets/industry.svg +1 -0
  752. package/assets/infinity.svg +1 -0
  753. package/assets/info-circle-fill.svg +1 -0
  754. package/assets/info-circle.svg +1 -0
  755. package/assets/infoInverse_default.svg +1 -0
  756. package/assets/info_default.svg +1 -0
  757. package/assets/informatics_color.svg +1 -0
  758. package/assets/information.svg +1 -0
  759. package/assets/instagram-social-color.svg +1 -0
  760. package/assets/instagram-social.svg +1 -0
  761. package/assets/iran.svg +1 -0
  762. package/assets/iraq.svg +1 -0
  763. package/assets/ireland.svg +1 -0
  764. package/assets/isle-of-man.svg +1 -0
  765. package/assets/israel.svg +1 -0
  766. package/assets/italic.svg +1 -0
  767. package/assets/italy.svg +1 -0
  768. package/assets/items.svg +1 -0
  769. package/assets/ivory-coast.svg +1 -0
  770. package/assets/jamaica.svg +1 -0
  771. package/assets/japan.svg +1 -0
  772. package/assets/jersey.svg +1 -0
  773. package/assets/jordan.svg +1 -0
  774. package/assets/journalistic_color.svg +1 -0
  775. package/assets/kazakhstan.svg +1 -0
  776. package/assets/kenya.svg +1 -0
  777. package/assets/kerning.svg +1 -0
  778. package/assets/key-tiny.svg +1 -0
  779. package/assets/key.svg +1 -0
  780. package/assets/keyboard-close.svg +1 -0
  781. package/assets/keyboard.svg +1 -0
  782. package/assets/kiribati.svg +1 -0
  783. package/assets/kuwait.svg +1 -0
  784. package/assets/kyrgyzstan.svg +1 -0
  785. package/assets/lamp-charge-fill.svg +1 -0
  786. package/assets/lamp-charge.svg +1 -0
  787. package/assets/lamp-off-fill.svg +1 -0
  788. package/assets/lamp-off.svg +1 -0
  789. package/assets/lamp-on-fill.svg +1 -0
  790. package/assets/lamp-on.svg +1 -0
  791. package/assets/lamp-warning-fill.svg +1 -0
  792. package/assets/lamp-warning.svg +1 -0
  793. package/assets/laos.svg +1 -0
  794. package/assets/laptop-arrow-down.svg +1 -0
  795. package/assets/laptop-arrow-up.svg +1 -0
  796. package/assets/laptop-error.svg +1 -0
  797. package/assets/laptop-exclamation.svg +1 -0
  798. package/assets/laptop-signal.svg +1 -0
  799. package/assets/laptop-tick.svg +1 -0
  800. package/assets/laptop.svg +1 -0
  801. package/assets/lasso.svg +1 -0
  802. package/assets/latvia.svg +1 -0
  803. package/assets/lebanon.svg +1 -0
  804. package/assets/left-alignment.svg +1 -0
  805. package/assets/left-indent.svg +1 -0
  806. package/assets/left-to-right-text-direction.svg +1 -0
  807. package/assets/lesotho.svg +1 -0
  808. package/assets/lessons_default.svg +1 -0
  809. package/assets/letter-chinese-a.svg +1 -0
  810. package/assets/liberia.svg +1 -0
  811. package/assets/libya.svg +1 -0
  812. package/assets/liechtenstein.svg +1 -0
  813. package/assets/light-warning-on.svg +1 -0
  814. package/assets/light-warning.svg +1 -0
  815. package/assets/lightning-fill.svg +1 -0
  816. package/assets/lightning.svg +1 -0
  817. package/assets/like.svg +1 -0
  818. package/assets/line-columns.svg +1 -0
  819. package/assets/line-height.svg +1 -0
  820. package/assets/lines-leaning.svg +1 -0
  821. package/assets/link-fill.svg +1 -0
  822. package/assets/link-slash.svg +1 -0
  823. package/assets/link.svg +1 -0
  824. package/assets/list-circle.svg +1 -0
  825. package/assets/list-ol.svg +1 -0
  826. package/assets/list-ul-level.svg +1 -0
  827. package/assets/list-ul.svg +1 -0
  828. package/assets/list.svg +1 -0
  829. package/assets/list_default.svg +1 -0
  830. package/assets/literature.svg +1 -0
  831. package/assets/literature_alt_color.svg +1 -0
  832. package/assets/literature_color.svg +1 -0
  833. package/assets/lithuania.svg +1 -0
  834. package/assets/loader-fill.svg +1 -0
  835. package/assets/loader.svg +1 -0
  836. package/assets/loading.svg +1 -0
  837. package/assets/location-check.svg +1 -0
  838. package/assets/lock-a.svg +1 -0
  839. package/assets/lock-fill.svg +1 -0
  840. package/assets/lock-hashtag.svg +1 -0
  841. package/assets/lock-slash.svg +1 -0
  842. package/assets/lock.svg +1 -0
  843. package/assets/log-in-fill.svg +1 -0
  844. package/assets/log-in.svg +1 -0
  845. package/assets/log-out-fill.svg +1 -0
  846. package/assets/log-out.svg +1 -0
  847. package/assets/logic_color.svg +1 -0
  848. package/assets/login_default.svg +3 -0
  849. package/assets/logoped_color.svg +1 -0
  850. package/assets/logout_default.svg +1 -0
  851. package/assets/loop.svg +1 -0
  852. package/assets/luxembourg.svg +1 -0
  853. package/assets/macao.svg +1 -0
  854. package/assets/madagascar.svg +1 -0
  855. package/assets/mail-add.svg +1 -0
  856. package/assets/mail-block.svg +1 -0
  857. package/assets/mail-edit.svg +1 -0
  858. package/assets/mail-fill.svg +1 -0
  859. package/assets/mail-info.svg +1 -0
  860. package/assets/mail-minus.svg +1 -0
  861. package/assets/mail-notif.svg +1 -0
  862. package/assets/mail-open.svg +1 -0
  863. package/assets/mail-refresh.svg +1 -0
  864. package/assets/mail-remove.svg +1 -0
  865. package/assets/mail-tick.svg +1 -0
  866. package/assets/mail-warning.svg +1 -0
  867. package/assets/mail.ru-authorization.svg +1 -0
  868. package/assets/mail.svg +1 -0
  869. package/assets/mailru-auth-mono-color.svg +1 -0
  870. package/assets/malawi.svg +1 -0
  871. package/assets/malaysia.svg +1 -0
  872. package/assets/maldives.svg +1 -0
  873. package/assets/mali.svg +1 -0
  874. package/assets/malta.svg +1 -0
  875. package/assets/map-location-pin.svg +1 -0
  876. package/assets/map-marker-add.svg +1 -0
  877. package/assets/map-marker-error.svg +1 -0
  878. package/assets/map-marker-off.svg +1 -0
  879. package/assets/map-marker-remove.svg +1 -0
  880. package/assets/map-marker-warning.svg +1 -0
  881. package/assets/map-marker.svg +1 -0
  882. package/assets/map.svg +1 -0
  883. package/assets/marshall-island.svg +1 -0
  884. package/assets/martinique.svg +1 -0
  885. package/assets/materials_color.svg +1 -0
  886. package/assets/math_color.svg +1 -0
  887. package/assets/math_elementary_color.svg +1 -0
  888. package/assets/mathematics.svg +1 -0
  889. package/assets/mauritania.svg +1 -0
  890. package/assets/mauritius.svg +1 -0
  891. package/assets/maximize.svg +1 -0
  892. package/assets/medal-fill.svg +1 -0
  893. package/assets/medal.svg +1 -0
  894. package/assets/medicine_color.svg +1 -0
  895. package/assets/megaphone_color.svg +1 -0
  896. package/assets/memo-check.svg +1 -0
  897. package/assets/memo-pencil.svg +1 -0
  898. package/assets/menu-fill.svg +1 -0
  899. package/assets/menu.svg +1 -0
  900. package/assets/message-circle-chat-fill.svg +1 -0
  901. package/assets/message-circle-chat.svg +1 -0
  902. package/assets/message-circle-export.svg +1 -0
  903. package/assets/message-circle-import.svg +1 -0
  904. package/assets/message-circle-info.svg +1 -0
  905. package/assets/message-circle-lines.svg +1 -0
  906. package/assets/message-circle-minus.svg +1 -0
  907. package/assets/message-circle-notif.svg +1 -0
  908. package/assets/message-circle-plus.svg +1 -0
  909. package/assets/message-circle-question.svg +1 -0
  910. package/assets/message-circle-tick.svg +1 -0
  911. package/assets/message-circle-warning.svg +1 -0
  912. package/assets/message-circle-xmark.svg +1 -0
  913. package/assets/message-circle.svg +1 -0
  914. package/assets/message-square-arrow-down.svg +1 -0
  915. package/assets/message-square-chat.svg +1 -0
  916. package/assets/message-square-export.svg +1 -0
  917. package/assets/message-square-info.svg +1 -0
  918. package/assets/message-square-lines-fill.svg +1 -0
  919. package/assets/message-square-lines.svg +1 -0
  920. package/assets/message-square-minus.svg +1 -0
  921. package/assets/message-square-notif.svg +1 -0
  922. package/assets/message-square-plus.svg +1 -0
  923. package/assets/message-square-question.svg +1 -0
  924. package/assets/message-square-remove.svg +1 -0
  925. package/assets/message-square-tick.svg +1 -0
  926. package/assets/message-square-warning.svg +1 -0
  927. package/assets/message-square.svg +1 -0
  928. package/assets/message_default.svg +1 -0
  929. package/assets/mexico.svg +1 -0
  930. package/assets/micronesia.svg +1 -0
  931. package/assets/microphone-off.svg +1 -0
  932. package/assets/microphone.svg +1 -0
  933. package/assets/mini_group_color.svg +1 -0
  934. package/assets/minimize.svg +1 -0
  935. package/assets/minus-circle-fill.svg +1 -0
  936. package/assets/minus-circle.svg +1 -0
  937. package/assets/minus-fill.svg +1 -0
  938. package/assets/minus.svg +1 -0
  939. package/assets/mix.svg +1 -0
  940. package/assets/mobile-bolt.svg +1 -0
  941. package/assets/mobile-remove.svg +1 -0
  942. package/assets/mobile-signal-out.svg +1 -0
  943. package/assets/mobile-signal.svg +1 -0
  944. package/assets/mobile-slash.svg +1 -0
  945. package/assets/mobile-tick.svg +1 -0
  946. package/assets/mobile.svg +1 -0
  947. package/assets/modem.svg +1 -0
  948. package/assets/moldova.svg +1 -0
  949. package/assets/monaco.svg +1 -0
  950. package/assets/mongolia.svg +1 -0
  951. package/assets/montenegro.svg +1 -0
  952. package/assets/montserrat.svg +1 -0
  953. package/assets/moon-fill.svg +1 -0
  954. package/assets/moon.svg +1 -0
  955. package/assets/more-horizontal-fill.svg +1 -0
  956. package/assets/more-horizontal.svg +1 -0
  957. package/assets/more-vertical-fill.svg +1 -0
  958. package/assets/more-vertical.svg +1 -0
  959. package/assets/morocco.svg +1 -0
  960. package/assets/motorcycle.svg +1 -0
  961. package/assets/mouse.svg +1 -0
  962. package/assets/move-down.svg +1 -0
  963. package/assets/move-left.svg +1 -0
  964. package/assets/move-right.svg +1 -0
  965. package/assets/move-up.svg +1 -0
  966. package/assets/move.svg +1 -0
  967. package/assets/mozambique.svg +1 -0
  968. package/assets/multi_discipline_color.svg +1 -0
  969. package/assets/music-note-off.svg +1 -0
  970. package/assets/music-note.svg +1 -0
  971. package/assets/music.svg +1 -0
  972. package/assets/music_color.svg +1 -0
  973. package/assets/myanmar.svg +1 -0
  974. package/assets/namibia.svg +1 -0
  975. package/assets/native_language_color.svg +1 -0
  976. package/assets/natural_sciences_color.svg +1 -0
  977. package/assets/nauru.svg +1 -0
  978. package/assets/navigation-forward.svg +1 -0
  979. package/assets/navigation.svg +1 -0
  980. package/assets/nepal.svg +1 -0
  981. package/assets/netherlands.svg +1 -0
  982. package/assets/new-zealand.svg +1 -0
  983. package/assets/next-fast.svg +1 -0
  984. package/assets/next.svg +1 -0
  985. package/assets/nicaragua.svg +1 -0
  986. package/assets/niger.svg +1 -0
  987. package/assets/nigeria.svg +1 -0
  988. package/assets/niue.svg +1 -0
  989. package/assets/norfolk-island.svg +1 -0
  990. package/assets/north-korea.svg +1 -0
  991. package/assets/northern-marianas-islands.svg +1 -0
  992. package/assets/norway.svg +1 -0
  993. package/assets/note-sticky.svg +1 -0
  994. package/assets/notebook.svg +1 -0
  995. package/assets/notif-fill.svg +1 -0
  996. package/assets/notif-off-fill.svg +1 -0
  997. package/assets/notif-off.svg +1 -0
  998. package/assets/notif.svg +1 -0
  999. package/assets/objective_default.svg +1 -0
  1000. package/assets/objects-align-bottom.svg +1 -0
  1001. package/assets/objects-align-center-horizontal.svg +1 -0
  1002. package/assets/objects-align-center-vertical.svg +1 -0
  1003. package/assets/objects-align-left.svg +1 -0
  1004. package/assets/objects-align-right.svg +1 -0
  1005. package/assets/objects-align-top.svg +1 -0
  1006. package/assets/objects-column.svg +1 -0
  1007. package/assets/obz_color.svg +1 -0
  1008. package/assets/obz_elementary_color.svg +1 -0
  1009. package/assets/octagon.svg +1 -0
  1010. package/assets/ok-authorization.svg +1 -0
  1011. package/assets/ok-social-color.svg +1 -0
  1012. package/assets/ok-social.svg +1 -0
  1013. package/assets/olympiad_color.svg +1 -0
  1014. package/assets/oman.svg +1 -0
  1015. package/assets/outcome.svg +1 -0
  1016. package/assets/overline.svg +1 -0
  1017. package/assets/ovz_color.svg +1 -0
  1018. package/assets/page_default.svg +1 -0
  1019. package/assets/paint-roller.svg +1 -0
  1020. package/assets/paintbrush.svg +1 -0
  1021. package/assets/pakistan.svg +1 -0
  1022. package/assets/palau.svg +1 -0
  1023. package/assets/palestine.svg +1 -0
  1024. package/assets/palette-fill.svg +1 -0
  1025. package/assets/palette.svg +1 -0
  1026. package/assets/panama.svg +1 -0
  1027. package/assets/paperclip-slash.svg +1 -0
  1028. package/assets/paperclip.svg +1 -0
  1029. package/assets/papua-new-guinea.svg +1 -0
  1030. package/assets/paragraph.svg +1 -0
  1031. package/assets/paraguay.svg +1 -0
  1032. package/assets/parchment.svg +1 -0
  1033. package/assets/parent.svg +1 -0
  1034. package/assets/pause-circle.svg +1 -0
  1035. package/assets/pause-fill.svg +1 -0
  1036. package/assets/pause-square.svg +1 -0
  1037. package/assets/pause-thin-fill.svg +1 -0
  1038. package/assets/pause-thin.svg +1 -0
  1039. package/assets/pause.svg +1 -0
  1040. package/assets/pen-nib-off.svg +1 -0
  1041. package/assets/pen-nib.svg +1 -0
  1042. package/assets/pen-ruler.svg +1 -0
  1043. package/assets/pen-slash.svg +1 -0
  1044. package/assets/pen.svg +1 -0
  1045. package/assets/pencil-off.svg +1 -0
  1046. package/assets/pencil.svg +1 -0
  1047. package/assets/pencil_default.svg +1 -0
  1048. package/assets/pentagon.svg +1 -0
  1049. package/assets/people.svg +1 -0
  1050. package/assets/percentage.svg +1 -0
  1051. package/assets/person_default.svg +1 -0
  1052. package/assets/peru.svg +1 -0
  1053. package/assets/philippines.svg +1 -0
  1054. package/assets/phone-add.svg +1 -0
  1055. package/assets/phone-call.svg +1 -0
  1056. package/assets/phone-fill.svg +1 -0
  1057. package/assets/phone-flip.svg +1 -0
  1058. package/assets/phone-incoming.svg +1 -0
  1059. package/assets/phone-missed.svg +1 -0
  1060. package/assets/phone-office.svg +1 -0
  1061. package/assets/phone-outgoing.svg +1 -0
  1062. package/assets/phone-pause.svg +1 -0
  1063. package/assets/phone-received.svg +1 -0
  1064. package/assets/phone-remove.svg +1 -0
  1065. package/assets/phone-slash.svg +1 -0
  1066. package/assets/phone.svg +1 -0
  1067. package/assets/phoneNoFill_default.svg +1 -0
  1068. package/assets/phone_color.svg +1 -0
  1069. package/assets/phone_default.svg +1 -0
  1070. package/assets/photo-off.svg +1 -0
  1071. package/assets/photo.svg +1 -0
  1072. package/assets/physic_chemistry_color.svg +1 -0
  1073. package/assets/physics.svg +1 -0
  1074. package/assets/physics_color.svg +1 -0
  1075. package/assets/picture_color.svg +1 -0
  1076. package/assets/pin-fill.svg +1 -0
  1077. package/assets/pin-location.svg +1 -0
  1078. package/assets/pin.svg +1 -0
  1079. package/assets/pitcairn-islands.svg +1 -0
  1080. package/assets/play-circle.svg +1 -0
  1081. package/assets/play-fill.svg +1 -0
  1082. package/assets/play-pause.svg +1 -0
  1083. package/assets/play-square.svg +1 -0
  1084. package/assets/play.svg +1 -0
  1085. package/assets/playPause_default.svg +1 -0
  1086. package/assets/play_default.svg +1 -0
  1087. package/assets/plug.svg +1 -0
  1088. package/assets/plus-circle-fill.svg +1 -0
  1089. package/assets/plus-circle.svg +1 -0
  1090. package/assets/plus-fill.svg +1 -0
  1091. package/assets/plus-large-fill.svg +1 -0
  1092. package/assets/plus-large.svg +1 -0
  1093. package/assets/plus.svg +1 -0
  1094. package/assets/plusThin_default.svg +1 -0
  1095. package/assets/plus_default.svg +1 -0
  1096. package/assets/podcast.svg +1 -0
  1097. package/assets/podium.svg +1 -0
  1098. package/assets/pointer-down.svg +1 -0
  1099. package/assets/pointer-left.svg +1 -0
  1100. package/assets/pointer-right.svg +1 -0
  1101. package/assets/pointer-up.svg +1 -0
  1102. package/assets/poland.svg +1 -0
  1103. package/assets/portugal.svg +1 -0
  1104. package/assets/power-bank.svg +1 -0
  1105. package/assets/power-off-fill.svg +1 -0
  1106. package/assets/power-off.svg +1 -0
  1107. package/assets/present_default.svg +15 -0
  1108. package/assets/presentation-chart.svg +1 -0
  1109. package/assets/presentation.svg +1 -0
  1110. package/assets/previous-fast.svg +1 -0
  1111. package/assets/previous.svg +1 -0
  1112. package/assets/priceTag_default.svg +1 -0
  1113. package/assets/print.svg +1 -0
  1114. package/assets/print_color.svg +1 -0
  1115. package/assets/print_default.svg +1 -0
  1116. package/assets/product_pack_color.svg +1 -0
  1117. package/assets/prof_default.svg +1 -0
  1118. package/assets/program_color.svg +1 -0
  1119. package/assets/programming.svg +1 -0
  1120. package/assets/programming_color.svg +1 -0
  1121. package/assets/projector.svg +1 -0
  1122. package/assets/pronunciation_color.svg +1 -0
  1123. package/assets/psychology_color.svg +1 -0
  1124. package/assets/puerto-rico.svg +1 -0
  1125. package/assets/qatar.svg +1 -0
  1126. package/assets/questionFilled_default.svg +1 -0
  1127. package/assets/radar.svg +1 -0
  1128. package/assets/radioChecked_default.svg +1 -0
  1129. package/assets/radioNotChecked_default.svg +1 -0
  1130. package/assets/rap_and_culture_color.svg +1 -0
  1131. package/assets/reciept.svg +1 -0
  1132. package/assets/rectangle-code.svg +1 -0
  1133. package/assets/rectangle-terminal.svg +1 -0
  1134. package/assets/rectangle-vertical.svg +1 -0
  1135. package/assets/rectangle-wide.svg +1 -0
  1136. package/assets/rectangles-mixed-fill.svg +1 -0
  1137. package/assets/rectangles-mixed.svg +1 -0
  1138. package/assets/redo-fill.svg +1 -0
  1139. package/assets/redo.svg +1 -0
  1140. package/assets/refresh-clock.svg +1 -0
  1141. package/assets/refresh-fill.svg +1 -0
  1142. package/assets/refresh.svg +1 -0
  1143. package/assets/reload_default.svg +1 -0
  1144. package/assets/repeat-vertical.svg +1 -0
  1145. package/assets/repeat.svg +1 -0
  1146. package/assets/reply.svg +1 -0
  1147. package/assets/republic-of-macedonia.svg +1 -0
  1148. package/assets/republic-of-the_congo.svg +1 -0
  1149. package/assets/resize-handle.svg +1 -0
  1150. package/assets/rewinding-left.svg +1 -0
  1151. package/assets/rewinding-right.svg +1 -0
  1152. package/assets/rhombus.svg +1 -0
  1153. package/assets/right-alignment.svg +1 -0
  1154. package/assets/right-indent.svg +1 -0
  1155. package/assets/right-to-left-text-direction.svg +1 -0
  1156. package/assets/robot_color.svg +1 -0
  1157. package/assets/robotechnics_color.svg +1 -0
  1158. package/assets/rocket-fill.svg +1 -0
  1159. package/assets/rocket.svg +1 -0
  1160. package/assets/romania.svg +1 -0
  1161. package/assets/rotate-fill.svg +1 -0
  1162. package/assets/rotate-left-fill.svg +1 -0
  1163. package/assets/rotate-left.svg +1 -0
  1164. package/assets/rotate-right-fill.svg +1 -0
  1165. package/assets/rotate-right.svg +1 -0
  1166. package/assets/rotate.svg +1 -0
  1167. package/assets/route.svg +1 -0
  1168. package/assets/rss.svg +1 -0
  1169. package/assets/rus_native_language_color.svg +1 -0
  1170. package/assets/russia.svg +1 -0
  1171. package/assets/russian_color.svg +1 -0
  1172. package/assets/rwanda.svg +1 -0
  1173. package/assets/sahrawi-arab-democratic_republic.svg +1 -0
  1174. package/assets/samoa.svg +1 -0
  1175. package/assets/san-marino.svg +1 -0
  1176. package/assets/sao-tome-and_prince.svg +1 -0
  1177. package/assets/saudi-arabia.svg +1 -0
  1178. package/assets/sb-auth-mono-color.svg +1 -0
  1179. package/assets/sb-authorization.svg +1 -0
  1180. package/assets/scan.svg +1 -0
  1181. package/assets/school-bag.svg +1 -0
  1182. package/assets/school.svg +1 -0
  1183. package/assets/school_preparation_color.svg +1 -0
  1184. package/assets/school_preparing_color.svg +1 -0
  1185. package/assets/school_program_color.svg +1 -0
  1186. package/assets/scissors.svg +1 -0
  1187. package/assets/scotland.svg +1 -0
  1188. package/assets/screen-export.svg +1 -0
  1189. package/assets/screen-import.svg +1 -0
  1190. package/assets/screen-remove.svg +1 -0
  1191. package/assets/screen-sharing.svg +1 -0
  1192. package/assets/screen.svg +1 -0
  1193. package/assets/screencast.svg +1 -0
  1194. package/assets/scribble.svg +1 -0
  1195. package/assets/seal.svg +1 -0
  1196. package/assets/search-out.svg +1 -0
  1197. package/assets/search-zoom.svg +1 -0
  1198. package/assets/search.svg +1 -0
  1199. package/assets/search_default.svg +1 -0
  1200. package/assets/seconds-10-right.svg +1 -0
  1201. package/assets/seconds-10.svg +1 -0
  1202. package/assets/seconds-15-right.svg +1 -0
  1203. package/assets/seconds-15.svg +1 -0
  1204. package/assets/seconds-5-right.svg +1 -0
  1205. package/assets/seconds-5.svg +1 -0
  1206. package/assets/send-angle.svg +1 -0
  1207. package/assets/send-forward.svg +1 -0
  1208. package/assets/send.svg +1 -0
  1209. package/assets/sending-left.svg +1 -0
  1210. package/assets/sending-right.svg +1 -0
  1211. package/assets/senegal.svg +1 -0
  1212. package/assets/serbia.svg +1 -0
  1213. package/assets/server.svg +1 -0
  1214. package/assets/server_color.svg +1 -0
  1215. package/assets/settings-fill.svg +1 -0
  1216. package/assets/settings.svg +1 -0
  1217. package/assets/settings_1_color.svg +1 -0
  1218. package/assets/settings_2_color.svg +1 -0
  1219. package/assets/settings_3_color.svg +1 -0
  1220. package/assets/settings_default.svg +1 -0
  1221. package/assets/seychelles.svg +1 -0
  1222. package/assets/shapes.svg +1 -0
  1223. package/assets/share-fill.svg +1 -0
  1224. package/assets/share.svg +1 -0
  1225. package/assets/sharpCross_default.svg +1 -0
  1226. package/assets/shield-check.svg +1 -0
  1227. package/assets/shield-error.svg +1 -0
  1228. package/assets/shield-keyhole.svg +1 -0
  1229. package/assets/shield-minus.svg +1 -0
  1230. package/assets/shield-plus.svg +1 -0
  1231. package/assets/shield-slash.svg +1 -0
  1232. package/assets/shield-warning.svg +1 -0
  1233. package/assets/shield.svg +1 -0
  1234. package/assets/shop.svg +1 -0
  1235. package/assets/shopping_color.svg +1 -0
  1236. package/assets/sidebar.svg +1 -0
  1237. package/assets/sierra-leone.svg +1 -0
  1238. package/assets/sigma.svg +1 -0
  1239. package/assets/signal-off.svg +1 -0
  1240. package/assets/signal-steam-off.svg +1 -0
  1241. package/assets/signal-steam-warning.svg +1 -0
  1242. package/assets/signal-steam.svg +1 -0
  1243. package/assets/signal-warning.svg +1 -0
  1244. package/assets/signal.svg +1 -0
  1245. package/assets/signature.svg +1 -0
  1246. package/assets/singapore.svg +1 -0
  1247. package/assets/sint-maarten.svg +1 -0
  1248. package/assets/slash-flip.svg +1 -0
  1249. package/assets/slash.svg +1 -0
  1250. package/assets/slide.svg +1 -0
  1251. package/assets/sliders.svg +1 -0
  1252. package/assets/slovakia.svg +1 -0
  1253. package/assets/slovenia.svg +1 -0
  1254. package/assets/social_color.svg +1 -0
  1255. package/assets/social_elementary_color.svg +1 -0
  1256. package/assets/social_sciences_color.svg +1 -0
  1257. package/assets/solomon-islands.svg +1 -0
  1258. package/assets/somalia.svg +1 -0
  1259. package/assets/sort-amount-down.svg +1 -0
  1260. package/assets/sort-amount-up.svg +1 -0
  1261. package/assets/sort-down-fill.svg +1 -0
  1262. package/assets/sort-down.svg +1 -0
  1263. package/assets/sort-fill.svg +1 -0
  1264. package/assets/sort-up-fill.svg +1 -0
  1265. package/assets/sort-up.svg +1 -0
  1266. package/assets/sort.svg +1 -0
  1267. package/assets/sort_default.svg +1 -0
  1268. package/assets/south-africa.svg +1 -0
  1269. package/assets/south-korea.svg +1 -0
  1270. package/assets/south-sudan.svg +1 -0
  1271. package/assets/spain.svg +1 -0
  1272. package/assets/spanish_color.svg +1 -0
  1273. package/assets/spell-check.svg +1 -0
  1274. package/assets/spelling_color.svg +1 -0
  1275. package/assets/sport.svg +1 -0
  1276. package/assets/square-a-lock.svg +1 -0
  1277. package/assets/square-check-fill.svg +1 -0
  1278. package/assets/square-check.svg +1 -0
  1279. package/assets/square-code.svg +1 -0
  1280. package/assets/square-dashed.svg +1 -0
  1281. package/assets/square-dazzle.svg +1 -0
  1282. package/assets/square-kanban.svg +1 -0
  1283. package/assets/square-list.svg +1 -0
  1284. package/assets/square-minus-fill.svg +1 -0
  1285. package/assets/square-minus.svg +1 -0
  1286. package/assets/square-poll-horizontal.svg +1 -0
  1287. package/assets/square-poll-vertical.svg +1 -0
  1288. package/assets/square-quarters.svg +1 -0
  1289. package/assets/square-ring.svg +1 -0
  1290. package/assets/square-small.svg +1 -0
  1291. package/assets/square-t.svg +1 -0
  1292. package/assets/square-terminal.svg +1 -0
  1293. package/assets/square.svg +1 -0
  1294. package/assets/sri-lanka.svg +1 -0
  1295. package/assets/st-barts.svg +1 -0
  1296. package/assets/st-lucia.svg +1 -0
  1297. package/assets/st-vincent-and-the-grenadines.svg +1 -0
  1298. package/assets/star-blink.svg +1 -0
  1299. package/assets/star-circle.svg +1 -0
  1300. package/assets/star-fill.svg +1 -0
  1301. package/assets/star-half-stroke.svg +1 -0
  1302. package/assets/star-half.svg +1 -0
  1303. package/assets/star-sparkle.svg +1 -0
  1304. package/assets/star-warning.svg +1 -0
  1305. package/assets/star.svg +1 -0
  1306. package/assets/star_default.svg +1 -0
  1307. package/assets/stars.svg +1 -0
  1308. package/assets/stopwatch.svg +1 -0
  1309. package/assets/strikethrough.svg +1 -0
  1310. package/assets/structure.svg +1 -0
  1311. package/assets/student-fill.svg +1 -0
  1312. package/assets/student.svg +1 -0
  1313. package/assets/student_default.svg +1 -0
  1314. package/assets/subdirectory.svg +1 -0
  1315. package/assets/subscript.svg +1 -0
  1316. package/assets/sudan.svg +1 -0
  1317. package/assets/superscript.svg +1 -0
  1318. package/assets/support.svg +1 -0
  1319. package/assets/suriname.svg +1 -0
  1320. package/assets/swaziland.svg +1 -0
  1321. package/assets/sweden.svg +1 -0
  1322. package/assets/switch-horizontal.svg +1 -0
  1323. package/assets/switch-vertical.svg +1 -0
  1324. package/assets/switzerland.svg +1 -0
  1325. package/assets/syria.svg +1 -0
  1326. package/assets/t-bank-authorization.svg +1 -0
  1327. package/assets/table-cells-large.svg +1 -0
  1328. package/assets/table-cells.svg +1 -0
  1329. package/assets/table-columns.svg +1 -0
  1330. package/assets/table-layout.svg +1 -0
  1331. package/assets/table-list.svg +1 -0
  1332. package/assets/table-rows.svg +1 -0
  1333. package/assets/table.svg +1 -0
  1334. package/assets/tablet.svg +1 -0
  1335. package/assets/tag-fill.svg +1 -0
  1336. package/assets/tag.svg +1 -0
  1337. package/assets/tags-fill.svg +1 -0
  1338. package/assets/tags.svg +1 -0
  1339. package/assets/taiwan.svg +1 -0
  1340. package/assets/tajikistan.svg +1 -0
  1341. package/assets/tanzania.svg +1 -0
  1342. package/assets/target_default.svg +1 -0
  1343. package/assets/task-fill.svg +1 -0
  1344. package/assets/task.svg +1 -0
  1345. package/assets/tasks_color.svg +1 -0
  1346. package/assets/tasks_default.svg +4 -0
  1347. package/assets/tbank-auth-mono-color.svg +1 -0
  1348. package/assets/teacher.svg +1 -0
  1349. package/assets/technology_color.svg +1 -0
  1350. package/assets/telegram-social-color.svg +1 -0
  1351. package/assets/telegram-social.svg +1 -0
  1352. package/assets/terminal.svg +1 -0
  1353. package/assets/terminal_color.svg +1 -0
  1354. package/assets/test.svg +1 -0
  1355. package/assets/test_color.svg +1 -0
  1356. package/assets/text-big.svg +1 -0
  1357. package/assets/text-erase.svg +1 -0
  1358. package/assets/text-height.svg +1 -0
  1359. package/assets/text-move-left.svg +1 -0
  1360. package/assets/text-move-right.svg +1 -0
  1361. package/assets/text-note.svg +1 -0
  1362. package/assets/text-size.svg +1 -0
  1363. package/assets/text-small.svg +1 -0
  1364. package/assets/text-width.svg +1 -0
  1365. package/assets/text.svg +1 -0
  1366. package/assets/textbook_color.svg +1 -0
  1367. package/assets/textbook_default.svg +1 -0
  1368. package/assets/thailand.svg +1 -0
  1369. package/assets/theory_color.svg +1 -0
  1370. package/assets/ticket-simple.svg +1 -0
  1371. package/assets/tiktok-social.svg +1 -0
  1372. package/assets/time-off.svg +1 -0
  1373. package/assets/timer.svg +1 -0
  1374. package/assets/tinkoff-authorization.svg +1 -0
  1375. package/assets/tinyCross_default.svg +1 -0
  1376. package/assets/togo.svg +1 -0
  1377. package/assets/tokelau.svg +1 -0
  1378. package/assets/tonga.svg +1 -0
  1379. package/assets/top-alignment.svg +1 -0
  1380. package/assets/train.svg +1 -0
  1381. package/assets/training_color.svg +1 -0
  1382. package/assets/translate_color.svg +1 -0
  1383. package/assets/trash-arrow-up-fill.svg +1 -0
  1384. package/assets/trash-arrow-up.svg +1 -0
  1385. package/assets/trash-blank-fill.svg +1 -0
  1386. package/assets/trash-blank.svg +1 -0
  1387. package/assets/trash-check-fill.svg +1 -0
  1388. package/assets/trash-check.svg +1 -0
  1389. package/assets/trash-clock.svg +1 -0
  1390. package/assets/trash-fill.svg +1 -0
  1391. package/assets/trash-list-fill.svg +1 -0
  1392. package/assets/trash-list.svg +1 -0
  1393. package/assets/trash-plus-fill.svg +1 -0
  1394. package/assets/trash-plus.svg +1 -0
  1395. package/assets/trash-slash-fill.svg +1 -0
  1396. package/assets/trash-slash.svg +1 -0
  1397. package/assets/trash-undo-fill.svg +1 -0
  1398. package/assets/trash-undo.svg +1 -0
  1399. package/assets/trash-xmark-fill.svg +1 -0
  1400. package/assets/trash-xmark.svg +1 -0
  1401. package/assets/trash.svg +1 -0
  1402. package/assets/triangle.svg +1 -0
  1403. package/assets/trinidad-and-tobago.svg +1 -0
  1404. package/assets/trophy.svg +1 -0
  1405. package/assets/trophy_color.svg +1 -0
  1406. package/assets/trophy_default.svg +1 -0
  1407. package/assets/tunisia.svg +1 -0
  1408. package/assets/turkey.svg +1 -0
  1409. package/assets/turkmenistan.svg +1 -0
  1410. package/assets/turks-and-caicos.svg +1 -0
  1411. package/assets/tutor_color.svg +1 -0
  1412. package/assets/tuvalu.svg +1 -0
  1413. package/assets/tv.svg +1 -0
  1414. package/assets/twenty-thirty-five-authorization.svg +1 -0
  1415. package/assets/uganda.svg +1 -0
  1416. package/assets/ukraine.svg +1 -0
  1417. package/assets/un2035-auth-mono-color.svg +1 -0
  1418. package/assets/underline.svg +1 -0
  1419. package/assets/undo-fill.svg +1 -0
  1420. package/assets/undo.svg +1 -0
  1421. package/assets/united-arab-emirates.svg +1 -0
  1422. package/assets/united-kingdom.svg +1 -0
  1423. package/assets/united-states.svg +1 -0
  1424. package/assets/university.svg +1 -0
  1425. package/assets/unlock.svg +1 -0
  1426. package/assets/unsort_default.svg +1 -0
  1427. package/assets/upload-fill.svg +1 -0
  1428. package/assets/upload.svg +1 -0
  1429. package/assets/uruguay.svg +1 -0
  1430. package/assets/usb-flash-drive.svg +1 -0
  1431. package/assets/user-add.svg +1 -0
  1432. package/assets/user-block.svg +1 -0
  1433. package/assets/user-circle.svg +1 -0
  1434. package/assets/user-edit.svg +1 -0
  1435. package/assets/user-heart.svg +1 -0
  1436. package/assets/user-lock.svg +1 -0
  1437. package/assets/user-minus.svg +1 -0
  1438. package/assets/user-question.svg +1 -0
  1439. package/assets/user-remove.svg +1 -0
  1440. package/assets/user-square.svg +1 -0
  1441. package/assets/user-tick.svg +1 -0
  1442. package/assets/user.svg +1 -0
  1443. package/assets/users-fill.svg +1 -0
  1444. package/assets/users.svg +1 -0
  1445. package/assets/uzbekistan.svg +1 -0
  1446. package/assets/vanuatu.svg +1 -0
  1447. package/assets/vatican-city.svg +1 -0
  1448. package/assets/vault.svg +1 -0
  1449. package/assets/venezuela.svg +1 -0
  1450. package/assets/video-add.svg +1 -0
  1451. package/assets/video-export.svg +1 -0
  1452. package/assets/video-fill.svg +1 -0
  1453. package/assets/video-import.svg +1 -0
  1454. package/assets/video-slash-fill.svg +1 -0
  1455. package/assets/video_default.svg +1 -0
  1456. package/assets/vietnam.svg +1 -0
  1457. package/assets/virgin-islands.svg +1 -0
  1458. package/assets/vk-auth-mono-color.svg +1 -0
  1459. package/assets/vk-authorization.svg +1 -0
  1460. package/assets/vk-social-color.svg +1 -0
  1461. package/assets/vk-social.svg +1 -0
  1462. package/assets/voicemail.svg +1 -0
  1463. package/assets/volume-add.svg +1 -0
  1464. package/assets/volume-min.svg +1 -0
  1465. package/assets/volume-minus.svg +1 -0
  1466. package/assets/volume-off.svg +1 -0
  1467. package/assets/volume-remove.svg +1 -0
  1468. package/assets/volume.svg +1 -0
  1469. package/assets/wales.svg +1 -0
  1470. package/assets/wallet-add.svg +1 -0
  1471. package/assets/wallet-remove.svg +1 -0
  1472. package/assets/wallet-transfer.svg +1 -0
  1473. package/assets/wallet.svg +1 -0
  1474. package/assets/wallet_default.svg +1 -0
  1475. package/assets/wand-magic-sparkles.svg +1 -0
  1476. package/assets/wand-magic.svg +1 -0
  1477. package/assets/warning-circle-check.svg +1 -0
  1478. package/assets/warning-circle-fill.svg +1 -0
  1479. package/assets/warning-circle.svg +1 -0
  1480. package/assets/warning-seal-fill.svg +1 -0
  1481. package/assets/warning-seal.svg +1 -0
  1482. package/assets/warning-triangle-fill.svg +1 -0
  1483. package/assets/warning-triangle.svg +1 -0
  1484. package/assets/warning.svg +1 -0
  1485. package/assets/watch.svg +1 -0
  1486. package/assets/webcam-slash-off.svg +1 -0
  1487. package/assets/webcam.svg +1 -0
  1488. package/assets/weight.svg +1 -0
  1489. package/assets/whatsapp-social-color.svg +1 -0
  1490. package/assets/whatsapp-social-fill.svg +1 -0
  1491. package/assets/whatsapp-social.svg +1 -0
  1492. package/assets/wifi-off.svg +1 -0
  1493. package/assets/wifi-warning.svg +1 -0
  1494. package/assets/wifi.svg +1 -0
  1495. package/assets/window.svg +1 -0
  1496. package/assets/work.svg +1 -0
  1497. package/assets/world_color.svg +1 -0
  1498. package/assets/world_elementary_color.svg +1 -0
  1499. package/assets/yandex-auth-mono-color.svg +1 -0
  1500. package/assets/yandex-authorization.svg +1 -0
  1501. package/assets/yemen.svg +1 -0
  1502. package/assets/youtube-alt-social-color.svg +1 -0
  1503. package/assets/youtube-alt-social.svg +1 -0
  1504. package/assets/youtube-social.svg +1 -0
  1505. package/assets/zambia.svg +1 -0
  1506. package/assets/zimbabwe.svg +1 -0
  1507. package/components/AccordionItem/AccordionItem.js +1 -1
  1508. package/components/AccordionItem/AccordionItem.js.map +1 -1
  1509. package/components/AccordionItem/AccordionItem.mjs +1 -1
  1510. package/components/AccordionItem/AccordionItem.mjs.map +1 -1
  1511. package/components/AddElement/AddElement.js +2 -0
  1512. package/components/AddElement/AddElement.js.map +1 -0
  1513. package/components/AddElement/AddElement.mjs +2 -0
  1514. package/components/AddElement/AddElement.mjs.map +1 -0
  1515. package/components/AddElement/sizes.js +2 -0
  1516. package/components/AddElement/sizes.js.map +1 -0
  1517. package/components/AddElement/sizes.mjs +2 -0
  1518. package/components/AddElement/sizes.mjs.map +1 -0
  1519. package/components/AddElement/style.js +2 -0
  1520. package/components/AddElement/style.js.map +1 -0
  1521. package/components/AddElement/style.mjs +2 -0
  1522. package/components/AddElement/style.mjs.map +1 -0
  1523. package/components/Alert/Alert.js +1 -1
  1524. package/components/Alert/Alert.js.map +1 -1
  1525. package/components/Alert/Alert.mjs +1 -1
  1526. package/components/Alert/Alert.mjs.map +1 -1
  1527. package/components/Arrow/Arrow.js +1 -1
  1528. package/components/Arrow/Arrow.js.map +1 -1
  1529. package/components/Arrow/Arrow.mjs +1 -1
  1530. package/components/Arrow/Arrow.mjs.map +1 -1
  1531. package/components/Button/Button.js +1 -1
  1532. package/components/Button/Button.js.map +1 -1
  1533. package/components/Button/Button.mjs +1 -1
  1534. package/components/Button/Button.mjs.map +1 -1
  1535. package/components/Checkbox/images/check-default.svg.js +2 -0
  1536. package/components/Checkbox/images/check-default.svg.js.map +1 -0
  1537. package/components/Checkbox/images/check-default.svg.mjs +2 -0
  1538. package/components/Checkbox/images/check-default.svg.mjs.map +1 -0
  1539. package/components/Checkbox/images/check.svg.js +2 -0
  1540. package/components/Checkbox/images/check.svg.js.map +1 -0
  1541. package/components/Checkbox/images/check.svg.mjs +2 -0
  1542. package/components/Checkbox/images/check.svg.mjs.map +1 -0
  1543. package/components/Checkbox/style.js +1 -1
  1544. package/components/Checkbox/style.js.map +1 -1
  1545. package/components/Checkbox/style.mjs +1 -1
  1546. package/components/Checkbox/style.mjs.map +1 -1
  1547. package/components/Chip/Chip.js +1 -1
  1548. package/components/Chip/Chip.js.map +1 -1
  1549. package/components/Chip/Chip.mjs +1 -1
  1550. package/components/Chip/Chip.mjs.map +1 -1
  1551. package/components/DialogComponent/DialogComponent.js +1 -1
  1552. package/components/DialogComponent/DialogComponent.js.map +1 -1
  1553. package/components/DialogComponent/DialogComponent.mjs +1 -1
  1554. package/components/DialogComponent/DialogComponent.mjs.map +1 -1
  1555. package/components/Dropdown/Dropdown.js +1 -1
  1556. package/components/Dropdown/Dropdown.js.map +1 -1
  1557. package/components/Dropdown/Dropdown.mjs +1 -1
  1558. package/components/Dropdown/Dropdown.mjs.map +1 -1
  1559. package/components/Dropdown/DropdownMenuNoOptions.js +1 -1
  1560. package/components/Dropdown/DropdownMenuNoOptions.js.map +1 -1
  1561. package/components/Dropdown/DropdownMenuNoOptions.mjs +1 -1
  1562. package/components/Dropdown/DropdownMenuNoOptions.mjs.map +1 -1
  1563. package/components/Dropdown/style.js +1 -1
  1564. package/components/Dropdown/style.js.map +1 -1
  1565. package/components/Dropdown/style.mjs +1 -1
  1566. package/components/Dropdown/style.mjs.map +1 -1
  1567. package/components/FormLabel/FormLabel.js +1 -1
  1568. package/components/FormLabel/FormLabel.js.map +1 -1
  1569. package/components/FormLabel/FormLabel.mjs +1 -1
  1570. package/components/FormLabel/FormLabel.mjs.map +1 -1
  1571. package/components/Icon/Icon.js +1 -1
  1572. package/components/Icon/Icon.js.map +1 -1
  1573. package/components/Icon/Icon.mjs +1 -1
  1574. package/components/Icon/Icon.mjs.map +1 -1
  1575. package/components/Icon/bg-worker.js +2 -0
  1576. package/components/Icon/bg-worker.js.map +1 -0
  1577. package/components/Icon/bg-worker.mjs +2 -0
  1578. package/components/Icon/bg-worker.mjs.map +1 -0
  1579. package/components/Icon/constants.js +2 -0
  1580. package/components/Icon/constants.js.map +1 -0
  1581. package/components/Icon/constants.mjs +2 -0
  1582. package/components/Icon/constants.mjs.map +1 -0
  1583. package/components/Icon/list/default.js +2 -0
  1584. package/components/Icon/list/default.js.map +1 -0
  1585. package/components/Icon/list/default.mjs +2 -0
  1586. package/components/Icon/list/default.mjs.map +1 -0
  1587. package/components/Icon/list/icon-pack.js +2 -0
  1588. package/components/Icon/list/icon-pack.js.map +1 -0
  1589. package/components/Icon/list/icon-pack.mjs +2 -0
  1590. package/components/Icon/list/icon-pack.mjs.map +1 -0
  1591. package/components/Icon/list/index.js +2 -0
  1592. package/components/Icon/list/index.js.map +1 -0
  1593. package/components/Icon/list/index.mjs +2 -0
  1594. package/components/Icon/list/index.mjs.map +1 -0
  1595. package/components/Icon/style.js +1 -1
  1596. package/components/Icon/style.js.map +1 -1
  1597. package/components/Icon/style.mjs +1 -1
  1598. package/components/Icon/style.mjs.map +1 -1
  1599. package/components/Input/Input.js +1 -1
  1600. package/components/Input/Input.js.map +1 -1
  1601. package/components/Input/Input.mjs +1 -1
  1602. package/components/Input/Input.mjs.map +1 -1
  1603. package/components/InputCheckbox/images/checked.svg.js +2 -0
  1604. package/components/InputCheckbox/images/checked.svg.js.map +1 -0
  1605. package/components/InputCheckbox/images/checked.svg.mjs +2 -0
  1606. package/components/InputCheckbox/images/checked.svg.mjs.map +1 -0
  1607. package/components/InputCheckbox/images/indeterminate.svg.js +2 -0
  1608. package/components/InputCheckbox/images/indeterminate.svg.js.map +1 -0
  1609. package/components/InputCheckbox/images/indeterminate.svg.mjs +2 -0
  1610. package/components/InputCheckbox/images/indeterminate.svg.mjs.map +1 -0
  1611. package/components/InputCheckbox/style.js +1 -1
  1612. package/components/InputCheckbox/style.js.map +1 -1
  1613. package/components/InputCheckbox/style.mjs +1 -1
  1614. package/components/InputCheckbox/style.mjs.map +1 -1
  1615. package/components/MenuContainer/MenuContainer.js +1 -1
  1616. package/components/MenuContainer/MenuContainer.js.map +1 -1
  1617. package/components/MenuContainer/MenuContainer.mjs +1 -1
  1618. package/components/MenuContainer/MenuContainer.mjs.map +1 -1
  1619. package/components/Modal/Close.js +1 -1
  1620. package/components/Modal/Close.js.map +1 -1
  1621. package/components/Modal/Close.mjs +1 -1
  1622. package/components/Modal/Close.mjs.map +1 -1
  1623. package/components/Notification/Notification.js +1 -1
  1624. package/components/Notification/Notification.js.map +1 -1
  1625. package/components/Notification/Notification.mjs +1 -1
  1626. package/components/Notification/Notification.mjs.map +1 -1
  1627. package/components/Notification/constants.js +1 -1
  1628. package/components/Notification/constants.js.map +1 -1
  1629. package/components/Notification/constants.mjs +1 -1
  1630. package/components/Notification/constants.mjs.map +1 -1
  1631. package/components/PopoverComponent/PopoverComponent.js +1 -1
  1632. package/components/PopoverComponent/PopoverComponent.js.map +1 -1
  1633. package/components/PopoverComponent/PopoverComponent.mjs +1 -1
  1634. package/components/PopoverComponent/PopoverComponent.mjs.map +1 -1
  1635. package/components/ProgressLine/ProgressLine.js +1 -1
  1636. package/components/ProgressLine/ProgressLine.js.map +1 -1
  1637. package/components/ProgressLine/ProgressLine.mjs +1 -1
  1638. package/components/ProgressLine/ProgressLine.mjs.map +1 -1
  1639. package/components/ProgressLine/style.js +1 -1
  1640. package/components/ProgressLine/style.js.map +1 -1
  1641. package/components/ProgressLine/style.mjs +1 -1
  1642. package/components/ProgressLine/style.mjs.map +1 -1
  1643. package/components/TabList/TabList.js +1 -1
  1644. package/components/TabList/TabList.js.map +1 -1
  1645. package/components/TabList/TabList.mjs +1 -1
  1646. package/components/TabList/TabList.mjs.map +1 -1
  1647. package/components/TabList/TabListMenuTab.js +1 -1
  1648. package/components/TabList/TabListMenuTab.js.map +1 -1
  1649. package/components/TabList/TabListMenuTab.mjs +1 -1
  1650. package/components/TabList/TabListMenuTab.mjs.map +1 -1
  1651. package/components/Textarea/Textarea.js +1 -1
  1652. package/components/Textarea/Textarea.js.map +1 -1
  1653. package/components/Textarea/Textarea.mjs +1 -1
  1654. package/components/Textarea/Textarea.mjs.map +1 -1
  1655. package/components/TooltipComponent/TooltipComponent.js +1 -1
  1656. package/components/TooltipComponent/TooltipComponent.js.map +1 -1
  1657. package/components/TooltipComponent/TooltipComponent.mjs +1 -1
  1658. package/components/TooltipComponent/TooltipComponent.mjs.map +1 -1
  1659. package/dts/index.d.ts +463 -2050
  1660. package/index.js +1 -1
  1661. package/index.mjs +1 -1
  1662. package/package.json +9 -4
  1663. package/shared/utils/isNil.js +2 -0
  1664. package/shared/utils/isNil.js.map +1 -0
  1665. package/shared/utils/isNil.mjs +2 -0
  1666. package/shared/utils/isNil.mjs.map +1 -0
  1667. package/components/Arrow/images/chevronUpDefault.svg.js +0 -2
  1668. package/components/Arrow/images/chevronUpDefault.svg.js.map +0 -1
  1669. package/components/Arrow/images/chevronUpDefault.svg.mjs +0 -2
  1670. package/components/Arrow/images/chevronUpDefault.svg.mjs.map +0 -1
  1671. package/components/Checkbox/images/checkDefault.svg.js +0 -2
  1672. package/components/Checkbox/images/checkDefault.svg.js.map +0 -1
  1673. package/components/Checkbox/images/checkDefault.svg.mjs +0 -2
  1674. package/components/Checkbox/images/checkDefault.svg.mjs.map +0 -1
  1675. package/components/Icon/iconPack.js +0 -2
  1676. package/components/Icon/iconPack.js.map +0 -1
  1677. package/components/Icon/iconPack.mjs +0 -2
  1678. package/components/Icon/iconPack.mjs.map +0 -1
  1679. package/components/Icon/iconsDefault.js +0 -2
  1680. package/components/Icon/iconsDefault.js.map +0 -1
  1681. package/components/Icon/iconsDefault.mjs +0 -2
  1682. package/components/Icon/iconsDefault.mjs.map +0 -1
  1683. package/components/Icon/images/blackBoard_default.svg.js +0 -2
  1684. package/components/Icon/images/blackBoard_default.svg.js.map +0 -1
  1685. package/components/Icon/images/blackBoard_default.svg.mjs +0 -2
  1686. package/components/Icon/images/blackBoard_default.svg.mjs.map +0 -1
  1687. package/components/Icon/images/book_default.svg.js +0 -2
  1688. package/components/Icon/images/book_default.svg.js.map +0 -1
  1689. package/components/Icon/images/book_default.svg.mjs +0 -2
  1690. package/components/Icon/images/book_default.svg.mjs.map +0 -1
  1691. package/components/Icon/images/burger_default.svg.js +0 -2
  1692. package/components/Icon/images/burger_default.svg.js.map +0 -1
  1693. package/components/Icon/images/burger_default.svg.mjs +0 -2
  1694. package/components/Icon/images/burger_default.svg.mjs.map +0 -1
  1695. package/components/Icon/images/calendar_default.svg.js +0 -2
  1696. package/components/Icon/images/calendar_default.svg.js.map +0 -1
  1697. package/components/Icon/images/calendar_default.svg.mjs +0 -2
  1698. package/components/Icon/images/calendar_default.svg.mjs.map +0 -1
  1699. package/components/Icon/images/calendar_simple_default.svg.js +0 -2
  1700. package/components/Icon/images/calendar_simple_default.svg.js.map +0 -1
  1701. package/components/Icon/images/calendar_simple_default.svg.mjs +0 -2
  1702. package/components/Icon/images/calendar_simple_default.svg.mjs.map +0 -1
  1703. package/components/Icon/images/camps_default.svg.js +0 -2
  1704. package/components/Icon/images/camps_default.svg.js.map +0 -1
  1705. package/components/Icon/images/camps_default.svg.mjs +0 -2
  1706. package/components/Icon/images/camps_default.svg.mjs.map +0 -1
  1707. package/components/Icon/images/cancel_default.svg.js +0 -2
  1708. package/components/Icon/images/cancel_default.svg.js.map +0 -1
  1709. package/components/Icon/images/cancel_default.svg.mjs +0 -2
  1710. package/components/Icon/images/cancel_default.svg.mjs.map +0 -1
  1711. package/components/Icon/images/cart_default.svg.js +0 -2
  1712. package/components/Icon/images/cart_default.svg.js.map +0 -1
  1713. package/components/Icon/images/cart_default.svg.mjs +0 -2
  1714. package/components/Icon/images/cart_default.svg.mjs.map +0 -1
  1715. package/components/Icon/images/checkCircle_default.svg.js +0 -2
  1716. package/components/Icon/images/checkCircle_default.svg.js.map +0 -1
  1717. package/components/Icon/images/checkCircle_default.svg.mjs +0 -2
  1718. package/components/Icon/images/checkCircle_default.svg.mjs.map +0 -1
  1719. package/components/Icon/images/check_default.svg.js +0 -2
  1720. package/components/Icon/images/check_default.svg.js.map +0 -1
  1721. package/components/Icon/images/check_default.svg.mjs +0 -2
  1722. package/components/Icon/images/check_default.svg.mjs.map +0 -1
  1723. package/components/Icon/images/chevronDown_default.svg.js +0 -2
  1724. package/components/Icon/images/chevronDown_default.svg.js.map +0 -1
  1725. package/components/Icon/images/chevronDown_default.svg.mjs +0 -2
  1726. package/components/Icon/images/chevronDown_default.svg.mjs.map +0 -1
  1727. package/components/Icon/images/chevronLeft_default.svg.js +0 -2
  1728. package/components/Icon/images/chevronLeft_default.svg.js.map +0 -1
  1729. package/components/Icon/images/chevronLeft_default.svg.mjs +0 -2
  1730. package/components/Icon/images/chevronLeft_default.svg.mjs.map +0 -1
  1731. package/components/Icon/images/chevronRight_default.svg.js +0 -2
  1732. package/components/Icon/images/chevronRight_default.svg.js.map +0 -1
  1733. package/components/Icon/images/chevronRight_default.svg.mjs +0 -2
  1734. package/components/Icon/images/chevronRight_default.svg.mjs.map +0 -1
  1735. package/components/Icon/images/chevronUp_default.svg.js +0 -2
  1736. package/components/Icon/images/chevronUp_default.svg.js.map +0 -1
  1737. package/components/Icon/images/chevronUp_default.svg.mjs +0 -2
  1738. package/components/Icon/images/chevronUp_default.svg.mjs.map +0 -1
  1739. package/components/Icon/images/clockFilled_default.svg.js +0 -2
  1740. package/components/Icon/images/clockFilled_default.svg.js.map +0 -1
  1741. package/components/Icon/images/clockFilled_default.svg.mjs +0 -2
  1742. package/components/Icon/images/clockFilled_default.svg.mjs.map +0 -1
  1743. package/components/Icon/images/clock_default.svg.js +0 -2
  1744. package/components/Icon/images/clock_default.svg.js.map +0 -1
  1745. package/components/Icon/images/clock_default.svg.mjs +0 -2
  1746. package/components/Icon/images/clock_default.svg.mjs.map +0 -1
  1747. package/components/Icon/images/coins_default.svg.js +0 -2
  1748. package/components/Icon/images/coins_default.svg.js.map +0 -1
  1749. package/components/Icon/images/coins_default.svg.mjs +0 -2
  1750. package/components/Icon/images/coins_default.svg.mjs.map +0 -1
  1751. package/components/Icon/images/copy_default.svg.js +0 -2
  1752. package/components/Icon/images/copy_default.svg.js.map +0 -1
  1753. package/components/Icon/images/copy_default.svg.mjs +0 -2
  1754. package/components/Icon/images/copy_default.svg.mjs.map +0 -1
  1755. package/components/Icon/images/courses_default.svg.js +0 -2
  1756. package/components/Icon/images/courses_default.svg.js.map +0 -1
  1757. package/components/Icon/images/courses_default.svg.mjs +0 -2
  1758. package/components/Icon/images/courses_default.svg.mjs.map +0 -1
  1759. package/components/Icon/images/cross_default.svg.js +0 -2
  1760. package/components/Icon/images/cross_default.svg.js.map +0 -1
  1761. package/components/Icon/images/cross_default.svg.mjs +0 -2
  1762. package/components/Icon/images/cross_default.svg.mjs.map +0 -1
  1763. package/components/Icon/images/dialog_default.svg.js +0 -2
  1764. package/components/Icon/images/dialog_default.svg.js.map +0 -1
  1765. package/components/Icon/images/dialog_default.svg.mjs +0 -2
  1766. package/components/Icon/images/dialog_default.svg.mjs.map +0 -1
  1767. package/components/Icon/images/diamondFilled_default.svg.js +0 -2
  1768. package/components/Icon/images/diamondFilled_default.svg.js.map +0 -1
  1769. package/components/Icon/images/diamondFilled_default.svg.mjs +0 -2
  1770. package/components/Icon/images/diamondFilled_default.svg.mjs.map +0 -1
  1771. package/components/Icon/images/diamond_default.svg.js +0 -2
  1772. package/components/Icon/images/diamond_default.svg.js.map +0 -1
  1773. package/components/Icon/images/diamond_default.svg.mjs +0 -2
  1774. package/components/Icon/images/diamond_default.svg.mjs.map +0 -1
  1775. package/components/Icon/images/discount_default.svg.js +0 -2
  1776. package/components/Icon/images/discount_default.svg.js.map +0 -1
  1777. package/components/Icon/images/discount_default.svg.mjs +0 -2
  1778. package/components/Icon/images/discount_default.svg.mjs.map +0 -1
  1779. package/components/Icon/images/document_default.svg.js +0 -2
  1780. package/components/Icon/images/document_default.svg.js.map +0 -1
  1781. package/components/Icon/images/document_default.svg.mjs +0 -2
  1782. package/components/Icon/images/document_default.svg.mjs.map +0 -1
  1783. package/components/Icon/images/dropDownArrow_default.svg.js +0 -2
  1784. package/components/Icon/images/dropDownArrow_default.svg.js.map +0 -1
  1785. package/components/Icon/images/dropDownArrow_default.svg.mjs +0 -2
  1786. package/components/Icon/images/dropDownArrow_default.svg.mjs.map +0 -1
  1787. package/components/Icon/images/edit_default.svg.js +0 -2
  1788. package/components/Icon/images/edit_default.svg.js.map +0 -1
  1789. package/components/Icon/images/edit_default.svg.mjs +0 -2
  1790. package/components/Icon/images/edit_default.svg.mjs.map +0 -1
  1791. package/components/Icon/images/email_default.svg.js +0 -2
  1792. package/components/Icon/images/email_default.svg.js.map +0 -1
  1793. package/components/Icon/images/email_default.svg.mjs +0 -2
  1794. package/components/Icon/images/email_default.svg.mjs.map +0 -1
  1795. package/components/Icon/images/externalLink_default.svg.js +0 -2
  1796. package/components/Icon/images/externalLink_default.svg.js.map +0 -1
  1797. package/components/Icon/images/externalLink_default.svg.mjs +0 -2
  1798. package/components/Icon/images/externalLink_default.svg.mjs.map +0 -1
  1799. package/components/Icon/images/externat_default.svg.js +0 -2
  1800. package/components/Icon/images/externat_default.svg.js.map +0 -1
  1801. package/components/Icon/images/externat_default.svg.mjs +0 -2
  1802. package/components/Icon/images/externat_default.svg.mjs.map +0 -1
  1803. package/components/Icon/images/eye_default.svg.js +0 -2
  1804. package/components/Icon/images/eye_default.svg.js.map +0 -1
  1805. package/components/Icon/images/eye_default.svg.mjs +0 -2
  1806. package/components/Icon/images/eye_default.svg.mjs.map +0 -1
  1807. package/components/Icon/images/fileBordered_default.svg.js +0 -2
  1808. package/components/Icon/images/fileBordered_default.svg.js.map +0 -1
  1809. package/components/Icon/images/fileBordered_default.svg.mjs +0 -2
  1810. package/components/Icon/images/fileBordered_default.svg.mjs.map +0 -1
  1811. package/components/Icon/images/file_default.svg.js +0 -2
  1812. package/components/Icon/images/file_default.svg.js.map +0 -1
  1813. package/components/Icon/images/file_default.svg.mjs +0 -2
  1814. package/components/Icon/images/file_default.svg.mjs.map +0 -1
  1815. package/components/Icon/images/fire_default.svg.js +0 -2
  1816. package/components/Icon/images/fire_default.svg.js.map +0 -1
  1817. package/components/Icon/images/fire_default.svg.mjs +0 -2
  1818. package/components/Icon/images/fire_default.svg.mjs.map +0 -1
  1819. package/components/Icon/images/headphones_default.svg.js +0 -2
  1820. package/components/Icon/images/headphones_default.svg.js.map +0 -1
  1821. package/components/Icon/images/headphones_default.svg.mjs +0 -2
  1822. package/components/Icon/images/headphones_default.svg.mjs.map +0 -1
  1823. package/components/Icon/images/home_default.svg.js +0 -2
  1824. package/components/Icon/images/home_default.svg.js.map +0 -1
  1825. package/components/Icon/images/home_default.svg.mjs +0 -2
  1826. package/components/Icon/images/home_default.svg.mjs.map +0 -1
  1827. package/components/Icon/images/infoInverse_default.svg.js +0 -2
  1828. package/components/Icon/images/infoInverse_default.svg.js.map +0 -1
  1829. package/components/Icon/images/infoInverse_default.svg.mjs +0 -2
  1830. package/components/Icon/images/infoInverse_default.svg.mjs.map +0 -1
  1831. package/components/Icon/images/info_default.svg.js +0 -2
  1832. package/components/Icon/images/info_default.svg.js.map +0 -1
  1833. package/components/Icon/images/info_default.svg.mjs +0 -2
  1834. package/components/Icon/images/info_default.svg.mjs.map +0 -1
  1835. package/components/Icon/images/lessons_default.svg.js +0 -2
  1836. package/components/Icon/images/lessons_default.svg.js.map +0 -1
  1837. package/components/Icon/images/lessons_default.svg.mjs +0 -2
  1838. package/components/Icon/images/lessons_default.svg.mjs.map +0 -1
  1839. package/components/Icon/images/list_default.svg.js +0 -2
  1840. package/components/Icon/images/list_default.svg.js.map +0 -1
  1841. package/components/Icon/images/list_default.svg.mjs +0 -2
  1842. package/components/Icon/images/list_default.svg.mjs.map +0 -1
  1843. package/components/Icon/images/login_default.svg.js +0 -2
  1844. package/components/Icon/images/login_default.svg.js.map +0 -1
  1845. package/components/Icon/images/login_default.svg.mjs +0 -2
  1846. package/components/Icon/images/login_default.svg.mjs.map +0 -1
  1847. package/components/Icon/images/logout_default.svg.js +0 -2
  1848. package/components/Icon/images/logout_default.svg.js.map +0 -1
  1849. package/components/Icon/images/logout_default.svg.mjs +0 -2
  1850. package/components/Icon/images/logout_default.svg.mjs.map +0 -1
  1851. package/components/Icon/images/message_default.svg.js +0 -2
  1852. package/components/Icon/images/message_default.svg.js.map +0 -1
  1853. package/components/Icon/images/message_default.svg.mjs +0 -2
  1854. package/components/Icon/images/message_default.svg.mjs.map +0 -1
  1855. package/components/Icon/images/objective_default.svg.js +0 -2
  1856. package/components/Icon/images/objective_default.svg.js.map +0 -1
  1857. package/components/Icon/images/objective_default.svg.mjs +0 -2
  1858. package/components/Icon/images/objective_default.svg.mjs.map +0 -1
  1859. package/components/Icon/images/page_default.svg.js +0 -2
  1860. package/components/Icon/images/page_default.svg.js.map +0 -1
  1861. package/components/Icon/images/page_default.svg.mjs +0 -2
  1862. package/components/Icon/images/page_default.svg.mjs.map +0 -1
  1863. package/components/Icon/images/pencil_default.svg.js +0 -2
  1864. package/components/Icon/images/pencil_default.svg.js.map +0 -1
  1865. package/components/Icon/images/pencil_default.svg.mjs +0 -2
  1866. package/components/Icon/images/pencil_default.svg.mjs.map +0 -1
  1867. package/components/Icon/images/person_default.svg.js +0 -2
  1868. package/components/Icon/images/person_default.svg.js.map +0 -1
  1869. package/components/Icon/images/person_default.svg.mjs +0 -2
  1870. package/components/Icon/images/person_default.svg.mjs.map +0 -1
  1871. package/components/Icon/images/phoneNoFill_default.svg.js +0 -2
  1872. package/components/Icon/images/phoneNoFill_default.svg.js.map +0 -1
  1873. package/components/Icon/images/phoneNoFill_default.svg.mjs +0 -2
  1874. package/components/Icon/images/phoneNoFill_default.svg.mjs.map +0 -1
  1875. package/components/Icon/images/phone_default.svg.js +0 -2
  1876. package/components/Icon/images/phone_default.svg.js.map +0 -1
  1877. package/components/Icon/images/phone_default.svg.mjs +0 -2
  1878. package/components/Icon/images/phone_default.svg.mjs.map +0 -1
  1879. package/components/Icon/images/playPause_default.svg.js +0 -2
  1880. package/components/Icon/images/playPause_default.svg.js.map +0 -1
  1881. package/components/Icon/images/playPause_default.svg.mjs +0 -2
  1882. package/components/Icon/images/playPause_default.svg.mjs.map +0 -1
  1883. package/components/Icon/images/play_default.svg.js +0 -2
  1884. package/components/Icon/images/play_default.svg.js.map +0 -1
  1885. package/components/Icon/images/play_default.svg.mjs +0 -2
  1886. package/components/Icon/images/play_default.svg.mjs.map +0 -1
  1887. package/components/Icon/images/plusThin_default.svg.js +0 -2
  1888. package/components/Icon/images/plusThin_default.svg.js.map +0 -1
  1889. package/components/Icon/images/plusThin_default.svg.mjs +0 -2
  1890. package/components/Icon/images/plusThin_default.svg.mjs.map +0 -1
  1891. package/components/Icon/images/plus_default.svg.js +0 -2
  1892. package/components/Icon/images/plus_default.svg.js.map +0 -1
  1893. package/components/Icon/images/plus_default.svg.mjs +0 -2
  1894. package/components/Icon/images/plus_default.svg.mjs.map +0 -1
  1895. package/components/Icon/images/present_default.svg.js +0 -2
  1896. package/components/Icon/images/present_default.svg.js.map +0 -1
  1897. package/components/Icon/images/present_default.svg.mjs +0 -2
  1898. package/components/Icon/images/present_default.svg.mjs.map +0 -1
  1899. package/components/Icon/images/priceTag_default.svg.js +0 -2
  1900. package/components/Icon/images/priceTag_default.svg.js.map +0 -1
  1901. package/components/Icon/images/priceTag_default.svg.mjs +0 -2
  1902. package/components/Icon/images/priceTag_default.svg.mjs.map +0 -1
  1903. package/components/Icon/images/print_default.svg.js +0 -2
  1904. package/components/Icon/images/print_default.svg.js.map +0 -1
  1905. package/components/Icon/images/print_default.svg.mjs +0 -2
  1906. package/components/Icon/images/print_default.svg.mjs.map +0 -1
  1907. package/components/Icon/images/prof_default.svg.js +0 -2
  1908. package/components/Icon/images/prof_default.svg.js.map +0 -1
  1909. package/components/Icon/images/prof_default.svg.mjs +0 -2
  1910. package/components/Icon/images/prof_default.svg.mjs.map +0 -1
  1911. package/components/Icon/images/questionFilled_default.svg.js +0 -2
  1912. package/components/Icon/images/questionFilled_default.svg.js.map +0 -1
  1913. package/components/Icon/images/questionFilled_default.svg.mjs +0 -2
  1914. package/components/Icon/images/questionFilled_default.svg.mjs.map +0 -1
  1915. package/components/Icon/images/radioChecked_default.svg.js +0 -2
  1916. package/components/Icon/images/radioChecked_default.svg.js.map +0 -1
  1917. package/components/Icon/images/radioChecked_default.svg.mjs +0 -2
  1918. package/components/Icon/images/radioChecked_default.svg.mjs.map +0 -1
  1919. package/components/Icon/images/radioNotChecked_default.svg.js +0 -2
  1920. package/components/Icon/images/radioNotChecked_default.svg.js.map +0 -1
  1921. package/components/Icon/images/radioNotChecked_default.svg.mjs +0 -2
  1922. package/components/Icon/images/radioNotChecked_default.svg.mjs.map +0 -1
  1923. package/components/Icon/images/reload_default.svg.js +0 -2
  1924. package/components/Icon/images/reload_default.svg.js.map +0 -1
  1925. package/components/Icon/images/reload_default.svg.mjs +0 -2
  1926. package/components/Icon/images/reload_default.svg.mjs.map +0 -1
  1927. package/components/Icon/images/search_default.svg.js +0 -2
  1928. package/components/Icon/images/search_default.svg.js.map +0 -1
  1929. package/components/Icon/images/search_default.svg.mjs +0 -2
  1930. package/components/Icon/images/search_default.svg.mjs.map +0 -1
  1931. package/components/Icon/images/settings_default.svg.js +0 -2
  1932. package/components/Icon/images/settings_default.svg.js.map +0 -1
  1933. package/components/Icon/images/settings_default.svg.mjs +0 -2
  1934. package/components/Icon/images/settings_default.svg.mjs.map +0 -1
  1935. package/components/Icon/images/sharpCross_default.svg.js +0 -2
  1936. package/components/Icon/images/sharpCross_default.svg.js.map +0 -1
  1937. package/components/Icon/images/sharpCross_default.svg.mjs +0 -2
  1938. package/components/Icon/images/sharpCross_default.svg.mjs.map +0 -1
  1939. package/components/Icon/images/sort_default.svg.js +0 -2
  1940. package/components/Icon/images/sort_default.svg.js.map +0 -1
  1941. package/components/Icon/images/sort_default.svg.mjs +0 -2
  1942. package/components/Icon/images/sort_default.svg.mjs.map +0 -1
  1943. package/components/Icon/images/star_default.svg.js +0 -2
  1944. package/components/Icon/images/star_default.svg.js.map +0 -1
  1945. package/components/Icon/images/star_default.svg.mjs +0 -2
  1946. package/components/Icon/images/star_default.svg.mjs.map +0 -1
  1947. package/components/Icon/images/student_default.svg.js +0 -2
  1948. package/components/Icon/images/student_default.svg.js.map +0 -1
  1949. package/components/Icon/images/student_default.svg.mjs +0 -2
  1950. package/components/Icon/images/student_default.svg.mjs.map +0 -1
  1951. package/components/Icon/images/target_default.svg.js +0 -2
  1952. package/components/Icon/images/target_default.svg.js.map +0 -1
  1953. package/components/Icon/images/target_default.svg.mjs +0 -2
  1954. package/components/Icon/images/target_default.svg.mjs.map +0 -1
  1955. package/components/Icon/images/tasks_default.svg.js +0 -2
  1956. package/components/Icon/images/tasks_default.svg.js.map +0 -1
  1957. package/components/Icon/images/tasks_default.svg.mjs +0 -2
  1958. package/components/Icon/images/tasks_default.svg.mjs.map +0 -1
  1959. package/components/Icon/images/textbook_default.svg.js +0 -2
  1960. package/components/Icon/images/textbook_default.svg.js.map +0 -1
  1961. package/components/Icon/images/textbook_default.svg.mjs +0 -2
  1962. package/components/Icon/images/textbook_default.svg.mjs.map +0 -1
  1963. package/components/Icon/images/tinyCross_default.svg.js +0 -2
  1964. package/components/Icon/images/tinyCross_default.svg.js.map +0 -1
  1965. package/components/Icon/images/tinyCross_default.svg.mjs +0 -2
  1966. package/components/Icon/images/tinyCross_default.svg.mjs.map +0 -1
  1967. package/components/Icon/images/trophy_default.svg.js +0 -2
  1968. package/components/Icon/images/trophy_default.svg.js.map +0 -1
  1969. package/components/Icon/images/trophy_default.svg.mjs +0 -2
  1970. package/components/Icon/images/trophy_default.svg.mjs.map +0 -1
  1971. package/components/Icon/images/unsort_default.svg.js +0 -2
  1972. package/components/Icon/images/unsort_default.svg.js.map +0 -1
  1973. package/components/Icon/images/unsort_default.svg.mjs +0 -2
  1974. package/components/Icon/images/unsort_default.svg.mjs.map +0 -1
  1975. package/components/Icon/images/video_default.svg.js +0 -2
  1976. package/components/Icon/images/video_default.svg.js.map +0 -1
  1977. package/components/Icon/images/video_default.svg.mjs +0 -2
  1978. package/components/Icon/images/video_default.svg.mjs.map +0 -1
  1979. package/components/Icon/images/wallet_default.svg.js +0 -2
  1980. package/components/Icon/images/wallet_default.svg.js.map +0 -1
  1981. package/components/Icon/images/wallet_default.svg.mjs +0 -2
  1982. package/components/Icon/images/wallet_default.svg.mjs.map +0 -1
  1983. package/components/Icon/sizes.js +0 -2
  1984. package/components/Icon/sizes.js.map +0 -1
  1985. package/components/Icon/sizes.mjs +0 -2
  1986. package/components/Icon/sizes.mjs.map +0 -1
  1987. package/components/Modal/images/tinyCrossDefault.svg.js +0 -2
  1988. package/components/Modal/images/tinyCrossDefault.svg.js.map +0 -1
  1989. package/components/Modal/images/tinyCrossDefault.svg.mjs +0 -2
  1990. package/components/Modal/images/tinyCrossDefault.svg.mjs.map +0 -1
  1991. package/icon-pack/src/collection.json.js +0 -2
  1992. package/icon-pack/src/collection.json.js.map +0 -1
  1993. package/icon-pack/src/collection.json.mjs +0 -2
  1994. package/icon-pack/src/collection.json.mjs.map +0 -1
  1995. package/icon-pack/src/icons/ArrowUp/index.js +0 -2
  1996. package/icon-pack/src/icons/ArrowUp/index.js.map +0 -1
  1997. package/icon-pack/src/icons/ArrowUp/index.mjs +0 -2
  1998. package/icon-pack/src/icons/ArrowUp/index.mjs.map +0 -1
  1999. package/icon-pack/src/icons/CheckCircle/index.js +0 -2
  2000. package/icon-pack/src/icons/CheckCircle/index.js.map +0 -1
  2001. package/icon-pack/src/icons/CheckCircle/index.mjs +0 -2
  2002. package/icon-pack/src/icons/CheckCircle/index.mjs.map +0 -1
  2003. package/icon-pack/src/icons/CheckCircleFill/index.js +0 -2
  2004. package/icon-pack/src/icons/CheckCircleFill/index.js.map +0 -1
  2005. package/icon-pack/src/icons/CheckCircleFill/index.mjs +0 -2
  2006. package/icon-pack/src/icons/CheckCircleFill/index.mjs.map +0 -1
  2007. package/icon-pack/src/icons/CheckFill/index.js +0 -2
  2008. package/icon-pack/src/icons/CheckFill/index.js.map +0 -1
  2009. package/icon-pack/src/icons/CheckFill/index.mjs +0 -2
  2010. package/icon-pack/src/icons/CheckFill/index.mjs.map +0 -1
  2011. package/icon-pack/src/icons/ChevronDown/index.js +0 -2
  2012. package/icon-pack/src/icons/ChevronDown/index.js.map +0 -1
  2013. package/icon-pack/src/icons/ChevronDown/index.mjs +0 -2
  2014. package/icon-pack/src/icons/ChevronDown/index.mjs.map +0 -1
  2015. package/icon-pack/src/icons/ChevronLeft/index.js +0 -2
  2016. package/icon-pack/src/icons/ChevronLeft/index.js.map +0 -1
  2017. package/icon-pack/src/icons/ChevronLeft/index.mjs +0 -2
  2018. package/icon-pack/src/icons/ChevronLeft/index.mjs.map +0 -1
  2019. package/icon-pack/src/icons/ChevronRight/index.js +0 -2
  2020. package/icon-pack/src/icons/ChevronRight/index.js.map +0 -1
  2021. package/icon-pack/src/icons/ChevronRight/index.mjs +0 -2
  2022. package/icon-pack/src/icons/ChevronRight/index.mjs.map +0 -1
  2023. package/icon-pack/src/icons/Close/index.js +0 -2
  2024. package/icon-pack/src/icons/Close/index.js.map +0 -1
  2025. package/icon-pack/src/icons/Close/index.mjs +0 -2
  2026. package/icon-pack/src/icons/Close/index.mjs.map +0 -1
  2027. package/icon-pack/src/icons/CloseCirlce/index.js +0 -2
  2028. package/icon-pack/src/icons/CloseCirlce/index.js.map +0 -1
  2029. package/icon-pack/src/icons/CloseCirlce/index.mjs +0 -2
  2030. package/icon-pack/src/icons/CloseCirlce/index.mjs.map +0 -1
  2031. package/icon-pack/src/icons/CloseCirlceFill/index.js +0 -2
  2032. package/icon-pack/src/icons/CloseCirlceFill/index.js.map +0 -1
  2033. package/icon-pack/src/icons/CloseCirlceFill/index.mjs +0 -2
  2034. package/icon-pack/src/icons/CloseCirlceFill/index.mjs.map +0 -1
  2035. package/icon-pack/src/icons/HelpCircle/index.js +0 -2
  2036. package/icon-pack/src/icons/HelpCircle/index.js.map +0 -1
  2037. package/icon-pack/src/icons/HelpCircle/index.mjs +0 -2
  2038. package/icon-pack/src/icons/HelpCircle/index.mjs.map +0 -1
  2039. package/icon-pack/src/icons/InfoCircle/index.js +0 -2
  2040. package/icon-pack/src/icons/InfoCircle/index.js.map +0 -1
  2041. package/icon-pack/src/icons/InfoCircle/index.mjs +0 -2
  2042. package/icon-pack/src/icons/InfoCircle/index.mjs.map +0 -1
  2043. package/icon-pack/src/icons/LoaderFill/index.js +0 -2
  2044. package/icon-pack/src/icons/LoaderFill/index.js.map +0 -1
  2045. package/icon-pack/src/icons/LoaderFill/index.mjs +0 -2
  2046. package/icon-pack/src/icons/LoaderFill/index.mjs.map +0 -1
  2047. package/icon-pack/src/icons/Minus/index.js +0 -2
  2048. package/icon-pack/src/icons/Minus/index.js.map +0 -1
  2049. package/icon-pack/src/icons/Minus/index.mjs +0 -2
  2050. package/icon-pack/src/icons/Minus/index.mjs.map +0 -1
  2051. package/icon-pack/src/icons/MinusFill/index.js +0 -2
  2052. package/icon-pack/src/icons/MinusFill/index.js.map +0 -1
  2053. package/icon-pack/src/icons/MinusFill/index.mjs +0 -2
  2054. package/icon-pack/src/icons/MinusFill/index.mjs.map +0 -1
  2055. package/icon-pack/src/icons/NotifFill/index.js +0 -2
  2056. package/icon-pack/src/icons/NotifFill/index.js.map +0 -1
  2057. package/icon-pack/src/icons/NotifFill/index.mjs +0 -2
  2058. package/icon-pack/src/icons/NotifFill/index.mjs.map +0 -1
  2059. package/icon-pack/src/icons/Plus/index.js +0 -2
  2060. package/icon-pack/src/icons/Plus/index.js.map +0 -1
  2061. package/icon-pack/src/icons/Plus/index.mjs +0 -2
  2062. package/icon-pack/src/icons/Plus/index.mjs.map +0 -1
  2063. package/icon-pack/src/icons/Redo/index.js +0 -2
  2064. package/icon-pack/src/icons/Redo/index.js.map +0 -1
  2065. package/icon-pack/src/icons/Redo/index.mjs +0 -2
  2066. package/icon-pack/src/icons/Redo/index.mjs.map +0 -1
  2067. package/icon-pack/src/icons/ResizeHandle/index.js +0 -2
  2068. package/icon-pack/src/icons/ResizeHandle/index.js.map +0 -1
  2069. package/icon-pack/src/icons/ResizeHandle/index.mjs +0 -2
  2070. package/icon-pack/src/icons/ResizeHandle/index.mjs.map +0 -1
  2071. package/icon-pack/src/icons/StarFill/index.js +0 -2
  2072. package/icon-pack/src/icons/StarFill/index.js.map +0 -1
  2073. package/icon-pack/src/icons/StarFill/index.mjs +0 -2
  2074. package/icon-pack/src/icons/StarFill/index.mjs.map +0 -1
  2075. package/icon-pack/src/icons/WarningTriangle/index.js +0 -2
  2076. package/icon-pack/src/icons/WarningTriangle/index.js.map +0 -1
  2077. package/icon-pack/src/icons/WarningTriangle/index.mjs +0 -2
  2078. package/icon-pack/src/icons/WarningTriangle/index.mjs.map +0 -1
  2079. package/icon-pack/src/icons/WarningTriangleFill/index.js +0 -2
  2080. package/icon-pack/src/icons/WarningTriangleFill/index.js.map +0 -1
  2081. package/icon-pack/src/icons/WarningTriangleFill/index.mjs +0 -2
  2082. package/icon-pack/src/icons/WarningTriangleFill/index.mjs.map +0 -1
@@ -1,2 +1,2 @@
1
- 'use strict';var React=require('react');var Floater=require('react-floater');var nanoid=require('nanoid');var tabList=require('../../shared/context/tabList.js');var useMergedPalette=require('../../hooks/useMergedPalette.js');var useClickOutside=require('../../hooks/useClickOutside.js');var constants=require('../../shared/constants.js');var useFloaterPortal=require('../../hooks/useFloaterPortal.js');var dom=require('../../shared/utils/dom.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var index=require('../../icon-pack/src/icons/ChevronDown/index.js');var TabListTab=require('../TabListTab/TabListTab.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Floater__default=_interopDefault(Floater);exports.TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:a="clear",size:r="m",sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u,disabled:d,text:m,control:b,menuItems:y,activeTab:p,firstTab:v,activationOnFocus:f,getTabIndex:k,onActiveTabChange:T}=e;const x=React.useMemo((()=>({size:r,sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u})),[r,s,n,i,l,c,u]);const C=useMergedPalette.useMergedPalette(e);const h=React.useRef(null);const[g,R]=React.useState(null);const j=React.useRef(null);const L=useFloaterPortal.useFloaterPortal();const[D,A]=React.useState(!1);const E=React.useMemo((()=>nanoid.nanoid()),[]);const M=React.useMemo((()=>[h,g]),[g]);const K=React.useCallback((()=>{A(!1)}),[]);const S=Boolean(y.find((e=>React.isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===p)));const q={...x,role:t,type:o,variant:a,'aria-haspopup':'menu',id:E,'aria-selected':S,active:S,tabIndex:S||!v?0:-1,disabled:d,text:m,addonRight:e=>jsxRuntime.jsx(style.IconAnimated,{...e.iconProps,rotate:D,icon:jsxRuntime.jsx(index.ChevronDown,{}),preset:"brand"}),palette:{color:C.tabColor,colorHover:C.tabColorHover,colorActive:C.tabColorActive,colorDisabled:C.tabColorDisabled,colorActiveDisabled:C.tabColorActiveDisabled,backgroundColor:C.tabBackgroundColor,backgroundColorHover:C.tabBackgroundColorHover,backgroundColorActive:C.tabBackgroundColorActive,backgroundColorDisabled:C.tabBackgroundColorDisabled,backgroundColorActiveDisabled:C.tabBackgroundColorActiveDisabled},onClick:()=>{A((e=>!e))},onKeyDown:e=>{D&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),A(!1)):!D&&(constants.keyboardKeys.F10.validate(e.key)&&e.shiftKey||constants.keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),A(!0))}};const w=React.useMemo((()=>({activationOnFocus:f,activeTab:p,onActiveTabChange:T,getTabIndex:k})),[f,p,T,k]);const z=React.useMemo((()=>({...x,disabled:d,role:'menuitem',variant:'filled'})),[x,d]);return useClickOutside.useClickOutside(M,K,{enabled:D,event:'mousedown'}),React.useEffect((()=>(j.current=setTimeout((()=>{if(!g)return;const e=Array.from(g.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(dom.SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),j.current=null}),100),()=>{j.current&&clearTimeout(j.current)})),[g]),L?jsxRuntime.jsx(Floater__default.default,{open:D,portalElement:L,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:d?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(h.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsxRuntime.jsx(style.Menu,{role:"menu","aria-labelledby":E,ref:R,palette:{backgroundColor:C.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(A(!1),setTimeout((()=>{h.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key)||constants.keyboardKeys.Home.validate(e.key)||constants.keyboardKeys.End.validate(e.key)||constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))))return;if(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))return e.preventDefault(),A(!1),void setTimeout((()=>{h.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(constants.keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):constants.keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),dom.navigateVerticalList(e.key,document.activeElement,t,dom.SELECTORS_FOCUSABLE)))},children:jsxRuntime.jsx(tabList.TabListTabsContext.Provider,{value:w,children:jsxRuntime.jsx(tabList.TabListPropsContext.Provider,{value:z,children:React.Children.map(y,(e=>jsxRuntime.jsx(style.MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(q):jsxRuntime.jsx(TabListTab.TabListTab,{...q})}):null};
1
+ 'use strict';var React=require('react');var Floater=require('react-floater');var nanoid=require('nanoid');var tabList=require('../../shared/context/tabList.js');var useMergedPalette=require('../../hooks/useMergedPalette.js');var useClickOutside=require('../../hooks/useClickOutside.js');var constants=require('../../shared/constants.js');var useFloaterPortal=require('../../hooks/useFloaterPortal.js');var dom=require('../../shared/utils/dom.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var TabListTab=require('../TabListTab/TabListTab.js');function _interopDefault(e){return e&&e.__esModule?e:{default:e}}var Floater__default=_interopDefault(Floater);exports.TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:a="clear",size:r="m",sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u,disabled:d,text:m,control:b,menuItems:y,activeTab:p,firstTab:v,activationOnFocus:f,getTabIndex:k,onActiveTabChange:T}=e;const h=React.useMemo((()=>({size:r,sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:u})),[r,s,n,i,l,c,u]);const C=useMergedPalette.useMergedPalette(e);const g=React.useRef(null);const[x,R]=React.useState(null);const L=React.useRef(null);const j=useFloaterPortal.useFloaterPortal();const[A,D]=React.useState(!1);const E=React.useMemo((()=>nanoid.nanoid()),[]);const M=React.useMemo((()=>[g,x]),[x]);const K=React.useCallback((()=>{D(!1)}),[]);const S=Boolean(y.find((e=>React.isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===p)));const q={...h,role:t,type:o,variant:a,'aria-haspopup':'menu',id:E,'aria-selected':S,active:S,tabIndex:S||!v?0:-1,disabled:d,text:m,addonRight:e=>jsxRuntime.jsx(style.IconAnimated,{...e.iconProps,rotate:A,name:"chevronDown",preset:"brand"}),palette:{color:C.tabColor,colorHover:C.tabColorHover,colorActive:C.tabColorActive,colorDisabled:C.tabColorDisabled,colorActiveDisabled:C.tabColorActiveDisabled,backgroundColor:C.tabBackgroundColor,backgroundColorHover:C.tabBackgroundColorHover,backgroundColorActive:C.tabBackgroundColorActive,backgroundColorDisabled:C.tabBackgroundColorDisabled,backgroundColorActiveDisabled:C.tabBackgroundColorActiveDisabled},onClick:()=>{D((e=>!e))},onKeyDown:e=>{A&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),D(!1)):!A&&(constants.keyboardKeys.F10.validate(e.key)&&e.shiftKey||constants.keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),D(!0))}};const w=React.useMemo((()=>({activationOnFocus:f,activeTab:p,onActiveTabChange:T,getTabIndex:k})),[f,p,T,k]);const z=React.useMemo((()=>({...h,disabled:d,role:'menuitem',variant:'filled'})),[h,d]);return useClickOutside.useClickOutside(M,K,{enabled:A,event:'mousedown'}),React.useEffect((()=>(L.current=setTimeout((()=>{if(!x)return;const e=Array.from(x.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(dom.SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),L.current=null}),100),()=>{L.current&&clearTimeout(L.current)})),[x]),j?jsxRuntime.jsx(Floater__default.default,{open:A,portalElement:j,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:d?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(g.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsxRuntime.jsx(style.Menu,{role:"menu","aria-labelledby":E,ref:R,palette:{backgroundColor:C.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(D(!1),setTimeout((()=>{g.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key)||constants.keyboardKeys.Home.validate(e.key)||constants.keyboardKeys.End.validate(e.key)||constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))))return;if(constants.keyboardKeys.Esc.validate(e.key)||constants.keyboardKeys.Tab.validate(e.key))return e.preventDefault(),D(!1),void setTimeout((()=>{g.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(constants.keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):constants.keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(constants.keyboardKeys.ArrowDown.validate(e.key)||constants.keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),dom.navigateVerticalList(e.key,document.activeElement,t,dom.SELECTORS_FOCUSABLE)))},children:jsxRuntime.jsx(tabList.TabListTabsContext.Provider,{value:w,children:jsxRuntime.jsx(tabList.TabListPropsContext.Provider,{value:z,children:React.Children.map(y,(e=>jsxRuntime.jsx(style.MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(q):jsxRuntime.jsx(TabListTab.TabListTab,{...q})}):null};
2
2
  //# sourceMappingURL=TabListMenuTab.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TabListMenuTab.js","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown } from '@foxford/icon-pack'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} icon={<ChevronDown />} preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","jsx","Styled","iconProps","rotate","icon","ChevronDown","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","name","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
1
+ {"version":3,"file":"TabListMenuTab.js","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} name='chevronDown' preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","jsx","Styled","iconProps","rotate","name","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{useMemo,useRef,useState,useCallback,isValidElement,useEffect,Children}from'react';import Floater from'react-floater';import{nanoid}from'nanoid';import{TabListTabsContext,TabListPropsContext}from'../../shared/context/tabList.mjs';import{useMergedPalette}from'../../hooks/useMergedPalette.mjs';import{useClickOutside}from'../../hooks/useClickOutside.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{useFloaterPortal}from'../../hooks/useFloaterPortal.mjs';import{SELECTORS_FOCUSABLE,navigateVerticalList}from'../../shared/utils/dom.mjs';import{IconAnimated,Menu,MenuItem}from'./style.mjs';import{jsx}from'react/jsx-runtime';import{ChevronDown}from'../../icon-pack/src/icons/ChevronDown/index.mjs';import{TabListTab}from'../TabListTab/TabListTab.mjs';const TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:r="clear",size:a="m",sizeXXS:n,sizeXS:s,sizeS:i,sizeM:l,sizeL:c,sizeXL:d,disabled:m,text:u,control:b,menuItems:p,activeTab:f,firstTab:y,activationOnFocus:v,getTabIndex:k,onActiveTabChange:T}=e;const C=useMemo((()=>({size:a,sizeXXS:n,sizeXS:s,sizeS:i,sizeM:l,sizeL:c,sizeXL:d})),[a,n,s,i,l,c,d]);const h=useMergedPalette(e);const g=useRef(null);const[L,E]=useState(null);const x=useRef(null);const A=useFloaterPortal();const[D,M]=useState(!1);const S=useMemo((()=>nanoid()),[]);const j=useMemo((()=>[g,L]),[L]);const K=useCallback((()=>{M(!1)}),[]);const w=Boolean(p.find((e=>isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===f)));const z={...C,role:t,type:o,variant:r,'aria-haspopup':'menu',id:S,'aria-selected':w,active:w,tabIndex:w||!y?0:-1,disabled:m,text:u,addonRight:e=>jsx(IconAnimated,{...e.iconProps,rotate:D,icon:jsx(ChevronDown,{}),preset:"brand"}),palette:{color:h.tabColor,colorHover:h.tabColorHover,colorActive:h.tabColorActive,colorDisabled:h.tabColorDisabled,colorActiveDisabled:h.tabColorActiveDisabled,backgroundColor:h.tabBackgroundColor,backgroundColorHover:h.tabBackgroundColorHover,backgroundColorActive:h.tabBackgroundColorActive,backgroundColorDisabled:h.tabBackgroundColorDisabled,backgroundColorActiveDisabled:h.tabBackgroundColorActiveDisabled},onClick:()=>{M((e=>!e))},onKeyDown:e=>{D&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),M(!1)):!D&&(keyboardKeys.F10.validate(e.key)&&e.shiftKey||keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),M(!0))}};const P=useMemo((()=>({activationOnFocus:v,activeTab:f,onActiveTabChange:T,getTabIndex:k})),[v,f,T,k]);const H=useMemo((()=>({...C,disabled:m,role:'menuitem',variant:'filled'})),[C,m]);return useClickOutside(j,K,{enabled:D,event:'mousedown'}),useEffect((()=>(x.current=setTimeout((()=>{if(!L)return;const e=Array.from(L.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),x.current=null}),100),()=>{x.current&&clearTimeout(x.current)})),[L]),A?jsx(Floater,{open:D,portalElement:A,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:m?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(g.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsx(Menu,{role:"menu","aria-labelledby":S,ref:E,palette:{backgroundColor:h.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(M(!1),setTimeout((()=>{g.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key)||keyboardKeys.Home.validate(e.key)||keyboardKeys.End.validate(e.key)||keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))))return;if(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))return e.preventDefault(),M(!1),void setTimeout((()=>{g.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),navigateVerticalList(e.key,document.activeElement,t,SELECTORS_FOCUSABLE)))},children:jsx(TabListTabsContext.Provider,{value:P,children:jsx(TabListPropsContext.Provider,{value:H,children:Children.map(p,(e=>jsx(MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(z):jsx(TabListTab,{...z})}):null};export{TabListMenuTab};
1
+ import{useMemo,useRef,useState,useCallback,isValidElement,useEffect,Children}from'react';import Floater from'react-floater';import{nanoid}from'nanoid';import{TabListTabsContext,TabListPropsContext}from'../../shared/context/tabList.mjs';import{useMergedPalette}from'../../hooks/useMergedPalette.mjs';import{useClickOutside}from'../../hooks/useClickOutside.mjs';import{keyboardKeys}from'../../shared/constants.mjs';import{useFloaterPortal}from'../../hooks/useFloaterPortal.mjs';import{SELECTORS_FOCUSABLE,navigateVerticalList}from'../../shared/utils/dom.mjs';import{IconAnimated,Menu,MenuItem}from'./style.mjs';import{jsx}from'react/jsx-runtime';import{TabListTab}from'../TabListTab/TabListTab.mjs';const TabListMenuTab=e=>{const{role:t="tab",type:o="button",variant:r="clear",size:a="m",sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:d,disabled:m,text:u,control:b,menuItems:p,activeTab:f,firstTab:y,activationOnFocus:v,getTabIndex:k,onActiveTabChange:T}=e;const C=useMemo((()=>({size:a,sizeXXS:s,sizeXS:n,sizeS:i,sizeM:l,sizeL:c,sizeXL:d})),[a,s,n,i,l,c,d]);const h=useMergedPalette(e);const g=useRef(null);const[L,E]=useState(null);const A=useRef(null);const x=useFloaterPortal();const[M,D]=useState(!1);const S=useMemo((()=>nanoid()),[]);const K=useMemo((()=>[g,L]),[L]);const j=useCallback((()=>{D(!1)}),[]);const w=Boolean(p.find((e=>isValidElement(e)&&typeof e.props=='object'&&e.props!==null&&e.props.id===f)));const z={...C,role:t,type:o,variant:r,'aria-haspopup':'menu',id:S,'aria-selected':w,active:w,tabIndex:w||!y?0:-1,disabled:m,text:u,addonRight:e=>jsx(IconAnimated,{...e.iconProps,rotate:M,name:"chevronDown",preset:"brand"}),palette:{color:h.tabColor,colorHover:h.tabColorHover,colorActive:h.tabColorActive,colorDisabled:h.tabColorDisabled,colorActiveDisabled:h.tabColorActiveDisabled,backgroundColor:h.tabBackgroundColor,backgroundColorHover:h.tabBackgroundColorHover,backgroundColorActive:h.tabBackgroundColorActive,backgroundColorDisabled:h.tabBackgroundColorDisabled,backgroundColorActiveDisabled:h.tabBackgroundColorActiveDisabled},onClick:()=>{D((e=>!e))},onKeyDown:e=>{M&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))?(e.preventDefault(),D(!1)):!M&&(keyboardKeys.F10.validate(e.key)&&e.shiftKey||keyboardKeys.ArrowDown.validate(e.key))&&(e.preventDefault(),D(!0))}};const P=useMemo((()=>({activationOnFocus:v,activeTab:f,onActiveTabChange:T,getTabIndex:k})),[v,f,T,k]);const H=useMemo((()=>({...C,disabled:m,role:'menuitem',variant:'filled'})),[C,m]);return useClickOutside(K,j,{enabled:M,event:'mousedown'}),useEffect((()=>(A.current=setTimeout((()=>{if(!L)return;const e=Array.from(L.querySelectorAll('[role="menuitem"]')).filter((e=>e.matches(SELECTORS_FOCUSABLE)));const t=e.find((e=>e.matches('[aria-selected="true"]')));t?t.focus():e[0]&&e[0].focus(),A.current=null}),100),()=>{A.current&&clearTimeout(A.current)})),[L]),x?jsx(Floater,{open:M,portalElement:x,placement:"bottom-end",offset:8,hideArrow:!0,styles:{options:{zIndex:void 0},wrapper:{cursor:m?'not-allowed':'pointer'},floater:{filter:'none',opacity:1,transitionDuration:'10ms'}},getPopper:e=>{e.state.elements.reference instanceof HTMLElement&&(g.current=e.state.elements.reference)},modifiers:{removeRoles:{name:'removeRoles',enabled:!0,phase:'beforeWrite',effect:({state:e})=>{if(e.elements.popper instanceof HTMLElement){const t=e.elements.popper.querySelector('[role="tooltip"]');t&&t.removeAttribute('role')}}},minWidth:{name:'minWidth',enabled:!0,phase:'beforeWrite',requires:['computeStyles'],fn:({state:e})=>{e.styles.popper.minWidth=`${e.rects.reference.width}px`},effect:({state:e})=>{e.elements.popper instanceof HTMLElement&&e.elements.reference instanceof HTMLElement&&(e.elements.popper.style.display='flex',e.elements.popper.style.flexDirection='column',e.elements.popper.style.alignItems='stretch',e.elements.popper.style.minWidth=`${e.elements.reference.offsetWidth}px`)}}},component:()=>jsx(Menu,{role:"menu","aria-labelledby":S,ref:E,palette:{backgroundColor:h.menuBackgroundColor},onClick:e=>{e.target instanceof HTMLElement&&e.target.closest('[role="menuitem"]')&&(D(!1),setTimeout((()=>{g.current?.focus()}),100))},onKeyDown:e=>{if(e.stopPropagation(),!(document.activeElement instanceof HTMLElement&&document.activeElement.matches('[role="menuitem"]')&&(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key)||keyboardKeys.Home.validate(e.key)||keyboardKeys.End.validate(e.key)||keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))))return;if(keyboardKeys.Esc.validate(e.key)||keyboardKeys.Tab.validate(e.key))return e.preventDefault(),D(!1),void setTimeout((()=>{g.current?.focus()}),100);const t=Array.from(e.currentTarget.querySelectorAll('[role="menuitem"]'));t.length!==0&&(keyboardKeys.Home.validate(e.key)?(e.preventDefault(),t[0].focus()):keyboardKeys.End.validate(e.key)?(e.preventDefault(),t[t.length-1].focus()):(keyboardKeys.ArrowDown.validate(e.key)||keyboardKeys.ArrowUp.validate(e.key))&&(e.preventDefault(),navigateVerticalList(e.key,document.activeElement,t,SELECTORS_FOCUSABLE)))},children:jsx(TabListTabsContext.Provider,{value:P,children:jsx(TabListPropsContext.Provider,{value:H,children:Children.map(p,(e=>jsx(MenuItem,{role:"none",children:e})))})})}),children:typeof b=='function'?b(z):jsx(TabListTab,{...z})}):null};export{TabListMenuTab};
2
2
  //# sourceMappingURL=TabListMenuTab.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"TabListMenuTab.mjs","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport { ChevronDown } from '@foxford/icon-pack'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} icon={<ChevronDown />} preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["TabListMenuTab","props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","Styled","iconProps","rotate","icon","ChevronDown","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","name","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
1
+ {"version":3,"file":"TabListMenuTab.mjs","sources":["../../../../src/components/TabList/TabListMenuTab.tsx"],"sourcesContent":["import { useState, useRef, useEffect, useMemo, useCallback, Children, isValidElement } from 'react'\nimport Floater from 'react-floater'\nimport { nanoid } from 'nanoid'\nimport type { Nullable } from 'shared/types'\nimport { TabListTabsContext, TabListPropsContext } from 'shared/context/tabList'\nimport { TabListTab } from 'components/TabListTab'\nimport { useMergedPalette } from 'hooks/useMergedPalette'\nimport { useClickOutside } from 'hooks/useClickOutside'\nimport { keyboardKeys } from 'shared/constants'\nimport { useFloaterPortal } from 'hooks/useFloaterPortal'\nimport { navigateVerticalList, SELECTORS_FOCUSABLE } from 'shared/utils/dom'\nimport type { TabListTabProps } from 'components/TabListTab'\nimport * as Styled from './style'\nimport type { TabListMenuTabProps } from './types'\n\nconst TabListMenuTab = (props: TabListMenuTabProps) => {\n const {\n role = 'tab',\n type = 'button',\n variant = 'clear',\n size = 'm',\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n disabled,\n text,\n control,\n menuItems,\n activeTab,\n firstTab,\n activationOnFocus,\n getTabIndex,\n onActiveTabChange,\n } = props\n\n const sizeProps = useMemo(\n () => ({ size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL }),\n [size, sizeXXS, sizeXS, sizeS, sizeM, sizeL, sizeXL]\n )\n\n const palette = useMergedPalette(props)\n\n const controlRef = useRef<Nullable<HTMLElement>>(null)\n const [menuRef, setMenuRef] = useState<Nullable<HTMLUListElement>>(null)\n\n const timerId = useRef<Nullable<ReturnType<typeof setTimeout>>>(null)\n\n const portalElement = useFloaterPortal()\n\n const [menuOpen, setMenuOpen] = useState(false)\n\n const controlId = useMemo(() => nanoid(), [])\n\n const clickOutsideTargets = useMemo(() => [controlRef, menuRef], [menuRef])\n\n const handleCloseMenu = useCallback(() => {\n setMenuOpen(false)\n }, [])\n\n const menuHasActiveTab = Boolean(\n menuItems.find(\n (item) =>\n isValidElement(item) && typeof item.props === 'object' && item.props !== null && item.props.id === activeTab\n )\n )\n\n const controlProps: TabListTabProps = {\n ...sizeProps,\n role,\n type,\n variant,\n 'aria-haspopup': 'menu',\n id: controlId,\n 'aria-selected': menuHasActiveTab,\n active: menuHasActiveTab,\n tabIndex: menuHasActiveTab || !firstTab ? 0 : -1,\n disabled,\n text,\n // eslint-disable-next-line react/no-unstable-nested-components\n addonRight: (addonProps) => (\n <Styled.IconAnimated {...addonProps.iconProps} rotate={menuOpen} name='chevronDown' preset='brand' />\n ),\n palette: {\n color: palette.tabColor,\n colorHover: palette.tabColorHover,\n colorActive: palette.tabColorActive,\n colorDisabled: palette.tabColorDisabled,\n colorActiveDisabled: palette.tabColorActiveDisabled,\n backgroundColor: palette.tabBackgroundColor,\n backgroundColorHover: palette.tabBackgroundColorHover,\n backgroundColorActive: palette.tabBackgroundColorActive,\n backgroundColorDisabled: palette.tabBackgroundColorDisabled,\n backgroundColorActiveDisabled: palette.tabBackgroundColorActiveDisabled,\n },\n onClick: () => {\n setMenuOpen((prev) => !prev)\n },\n onKeyDown: (evt) => {\n if (menuOpen && (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key))) {\n evt.preventDefault()\n setMenuOpen(false)\n } else if (\n !menuOpen &&\n ((keyboardKeys.F10.validate(evt.key) && evt.shiftKey) || keyboardKeys.ArrowDown.validate(evt.key))\n ) {\n evt.preventDefault()\n setMenuOpen(true)\n }\n },\n }\n\n const controlsContextProps = useMemo(\n () => ({\n activationOnFocus,\n activeTab,\n onActiveTabChange,\n getTabIndex,\n }),\n [activationOnFocus, activeTab, onActiveTabChange, getTabIndex]\n )\n\n const menuItemsContextProps = useMemo(\n () => ({\n ...sizeProps,\n disabled,\n role: 'menuitem',\n variant: 'filled' as TabListTabProps['variant'],\n }),\n [sizeProps, disabled]\n )\n\n useClickOutside(clickOutsideTargets, handleCloseMenu, {\n enabled: menuOpen,\n event: 'mousedown',\n })\n\n useEffect(() => {\n timerId.current = setTimeout(() => {\n if (!menuRef) return\n\n const items = Array.from(menuRef.querySelectorAll<HTMLElement>('[role=\"menuitem\"]')).filter((item) =>\n item.matches(SELECTORS_FOCUSABLE)\n )\n\n const activeItem = items.find((item) => item.matches('[aria-selected=\"true\"]'))\n\n if (activeItem) {\n activeItem.focus()\n } else if (items[0]) {\n items[0].focus()\n }\n\n timerId.current = null\n }, 100)\n\n return () => {\n if (timerId.current) {\n clearTimeout(timerId.current)\n }\n }\n }, [menuRef])\n\n if (!portalElement) {\n return null\n }\n\n return (\n <Floater\n open={menuOpen}\n portalElement={portalElement}\n placement='bottom-end'\n offset={8}\n hideArrow\n styles={{\n options: {\n zIndex: undefined,\n },\n wrapper: {\n cursor: disabled ? 'not-allowed' : 'pointer',\n },\n floater: {\n filter: 'none',\n opacity: 1,\n transitionDuration: '10ms',\n },\n }}\n getPopper={(popper) => {\n if (popper.state.elements.reference instanceof HTMLElement) {\n controlRef.current = popper.state.elements.reference\n }\n }}\n modifiers={{\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n removeRoles: {\n name: 'removeRoles',\n enabled: true,\n phase: 'beforeWrite',\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement) {\n const floaterElement = state.elements.popper.querySelector('[role=\"tooltip\"]')\n if (floaterElement) {\n floaterElement.removeAttribute('role')\n }\n }\n },\n },\n minWidth: {\n name: 'minWidth',\n enabled: true,\n phase: 'beforeWrite',\n requires: ['computeStyles'],\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n fn: ({ state }) => {\n state.styles.popper.minWidth = `${state.rects.reference.width}px`\n },\n // eslint-disable-next-line @typescript-eslint/ban-ts-comment\n // @ts-ignore\n effect: ({ state }) => {\n if (state.elements.popper instanceof HTMLElement && state.elements.reference instanceof HTMLElement) {\n state.elements.popper.style.display = 'flex'\n state.elements.popper.style.flexDirection = 'column'\n state.elements.popper.style.alignItems = 'stretch'\n state.elements.popper.style.minWidth = `${state.elements.reference.offsetWidth}px`\n }\n },\n },\n }}\n // eslint-disable-next-line react/no-unstable-nested-components\n component={() => (\n <Styled.Menu\n role='menu'\n aria-labelledby={controlId}\n ref={setMenuRef}\n palette={{\n backgroundColor: palette.menuBackgroundColor,\n }}\n onClick={(evt) => {\n if (evt.target instanceof HTMLElement && evt.target.closest('[role=\"menuitem\"]')) {\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n }\n }}\n onKeyDown={(evt) => {\n evt.stopPropagation()\n\n if (\n !(document.activeElement instanceof HTMLElement) ||\n !document.activeElement.matches('[role=\"menuitem\"]') ||\n (!keyboardKeys.Esc.validate(evt.key) &&\n !keyboardKeys.Tab.validate(evt.key) &&\n !keyboardKeys.Home.validate(evt.key) &&\n !keyboardKeys.End.validate(evt.key) &&\n !keyboardKeys.ArrowDown.validate(evt.key) &&\n !keyboardKeys.ArrowUp.validate(evt.key))\n ) {\n return\n }\n\n if (keyboardKeys.Esc.validate(evt.key) || keyboardKeys.Tab.validate(evt.key)) {\n evt.preventDefault()\n\n setMenuOpen(false)\n\n setTimeout(() => {\n controlRef.current?.focus()\n }, 100)\n\n return\n }\n\n const items = Array.from(evt.currentTarget.querySelectorAll<HTMLElement>('[role=\"menuitem\"]'))\n\n if (items.length === 0) return\n\n if (keyboardKeys.Home.validate(evt.key)) {\n evt.preventDefault()\n items[0].focus()\n } else if (keyboardKeys.End.validate(evt.key)) {\n evt.preventDefault()\n items[items.length - 1].focus()\n } else if (keyboardKeys.ArrowDown.validate(evt.key) || keyboardKeys.ArrowUp.validate(evt.key)) {\n evt.preventDefault()\n navigateVerticalList(evt.key, document.activeElement, items, SELECTORS_FOCUSABLE)\n }\n }}\n >\n <TabListTabsContext.Provider value={controlsContextProps}>\n <TabListPropsContext.Provider value={menuItemsContextProps}>\n {Children.map(menuItems, (item) => (\n <Styled.MenuItem role='none'>{item}</Styled.MenuItem>\n ))}\n </TabListPropsContext.Provider>\n </TabListTabsContext.Provider>\n </Styled.Menu>\n )}\n >\n {typeof control === 'function' ? control(controlProps) : <TabListTab {...controlProps} />}\n </Floater>\n )\n}\n\nexport { TabListMenuTab }\n"],"names":["TabListMenuTab","props","role","type","variant","size","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","disabled","text","control","menuItems","activeTab","firstTab","activationOnFocus","getTabIndex","onActiveTabChange","sizeProps","useMemo","palette","useMergedPalette","controlRef","useRef","menuRef","setMenuRef","useState","timerId","portalElement","useFloaterPortal","menuOpen","setMenuOpen","controlId","nanoid","clickOutsideTargets","handleCloseMenu","useCallback","menuHasActiveTab","Boolean","find","item","isValidElement","id","controlProps","active","tabIndex","addonRight","addonProps","_jsx","Styled","iconProps","rotate","name","preset","color","tabColor","colorHover","tabColorHover","colorActive","tabColorActive","colorDisabled","tabColorDisabled","colorActiveDisabled","tabColorActiveDisabled","backgroundColor","tabBackgroundColor","backgroundColorHover","tabBackgroundColorHover","backgroundColorActive","tabBackgroundColorActive","backgroundColorDisabled","tabBackgroundColorDisabled","backgroundColorActiveDisabled","tabBackgroundColorActiveDisabled","onClick","prev","onKeyDown","evt","keyboardKeys","Esc","validate","key","Tab","preventDefault","F10","shiftKey","ArrowDown","controlsContextProps","menuItemsContextProps","useClickOutside","enabled","event","useEffect","current","setTimeout","items","Array","from","querySelectorAll","filter","matches","SELECTORS_FOCUSABLE","activeItem","focus","clearTimeout","Floater","open","placement","offset","hideArrow","styles","options","zIndex","undefined","wrapper","cursor","floater","opacity","transitionDuration","getPopper","popper","state","elements","reference","HTMLElement","modifiers","removeRoles","phase","effect","floaterElement","querySelector","removeAttribute","minWidth","requires","fn","rects","width","style","display","flexDirection","alignItems","offsetWidth","component","ref","menuBackgroundColor","target","closest","stopPropagation","document","activeElement","Home","End","ArrowUp","currentTarget","length","navigateVerticalList","children","TabListTabsContext","Provider","value","TabListPropsContext","Children","map","TabListTab"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- 'use strict';var React=require('react');var styled=require('styled-components');var nanoid=require('nanoid');var withMergedProps=require('../../hocs/withMergedProps.js');var useResizable=require('../../hooks/useResizable.js');var misc=require('../../shared/utils/misc.js');var sizes=require('./sizes.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var FormInputLabel=require('../FormInputLabel/FormInputLabel.js');var InputLabel=require('../InputLabel/InputLabel.js');var sizes$1=require('../FormInput/sizes.js');var index=require('../../icon-pack/src/icons/ResizeHandle/index.js');const Textarea=withMergedProps.withMergedProps(React.forwardRef(((e,r)=>{const t=styled.useTheme();const{size:a="m",rows:i=2,maxRows:n=30,labelPosition:o="dynamic",primary:s=!0,width:l=t.defaultInputControlsWidth,autosize:m=!0,rounded:u=!0,color:c="mineShaft",placeholderColor:g="silver",autoRows:d,resize:h,contrast:p,inline:X,secondary:b,success:L,error:R,sizeXXS:S,sizeXS:z,sizeS:f,sizeM:x,sizeL:v,sizeXL:w,sizes:j,sizeUnits:M,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:q,marginXL:D,marginTop:F,marginTopXXS:k,marginTopXS:N,marginTopS:E,marginTopM:H,marginTopL:P,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,widthXXS:me,widthXS:ue,widthS:ce,widthM:ge,widthL:de,widthXL:he,preset:pe,palette:Xe,label:be,fluid:Le,className:Re,style:Se,disabled:ze,...fe}=e;const xe={size:a,sizeXXS:S,sizeXS:z,sizeS:f,sizeM:x,sizeL:v,sizeXL:w};const ve=React.useRef(null);const we=React.useRef(null);const je=React.useRef(null);React.useImperativeHandle(r,(()=>ve.current),[]);const[Me,Ce,Te]=useResizable.useResizable({target:je,direction:h});const ye=React.useMemo((()=>nanoid.nanoid()),[]);const[Ie,Be]=React.useState((()=>{const e=fe.value??fe.defaultValue;return typeof e=='string'&&e.length>0}));const[qe,De]=React.useState((()=>Math.min(i,n)));const Fe=pe==='brand'&&d||pe!=='brand'&&m?qe:Math.min(i,n);const ke=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Ne=React.useCallback((()=>{if(!ve.current)return;if(pe==='brand'){if(!we.current)return;we.current.value=ve.current.value;const e=Math.max(Math.round(we.current.scrollHeight/we.current.clientHeight),i);return void De(Math.min(e,n))}const e=getComputedStyle(ve.current);const r=parseFloat(e.lineHeight);const t=Math.max(Math.round((ve.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),i);De((e=>t>e?Math.min(t,n):ve.current&&!ve.current.value?i:e))}),[pe,i,n]);return React.useLayoutEffect((()=>{pe==='brand'&&typeof fe.value=='string'&&ve.current&&ve.current!==document.activeElement&&Be(fe.value.length>0)}),[pe,fe.value]),React.useEffect((()=>{const e=misc.createThrottledCallback(Ne,200);return(pe==='brand'&&d||pe!=='brand'&&m)&&(Ne(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,d,m,Ne]),pe!=='brand'?jsxRuntime.jsx(style.Root,{...fe,ref:ve,className:Re,style:Se,onChange:e=>{m&&Ne(),fe.onChange&&fe.onChange(e)},rows:Fe,color:c,rounded:u,placeholderColor:g,disabled:ze,error:R,fluid:Le,width:l,widthXXS:me,widthXS:ue,widthS:ce,widthM:ge,widthL:de,widthXL:he}):jsxRuntime.jsx(FormInputLabel.FormInputLabel,{...xe,ref:je,sizes:j,sizeUnits:M,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:q,marginXL:D,marginTop:F,marginTopXXS:k,marginTopXS:N,marginTopS:E,marginTopM:H,marginTopL:P,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,className:Re,style:Se,contrast:p,error:R,inline:X,disabled:ze,primary:s,secondary:b,success:L,palette:{color:ze?Xe.colorDisabled:Xe.color,backgroundColor:ze?Xe.backgroundColorDisabled:Xe.backgroundColor,backgroundColorHover:ze?Xe.backgroundColorDisabled:Xe.backgroundColorHover,borderColor:ze?Xe.borderColorDisabled:Xe.borderColor},onClick:()=>{ve.current&&ve.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==ve.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{ve.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(ve.current.value))},overflow:"hidden",input:jsxRuntime.jsxs(InputLabel.InputLabel,{...xe,sizes:sizes$1.SIZES,active:Ie,label:be,labelId:ye,labelPosition:o,children:[d?jsxRuntime.jsx(style.TextareaMimic,{ref:we,rows:1}):null,jsxRuntime.jsx(style.Textarea,{...fe,ref:ve,"aria-labelledby":be?ye:void 0,disabled:ze,onChange:e=>{d&&Ne(),fe.onChange&&fe.onChange(e)},rows:Fe,palette:{color:Xe.color,colorDisabled:Xe.colorDisabled,placeholderColor:Xe.placeholderColor,placeholderColorDisabled:Xe.placeholderColorDisabled}})]}),addon:h?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[Me?jsxRuntime.jsx(style.ResizeGlobals,{cursor:ke}):null,jsxRuntime.jsx(style.ResizeIcon,{size:"l",icon:jsxRuntime.jsx(index.ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:Ce,onKeyDown:Te,cursor:ke})]}):void 0})})),{displayName:"Textarea",sizes:sizes.SIZES});exports.COMPONENT_NAME="Textarea",exports.Textarea=Textarea;
1
+ 'use strict';var React=require('react');var styled=require('styled-components');var nanoid=require('nanoid');var iconPack=require('@foxford/icon-pack');var withMergedProps=require('../../hocs/withMergedProps.js');var useResizable=require('../../hooks/useResizable.js');var misc=require('../../shared/utils/misc.js');var sizes=require('./sizes.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var FormInputLabel=require('../FormInputLabel/FormInputLabel.js');var InputLabel=require('../InputLabel/InputLabel.js');var sizes$1=require('../FormInput/sizes.js');const Textarea=withMergedProps.withMergedProps(React.forwardRef(((e,r)=>{const t=styled.useTheme();const{size:a="m",rows:i=2,maxRows:n=30,labelPosition:o="dynamic",primary:s=!0,width:l=t.defaultInputControlsWidth,autosize:m=!0,rounded:c=!0,color:u="mineShaft",placeholderColor:g="silver",autoRows:d,resize:h,contrast:p,inline:X,secondary:b,success:L,error:R,sizeXXS:S,sizeXS:f,sizeS:z,sizeM:v,sizeL:w,sizeXL:x,sizes:M,sizeUnits:j,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:k,marginXL:q,marginTop:D,marginTopXXS:F,marginTopXS:N,marginTopS:P,marginTopM:E,marginTopL:H,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,widthXXS:me,widthXS:ce,widthS:ue,widthM:ge,widthL:de,widthXL:he,preset:pe,palette:Xe,label:be,fluid:Le,className:Re,style:Se,disabled:fe,...ze}=e;const ve={size:a,sizeXXS:S,sizeXS:f,sizeS:z,sizeM:v,sizeL:w,sizeXL:x};const we=React.useRef(null);const xe=React.useRef(null);const Me=React.useRef(null);React.useImperativeHandle(r,(()=>we.current),[]);const[je,Ce,Te]=useResizable.useResizable({target:Me,direction:h});const ye=React.useMemo((()=>nanoid.nanoid()),[]);const[Ie,Be]=React.useState((()=>{const e=ze.value??ze.defaultValue;return typeof e=='string'&&e.length>0}));const[ke,qe]=React.useState((()=>Math.min(i,n)));const De=pe==='brand'&&d||pe!=='brand'&&m?ke:Math.min(i,n);const Fe=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Ne=React.useCallback((()=>{if(!we.current)return;if(pe==='brand'){if(!xe.current)return;xe.current.value=we.current.value;const e=Math.max(Math.round(xe.current.scrollHeight/xe.current.clientHeight),i);return void qe(Math.min(e,n))}const e=getComputedStyle(we.current);const r=parseFloat(e.lineHeight);const t=Math.max(Math.round((we.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),i);qe((e=>t>e?Math.min(t,n):we.current&&!we.current.value?i:e))}),[pe,i,n]);return React.useLayoutEffect((()=>{pe==='brand'&&typeof ze.value=='string'&&we.current&&we.current!==document.activeElement&&Be(ze.value.length>0)}),[pe,ze.value]),React.useEffect((()=>{const e=misc.createThrottledCallback(Ne,200);return(pe==='brand'&&d||pe!=='brand'&&m)&&(Ne(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,d,m,Ne]),pe!=='brand'?jsxRuntime.jsx(style.Root,{...ze,ref:we,className:Re,style:Se,onChange:e=>{m&&Ne(),ze.onChange&&ze.onChange(e)},rows:De,color:u,rounded:c,placeholderColor:g,disabled:fe,error:R,fluid:Le,width:l,widthXXS:me,widthXS:ce,widthS:ue,widthM:ge,widthL:de,widthXL:he}):jsxRuntime.jsx(FormInputLabel.FormInputLabel,{...ve,ref:Me,sizes:M,sizeUnits:j,margin:C,marginXXS:T,marginXS:y,marginS:I,marginM:B,marginL:k,marginXL:q,marginTop:D,marginTopXXS:F,marginTopXS:N,marginTopS:P,marginTopM:E,marginTopL:H,marginTopXL:O,marginRight:U,marginRightXXS:Z,marginRightXS:$,marginRightS:A,marginRightM:G,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:_,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:te,marginLeftXXS:ae,marginLeftXS:ie,marginLeftS:ne,marginLeftM:oe,marginLeftL:se,marginLeftXL:le,className:Re,style:Se,contrast:p,error:R,inline:X,disabled:fe,primary:s,secondary:b,success:L,palette:{color:fe?Xe.colorDisabled:Xe.color,backgroundColor:fe?Xe.backgroundColorDisabled:Xe.backgroundColor,backgroundColorHover:fe?Xe.backgroundColorDisabled:Xe.backgroundColorHover,borderColor:fe?Xe.borderColorDisabled:Xe.borderColor},onClick:()=>{we.current&&we.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==we.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{we.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(we.current.value))},overflow:"hidden",input:jsxRuntime.jsxs(InputLabel.InputLabel,{...ve,sizes:sizes$1.SIZES,active:Ie,label:be,labelId:ye,labelPosition:o,children:[d?jsxRuntime.jsx(style.TextareaMimic,{ref:xe,rows:1}):null,jsxRuntime.jsx(style.Textarea,{...ze,ref:we,"aria-labelledby":be?ye:void 0,disabled:fe,onChange:e=>{d&&Ne(),ze.onChange&&ze.onChange(e)},rows:De,palette:{color:Xe.color,colorDisabled:Xe.colorDisabled,placeholderColor:Xe.placeholderColor,placeholderColorDisabled:Xe.placeholderColorDisabled}})]}),addon:h?jsxRuntime.jsxs(jsxRuntime.Fragment,{children:[je?jsxRuntime.jsx(style.ResizeGlobals,{cursor:Fe}):null,jsxRuntime.jsx(style.ResizeIcon,{size:"l",icon:jsxRuntime.jsx(iconPack.ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:Ce,onKeyDown:Te,cursor:Fe})]}):void 0})})),{displayName:"Textarea",sizes:sizes.SIZES});exports.COMPONENT_NAME="Textarea",exports.Textarea=Textarea;
2
2
  //# sourceMappingURL=Textarea.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.js","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","jsxs","InputLabel","SIZES_FORM_INPUT","SIZES","children","jsx","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName"],"mappings":"umBAgCMA,MAAAA,SAA2DC,gBAAAA,gBAC/DC,MAAAA,YAA4D,CAACC,EAAOC,KAClE,MAAMC,EAAQC,OAAAA,WAEd,MAAMC,KACJA,EAAO,IAAGC,KACVA,EAAO,EAACC,QACRA,EAAU,GAAEC,cACZA,EAAgB,UAASC,QACzBA,GAAU,EAAIC,MACdA,EAAQP,EAAMQ,0BAAyBC,SACvCA,GAAW,EAAIC,QACfA,GAAU,EAAIC,MACdA,EAAQ,YAAWC,iBACnBA,EAAmB,SAAQC,SAC3BA,EAAQC,OACRA,EAAMC,SACNA,EAAQC,OACRA,EAAMC,UACNA,EAASC,QACTA,EAAOC,MACPA,EAAKC,QACLA,EAAOC,OACPA,EAAMC,MACNA,EAAKC,MACLA,EAAKC,MACLA,EAAKC,OACLA,EAAMC,MACNA,EAAKC,UACLA,EAASC,OACTA,EAAMC,UACNA,EAASC,SACTA,EAAQC,QACRA,EAAOC,QACPA,EAAOC,QACPA,EAAOC,SACPA,EAAQC,UACRA,EAASC,aACTA,EAAYC,YACZA,EAAWC,WACXA,EAAUC,WACVA,EAAUC,WACVA,EAAUC,YACVA,EAAWC,YACXA,EAAWC,eACXA,EAAcC,cACdA,EAAaC,aACbA,EAAYC,aACZA,EAAYC,aACZA,EAAYC,cACZA,EAAaC,aACbA,EAAYC,gBACZA,EAAeC,eACfA,EAAcC,cACdA,EAAaC,cACbA,EAAaC,cACbA,GAAaC,eACbA,GAAcC,WACdA,GAAUC,cACVA,GAAaC,aACbA,GAAYC,YACZA,GAAWC,YACXA,GAAWC,YACXA,GAAWC,aACXA,GAAYC,SACZA,GAAQC,QACRA,GAAOC,OACPA,GAAMC,OACNA,GAAMC,OACNA,GAAMC,QACNA,GAAOC,OACPA,GAAMC,QACNA,GAAOC,MACPA,GAAKC,MACLA,GAAKC,UACLA,SACAC,GAAKC,SACLA,MACGC,IACD9E,EAEJ,MAAM+E,GAAY,CAChB3E,OACAkB,UACAC,SACAC,QACAC,QACAC,QACAC,UAGF,MAAMqD,GAAcC,aAA4B,MAEhD,MAAMC,GAAmBD,aAA4B,MAErD,MAAME,GAAoBF,aAAuB,MAEjDG,MAAAA,oBAAoBnF,GAAc,IAAM+E,GAAYK,SAAgC,IAEpF,MAAOC,GAAUC,GAAmBC,IAAuBC,aAAAA,aAA8C,CACvGC,OAAQP,GACRQ,UAAW3E,IAGb,MAAM4E,GAAUC,MAAOA,SAAC,IAAMC,OAAAA,UAAU,IAExC,MAAOC,GAAQC,IAAaC,MAAQA,UAAC,KACnC,MAAMC,EAAYpB,GAAcqB,OAASrB,GAAcsB,aAEvD,cAAcF,GAAc,UAAYA,EAAUG,OAAS,CAAC,IAG9D,MAAOC,GAAeC,IAAoBN,MAAQA,UAAC,IAAMO,KAAKC,IAAIpG,EAAMC,KAExE,MAAMoG,GACHnC,KAAW,SAAWxD,GAAcwD,KAAW,SAAW5D,EAAY2F,GAAgBE,KAAKC,IAAIpG,EAAMC,GAExG,MAAMqG,GAAe3F,IAAW,aAAe,YAAcA,IAAW,WAAa,YAAc,cAEnG,MAAM4F,GAAsBC,MAAAA,aAAY,KACtC,IAAK7B,GAAYK,QAAS,OAE1B,GAAId,KAAW,QAAS,CACtB,IAAKW,GAAiBG,QAAS,OAE/BH,GAAiBG,QAAQc,MAAQnB,GAAYK,QAAQc,MAErD,MAAMW,EAAWN,KAAKO,IACpBP,KAAKQ,MAAM9B,GAAiBG,QAAQ4B,aAAe/B,GAAiBG,QAAQ6B,cAC5E7G,GAKF,YAFAkG,GAAiBC,KAAKC,IAAIK,EAAUxG,GAGtC,CAEA,MAAM6G,EAASC,iBAAiBpC,GAAYK,SAE5C,MAAMgC,EAAaC,WAAWH,EAAOE,YAErC,MAAMP,EAAWN,KAAKO,IACpBP,KAAKQ,OACFhC,GAAYK,QAAQ4B,aAAeK,WAAWH,EAAOI,YAAcD,WAAWH,EAAOK,iBACnFC,OAAOC,MAAML,GAAcC,WAAWH,EAAOQ,UAAY,IAAMN,IAEpEhH,GAGFkG,IAAkBqB,GACZd,EAAWc,EAAiBpB,KAAKC,IAAIK,EAAUxG,GAC/C0E,GAAYK,UAAYL,GAAYK,QAAQc,MAAc9F,EAEvDuH,GACP,GACD,CAACrD,GAAQlE,EAAMC,IA0BlB,OAxBAuH,MAAAA,iBAAgB,KAEZtD,KAAW,gBACJO,GAAcqB,OAAU,UAC/BnB,GAAYK,SACZL,GAAYK,UAAYyC,SAASC,eAEjC/B,GAAUlB,GAAcqB,MAAME,OAAS,EACzC,GACC,CAAC9B,GAAQO,GAAcqB,QAE1B6B,MAAAA,WAAU,KACR,MAAMC,EAAeC,KAAAA,wBAAiCtB,GAAqB,KAO3E,OALKrC,KAAW,SAAWxD,GAAcwD,KAAW,SAAW5D,KAC7DiG,KACAuB,OAAOC,iBAAiB,SAAUH,IAG7B,KACLE,OAAOE,oBAAoB,SAAUJ,EAAa,CACnD,GACA,CAAC1D,GAAQxD,EAAUJ,EAAUiG,KAE5BrC,KAAW,QAEX+D,WAAAA,IAACC,MAAAA,KAAW,IACNzD,GACJ0D,IAAKxD,GACLL,UAAWA,GACXC,MAAOA,GACP6D,SAAWC,IACL/H,GAAUiG,KACV9B,GAAc2D,UAAU3D,GAAc2D,SAASC,EAAI,EAEzDrI,KAAMqG,GACN7F,MAAOA,EACPD,QAASA,EACTE,iBAAkBA,EAClB+D,SAAUA,GACVxD,MAAOA,EACPqD,MAAOA,GACPjE,MAAOA,EACPwD,SAAUA,GACVC,QAASA,GACTC,OAAQA,GACRC,OAAQA,GACRC,OAAQA,GACRC,QAASA,KAMbgE,WAAAA,IAACK,eAAAA,eAAc,IACT5D,GACJyD,IAAKrD,GACLvD,MAAOA,EACPC,UAAWA,EACXC,OAAQA,EACRC,UAAWA,EACXC,SAAUA,EACVC,QAASA,EACTC,QAASA,EACTC,QAASA,EACTC,SAAUA,EACVC,UAAWA,EACXC,aAAcA,EACdC,YAAaA,EACbC,WAAYA,EACZC,WAAYA,EACZC,WAAYA,EACZC,YAAaA,EACbC,YAAaA,EACbC,eAAgBA,EAChBC,cAAeA,EACfC,aAAcA,EACdC,aAAcA,EACdC,aAAcA,EACdC,cAAeA,EACfC,aAAcA,EACdC,gBAAiBA,EACjBC,eAAgBA,EAChBC,cAAeA,EACfC,cAAeA,EACfC,cAAeA,GACfC,eAAgBA,GAChBC,WAAYA,GACZC,cAAeA,GACfC,aAAcA,GACdC,YAAaA,GACbC,YAAaA,GACbC,YAAaA,GACbC,aAAcA,GACdW,UAAWA,GACXC,MAAOA,GACP3D,SAAUA,EACVI,MAAOA,EACPH,OAAQA,EACR2D,SAAUA,GACVrE,QAASA,EACTW,UAAWA,EACXC,QAASA,EACToD,QAAS,CACP3D,MAAOgE,GAAWL,GAAQoE,cAAgBpE,GAAQ3D,MAClDgI,gBAAiBhE,GAAWL,GAAQsE,wBAA0BtE,GAAQqE,gBACtEE,qBAAsBlE,GAAWL,GAAQsE,wBAA0BtE,GAAQuE,qBAC3EC,YAAanE,GAAWL,GAAQyE,oBAAsBzE,GAAQwE,aAEhEE,QAASA,KACHlE,GAAYK,SACdL,GAAYK,QAAQ8D,OACtB,EAEFC,QAASA,KACPpD,IAAU,EAAK,EAEjBqD,cAAgBX,IACVA,EAAIhD,SAAWV,GAAYK,SAAaqD,EAAIhD,kBAAkB4D,MAGlEZ,EAAIa,gBAAgB,EAEtBC,OAASd,IACH1D,GAAYK,UAAYqD,EAAIe,cAAcC,SAAShB,EAAIiB,gBACzD3D,GAAU4D,QAAQ5E,GAAYK,QAAQc,OACxC,EAEF0D,SAAS,SACTC,MACEC,WAAAC,KAACC,sBAAU,IACLlF,GACJnD,MAAOsI,QAAiBC,MACxBpE,OAAQA,GACRtB,MAAOA,GACPmB,QAASA,GACTrF,cAAeA,EAAc6J,UAE5BrJ,EAAWuH,WAAA+B,IAAC9B,oBAAoB,CAACC,IAAKtD,GAAkB7E,KAAM,IAAQ,KACvEiI,WAAA+B,IAAC9B,eAAe,IACVzD,GACJ0D,IAAKxD,GACL,kBAAiBP,GAAQmB,QAAU0E,EACnCzF,SAAUA,GACV4D,SAAWC,IACL3H,GAAU6F,KACV9B,GAAc2D,UAAU3D,GAAc2D,SAASC,EAAI,EAEzDrI,KAAMqG,GACNlC,QAAS,CACP3D,MAAO2D,GAAQ3D,MACf+H,cAAepE,GAAQoE,cACvB9H,iBAAkB0D,GAAQ1D,iBAC1ByJ,yBAA0B/F,GAAQ+F,+BAK1CC,MACExJ,EACE+I,WAAAC,KAAAS,oBAAA,CAAAL,UACG9E,GAAWgD,WAAA+B,IAAC9B,oBAAoB,CAACmC,OAAQ/D,KAAmB,KAC7D2B,WAAA+B,IAAC9B,iBAAiB,CAChBnI,KAAK,IACLuK,KAAMrC,WAAAA,IAACsC,MAAYA,iBACnB/J,MAAM,8BACNgK,SAAU,EACVxB,cAAe9D,GACfuF,UAAWtF,GACXkF,OAAQ/D,aAGV2D,GAEN,IAGN,CACES,YAvVmB,WAwVnBnJ,MAAOuI,MAAAA,+BAxVY"}
1
+ {"version":3,"file":"Textarea.js","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","jsxs","InputLabel","SIZES_FORM_INPUT","SIZES","children","jsx","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{forwardRef,useRef,useImperativeHandle,useMemo,useState,useCallback,useLayoutEffect,useEffect}from'react';import{useTheme}from'styled-components';import{nanoid}from'nanoid';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{useResizable}from'../../hooks/useResizable.mjs';import{createThrottledCallback}from'../../shared/utils/misc.mjs';import{SIZES}from'./sizes.mjs';import{Root,TextareaMimic,Textarea as Textarea$1,ResizeGlobals,ResizeIcon}from'./style.mjs';import{jsx,jsxs,Fragment}from'react/jsx-runtime';import{FormInputLabel}from'../FormInputLabel/FormInputLabel.mjs';import{InputLabel}from'../InputLabel/InputLabel.mjs';import{SIZES as SIZES$1}from'../FormInput/sizes.mjs';import{ResizeHandle}from'../../icon-pack/src/icons/ResizeHandle/index.mjs';const COMPONENT_NAME='Textarea';const Textarea=withMergedProps(forwardRef(((e,r)=>{const o=useTheme();const{size:t="m",rows:a=2,maxRows:n=30,labelPosition:i="dynamic",primary:s=!0,width:m=o.defaultInputControlsWidth,autosize:l=!0,rounded:g=!0,color:c="mineShaft",placeholderColor:d="silver",autoRows:u,resize:h,contrast:p,inline:f,secondary:S,success:X,error:b,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:R,sizeL:M,sizeXL:T,sizes:C,sizeUnits:x,margin:v,marginXXS:j,marginXS:I,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he,preset:pe,palette:fe,label:Se,fluid:Xe,className:be,style:Le,disabled:ze,...we}=e;const Re={size:t,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:R,sizeL:M,sizeXL:T};const Me=useRef(null);const Te=useRef(null);const Ce=useRef(null);useImperativeHandle(r,(()=>Me.current),[]);const[xe,ve,je]=useResizable({target:Ce,direction:h});const Ie=useMemo((()=>nanoid()),[]);const[ye,Be]=useState((()=>{const e=we.value??we.defaultValue;return typeof e=='string'&&e.length>0}));const[Ee,Ne]=useState((()=>Math.min(a,n)));const ke=pe==='brand'&&u||pe!=='brand'&&l?Ee:Math.min(a,n);const De=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Fe=useCallback((()=>{if(!Me.current)return;if(pe==='brand'){if(!Te.current)return;Te.current.value=Me.current.value;const e=Math.max(Math.round(Te.current.scrollHeight/Te.current.clientHeight),a);return void Ne(Math.min(e,n))}const e=getComputedStyle(Me.current);const r=parseFloat(e.lineHeight);const o=Math.max(Math.round((Me.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),a);Ne((e=>o>e?Math.min(o,n):Me.current&&!Me.current.value?a:e))}),[pe,a,n]);return useLayoutEffect((()=>{pe==='brand'&&typeof we.value=='string'&&Me.current&&Me.current!==document.activeElement&&Be(we.value.length>0)}),[pe,we.value]),useEffect((()=>{const e=createThrottledCallback(Fe,200);return(pe==='brand'&&u||pe!=='brand'&&l)&&(Fe(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,u,l,Fe]),pe!=='brand'?jsx(Root,{...we,ref:Me,className:be,style:Le,onChange:e=>{l&&Fe(),we.onChange&&we.onChange(e)},rows:ke,color:c,rounded:g,placeholderColor:d,disabled:ze,error:b,fluid:Xe,width:m,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he}):jsx(FormInputLabel,{...Re,ref:Ce,sizes:C,sizeUnits:x,margin:v,marginXXS:j,marginXS:I,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,className:be,style:Le,contrast:p,error:b,inline:f,disabled:ze,primary:s,secondary:S,success:X,palette:{color:ze?fe.colorDisabled:fe.color,backgroundColor:ze?fe.backgroundColorDisabled:fe.backgroundColor,backgroundColorHover:ze?fe.backgroundColorDisabled:fe.backgroundColorHover,borderColor:ze?fe.borderColorDisabled:fe.borderColor},onClick:()=>{Me.current&&Me.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==Me.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{Me.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(Me.current.value))},overflow:"hidden",input:jsxs(InputLabel,{...Re,sizes:SIZES$1,active:ye,label:Se,labelId:Ie,labelPosition:i,children:[u?jsx(TextareaMimic,{ref:Te,rows:1}):null,jsx(Textarea$1,{...we,ref:Me,"aria-labelledby":Se?Ie:void 0,disabled:ze,onChange:e=>{u&&Fe(),we.onChange&&we.onChange(e)},rows:ke,palette:{color:fe.color,colorDisabled:fe.colorDisabled,placeholderColor:fe.placeholderColor,placeholderColorDisabled:fe.placeholderColorDisabled}})]}),addon:h?jsxs(Fragment,{children:[xe?jsx(ResizeGlobals,{cursor:De}):null,jsx(ResizeIcon,{size:"l",icon:jsx(ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:ve,onKeyDown:je,cursor:De})]}):void 0})})),{displayName:"Textarea",sizes:SIZES});export{COMPONENT_NAME,Textarea};
1
+ import{forwardRef,useRef,useImperativeHandle,useMemo,useState,useCallback,useLayoutEffect,useEffect}from'react';import{useTheme}from'styled-components';import{nanoid}from'nanoid';import{ResizeHandle}from'@foxford/icon-pack';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{useResizable}from'../../hooks/useResizable.mjs';import{createThrottledCallback}from'../../shared/utils/misc.mjs';import{SIZES}from'./sizes.mjs';import{Root,TextareaMimic,Textarea as Textarea$1,ResizeGlobals,ResizeIcon}from'./style.mjs';import{jsx,jsxs,Fragment}from'react/jsx-runtime';import{FormInputLabel}from'../FormInputLabel/FormInputLabel.mjs';import{InputLabel}from'../InputLabel/InputLabel.mjs';import{SIZES as SIZES$1}from'../FormInput/sizes.mjs';const COMPONENT_NAME='Textarea';const Textarea=withMergedProps(forwardRef(((e,r)=>{const o=useTheme();const{size:t="m",rows:a=2,maxRows:n=30,labelPosition:i="dynamic",primary:s=!0,width:m=o.defaultInputControlsWidth,autosize:l=!0,rounded:g=!0,color:c="mineShaft",placeholderColor:d="silver",autoRows:u,resize:h,contrast:p,inline:f,secondary:S,success:X,error:b,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:M,sizeL:R,sizeXL:T,sizes:C,sizeUnits:x,margin:v,marginXXS:I,marginXS:j,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he,preset:pe,palette:fe,label:Se,fluid:Xe,className:be,style:Le,disabled:ze,...we}=e;const Me={size:t,sizeXXS:L,sizeXS:z,sizeS:w,sizeM:M,sizeL:R,sizeXL:T};const Re=useRef(null);const Te=useRef(null);const Ce=useRef(null);useImperativeHandle(r,(()=>Re.current),[]);const[xe,ve,Ie]=useResizable({target:Ce,direction:h});const je=useMemo((()=>nanoid()),[]);const[ye,Be]=useState((()=>{const e=we.value??we.defaultValue;return typeof e=='string'&&e.length>0}));const[Ee,Ne]=useState((()=>Math.min(a,n)));const ke=pe==='brand'&&u||pe!=='brand'&&l?Ee:Math.min(a,n);const De=h==='horizontal'?'ew-resize':h==='vertical'?'ns-resize':'nwse-resize';const Fe=useCallback((()=>{if(!Re.current)return;if(pe==='brand'){if(!Te.current)return;Te.current.value=Re.current.value;const e=Math.max(Math.round(Te.current.scrollHeight/Te.current.clientHeight),a);return void Ne(Math.min(e,n))}const e=getComputedStyle(Re.current);const r=parseFloat(e.lineHeight);const o=Math.max(Math.round((Re.current.scrollHeight-parseFloat(e.paddingTop)-parseFloat(e.paddingBottom))/(Number.isNaN(r)?parseFloat(e.fontSize)*1.2:r)),a);Ne((e=>o>e?Math.min(o,n):Re.current&&!Re.current.value?a:e))}),[pe,a,n]);return useLayoutEffect((()=>{pe==='brand'&&typeof we.value=='string'&&Re.current&&Re.current!==document.activeElement&&Be(we.value.length>0)}),[pe,we.value]),useEffect((()=>{const e=createThrottledCallback(Fe,200);return(pe==='brand'&&u||pe!=='brand'&&l)&&(Fe(),window.addEventListener('resize',e)),()=>{window.removeEventListener('resize',e)}}),[pe,u,l,Fe]),pe!=='brand'?jsx(Root,{...we,ref:Re,className:be,style:Le,onChange:e=>{l&&Fe(),we.onChange&&we.onChange(e)},rows:ke,color:c,rounded:g,placeholderColor:d,disabled:ze,error:b,fluid:Xe,width:m,widthXXS:le,widthXS:ge,widthS:ce,widthM:de,widthL:ue,widthXL:he}):jsx(FormInputLabel,{...Me,ref:Ce,sizes:C,sizeUnits:x,margin:v,marginXXS:I,marginXS:j,marginS:y,marginM:B,marginL:E,marginXL:N,marginTop:k,marginTopXXS:D,marginTopXS:F,marginTopS:H,marginTopM:P,marginTopL:Z,marginTopXL:O,marginRight:$,marginRightXXS:A,marginRightXS:G,marginRightS:U,marginRightM:_,marginRightL:K,marginRightXL:V,marginBottom:W,marginBottomXXS:q,marginBottomXS:J,marginBottomS:Q,marginBottomM:Y,marginBottomL:ee,marginBottomXL:re,marginLeft:oe,marginLeftXXS:te,marginLeftXS:ae,marginLeftS:ne,marginLeftM:ie,marginLeftL:se,marginLeftXL:me,className:be,style:Le,contrast:p,error:b,inline:f,disabled:ze,primary:s,secondary:S,success:X,palette:{color:ze?fe.colorDisabled:fe.color,backgroundColor:ze?fe.backgroundColorDisabled:fe.backgroundColor,backgroundColorHover:ze?fe.backgroundColorDisabled:fe.backgroundColorHover,borderColor:ze?fe.borderColorDisabled:fe.borderColor},onClick:()=>{Re.current&&Re.current.focus()},onFocus:()=>{Be(!0)},onPointerDown:e=>{e.target!==Re.current&&e.target instanceof Node&&e.preventDefault()},onBlur:e=>{Re.current&&!e.currentTarget.contains(e.relatedTarget)&&Be(Boolean(Re.current.value))},overflow:"hidden",input:jsxs(InputLabel,{...Me,sizes:SIZES$1,active:ye,label:Se,labelId:je,labelPosition:i,children:[u?jsx(TextareaMimic,{ref:Te,rows:1}):null,jsx(Textarea$1,{...we,ref:Re,"aria-labelledby":Se?je:void 0,disabled:ze,onChange:e=>{u&&Fe(),we.onChange&&we.onChange(e)},rows:ke,palette:{color:fe.color,colorDisabled:fe.colorDisabled,placeholderColor:fe.placeholderColor,placeholderColorDisabled:fe.placeholderColorDisabled}})]}),addon:h?jsxs(Fragment,{children:[xe?jsx(ResizeGlobals,{cursor:De}):null,jsx(ResizeIcon,{size:"l",icon:jsx(ResizeHandle,{}),color:"border-onmain-default-small",tabIndex:0,onPointerDown:ve,onKeyDown:Ie,cursor:De})]}):void 0})})),{displayName:"Textarea",sizes:SIZES});export{COMPONENT_NAME,Textarea};
2
2
  //# sourceMappingURL=Textarea.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"Textarea.mjs","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["COMPONENT_NAME","Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","InputLabel","SIZES_FORM_INPUT","children","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName","SIZES"],"mappings":"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"}
1
+ {"version":3,"file":"Textarea.mjs","sources":["../../../../src/components/Textarea/Textarea.tsx"],"sourcesContent":["import {\n forwardRef,\n useImperativeHandle,\n useLayoutEffect,\n useEffect,\n useRef,\n useState,\n useMemo,\n useCallback,\n} from 'react'\nimport { useTheme } from 'styled-components'\nimport { nanoid } from 'nanoid'\nimport { ResizeHandle } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport { InputLabel } from 'components/InputLabel'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { useResizable } from 'hooks/useResizable'\nimport { createThrottledCallback } from 'shared/utils/misc'\nimport { FormInputLabel } from 'components/FormInputLabel'\nimport { SIZES as SIZES_FORM_INPUT } from 'components/FormInput'\nimport { SIZES } from './sizes'\nimport * as Styled from './style'\nimport type { TextareaProps } from './types'\n\nconst COMPONENT_NAME = 'Textarea'\n\n/**\n *\n * Компонент для приема многострочного ввода.\n *\n * Поддерживается \"ref\" и все нативные атрибуты \\<textarea\\> элемента.\n */\nconst Textarea: React.ForwardRefExoticComponent<TextareaProps> = withMergedProps<TextareaProps, HTMLTextAreaElement>(\n forwardRef<HTMLTextAreaElement, MergedProps<TextareaProps>>((props, forwardedRef) => {\n const theme = useTheme()\n\n const {\n size = 'm',\n rows = 2,\n maxRows = 30,\n labelPosition = 'dynamic',\n primary = true,\n width = theme.defaultInputControlsWidth,\n autosize = true,\n rounded = true,\n color = 'mineShaft',\n placeholderColor = 'silver',\n autoRows,\n resize,\n contrast,\n inline,\n secondary,\n success,\n error,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n sizes,\n sizeUnits,\n margin,\n marginXXS,\n marginXS,\n marginS,\n marginM,\n marginL,\n marginXL,\n marginTop,\n marginTopXXS,\n marginTopXS,\n marginTopS,\n marginTopM,\n marginTopL,\n marginTopXL,\n marginRight,\n marginRightXXS,\n marginRightXS,\n marginRightS,\n marginRightM,\n marginRightL,\n marginRightXL,\n marginBottom,\n marginBottomXXS,\n marginBottomXS,\n marginBottomS,\n marginBottomM,\n marginBottomL,\n marginBottomXL,\n marginLeft,\n marginLeftXXS,\n marginLeftXS,\n marginLeftS,\n marginLeftM,\n marginLeftL,\n marginLeftXL,\n widthXXS,\n widthXS,\n widthS,\n widthM,\n widthL,\n widthXL,\n preset,\n palette,\n label,\n fluid,\n className,\n style,\n disabled,\n ...textareaProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n const textareaRef = useRef<HTMLTextAreaElement>(null)\n\n const textareaMimicRef = useRef<HTMLTextAreaElement>(null)\n\n const formInputLabelRef = useRef<HTMLDivElement>(null)\n\n useImperativeHandle(forwardedRef, () => textareaRef.current as HTMLTextAreaElement, [])\n\n const [resizing, handleResizeStart, handleResizeOnNudge] = useResizable<HTMLDivElement, HTMLSpanElement>({\n target: formInputLabelRef,\n direction: resize,\n })\n\n const labelId = useMemo(() => nanoid(), [])\n\n const [active, setActive] = useState(() => {\n const valueInit = textareaProps.value ?? textareaProps.defaultValue\n\n return typeof valueInit === 'string' && valueInit.length > 0\n })\n\n const [autoRowsCount, setAutoRowsCount] = useState(() => Math.min(rows, maxRows))\n\n const rowsVisible =\n (preset === 'brand' && autoRows) || (preset !== 'brand' && autosize) ? autoRowsCount : Math.min(rows, maxRows)\n\n const cursorResize = resize === 'horizontal' ? 'ew-resize' : resize === 'vertical' ? 'ns-resize' : 'nwse-resize'\n\n const updateAutoRowsCount = useCallback(() => {\n if (!textareaRef.current) return\n\n if (preset === 'brand') {\n if (!textareaMimicRef.current) return\n\n textareaMimicRef.current.value = textareaRef.current.value\n\n const nextRows = Math.max(\n Math.round(textareaMimicRef.current.scrollHeight / textareaMimicRef.current.clientHeight),\n rows\n )\n\n setAutoRowsCount(Math.min(nextRows, maxRows))\n\n return\n }\n\n const styles = getComputedStyle(textareaRef.current)\n\n const lineHeight = parseFloat(styles.lineHeight)\n\n const nextRows = Math.max(\n Math.round(\n (textareaRef.current.scrollHeight - parseFloat(styles.paddingTop) - parseFloat(styles.paddingBottom)) /\n (Number.isNaN(lineHeight) ? parseFloat(styles.fontSize) * 1.2 : lineHeight)\n ),\n rows\n )\n\n setAutoRowsCount((prevRows) => {\n if (nextRows > prevRows) return Math.min(nextRows, maxRows)\n if (textareaRef.current && !textareaRef.current.value) return rows\n\n return prevRows\n })\n }, [preset, rows, maxRows])\n\n useLayoutEffect(() => {\n if (\n preset === 'brand' &&\n typeof textareaProps.value === 'string' &&\n textareaRef.current &&\n textareaRef.current !== document.activeElement\n ) {\n setActive(textareaProps.value.length > 0)\n }\n }, [preset, textareaProps.value])\n\n useEffect(() => {\n const handleResize = createThrottledCallback<UIEvent>(updateAutoRowsCount, 200)\n\n if ((preset === 'brand' && autoRows) || (preset !== 'brand' && autosize)) {\n updateAutoRowsCount()\n window.addEventListener('resize', handleResize)\n }\n\n return () => {\n window.removeEventListener('resize', handleResize)\n }\n }, [preset, autoRows, autosize, updateAutoRowsCount])\n\n if (preset !== 'brand') {\n return (\n <Styled.Root\n {...textareaProps}\n ref={textareaRef}\n className={className}\n style={style}\n onChange={(evt) => {\n if (autosize) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n color={color}\n rounded={rounded}\n placeholderColor={placeholderColor}\n disabled={disabled}\n error={error}\n fluid={fluid}\n width={width}\n widthXXS={widthXXS}\n widthXS={widthXS}\n widthS={widthS}\n widthM={widthM}\n widthL={widthL}\n widthXL={widthXL}\n />\n )\n }\n\n return (\n <FormInputLabel\n {...sizeProps}\n ref={formInputLabelRef}\n sizes={sizes}\n sizeUnits={sizeUnits}\n margin={margin}\n marginXXS={marginXXS}\n marginXS={marginXS}\n marginS={marginS}\n marginM={marginM}\n marginL={marginL}\n marginXL={marginXL}\n marginTop={marginTop}\n marginTopXXS={marginTopXXS}\n marginTopXS={marginTopXS}\n marginTopS={marginTopS}\n marginTopM={marginTopM}\n marginTopL={marginTopL}\n marginTopXL={marginTopXL}\n marginRight={marginRight}\n marginRightXXS={marginRightXXS}\n marginRightXS={marginRightXS}\n marginRightS={marginRightS}\n marginRightM={marginRightM}\n marginRightL={marginRightL}\n marginRightXL={marginRightXL}\n marginBottom={marginBottom}\n marginBottomXXS={marginBottomXXS}\n marginBottomXS={marginBottomXS}\n marginBottomS={marginBottomS}\n marginBottomM={marginBottomM}\n marginBottomL={marginBottomL}\n marginBottomXL={marginBottomXL}\n marginLeft={marginLeft}\n marginLeftXXS={marginLeftXXS}\n marginLeftXS={marginLeftXS}\n marginLeftS={marginLeftS}\n marginLeftM={marginLeftM}\n marginLeftL={marginLeftL}\n marginLeftXL={marginLeftXL}\n className={className}\n style={style}\n contrast={contrast}\n error={error}\n inline={inline}\n disabled={disabled}\n primary={primary}\n secondary={secondary}\n success={success}\n palette={{\n color: disabled ? palette.colorDisabled : palette.color,\n backgroundColor: disabled ? palette.backgroundColorDisabled : palette.backgroundColor,\n backgroundColorHover: disabled ? palette.backgroundColorDisabled : palette.backgroundColorHover,\n borderColor: disabled ? palette.borderColorDisabled : palette.borderColor,\n }}\n onClick={() => {\n if (textareaRef.current) {\n textareaRef.current.focus()\n }\n }}\n onFocus={() => {\n setActive(true)\n }}\n onPointerDown={(evt) => {\n if (evt.target === textareaRef.current || !(evt.target instanceof Node)) {\n return\n }\n evt.preventDefault()\n }}\n onBlur={(evt) => {\n if (textareaRef.current && !evt.currentTarget.contains(evt.relatedTarget)) {\n setActive(Boolean(textareaRef.current.value))\n }\n }}\n overflow='hidden'\n input={\n <InputLabel\n {...sizeProps}\n sizes={SIZES_FORM_INPUT}\n active={active}\n label={label}\n labelId={labelId}\n labelPosition={labelPosition}\n >\n {autoRows ? <Styled.TextareaMimic ref={textareaMimicRef} rows={1} /> : null}\n <Styled.Textarea\n {...textareaProps}\n ref={textareaRef}\n aria-labelledby={label ? labelId : undefined}\n disabled={disabled}\n onChange={(evt) => {\n if (autoRows) updateAutoRowsCount()\n if (textareaProps.onChange) textareaProps.onChange(evt)\n }}\n rows={rowsVisible}\n palette={{\n color: palette.color,\n colorDisabled: palette.colorDisabled,\n placeholderColor: palette.placeholderColor,\n placeholderColorDisabled: palette.placeholderColorDisabled,\n }}\n />\n </InputLabel>\n }\n addon={\n resize ? (\n <>\n {resizing ? <Styled.ResizeGlobals cursor={cursorResize} /> : null}\n <Styled.ResizeIcon\n size='l'\n icon={<ResizeHandle />}\n color='border-onmain-default-small'\n tabIndex={0}\n onPointerDown={handleResizeStart}\n onKeyDown={handleResizeOnNudge}\n cursor={cursorResize}\n />\n </>\n ) : undefined\n }\n />\n )\n }),\n {\n displayName: COMPONENT_NAME,\n sizes: SIZES,\n }\n)\n\nexport { Textarea, COMPONENT_NAME }\n"],"names":["COMPONENT_NAME","Textarea","withMergedProps","forwardRef","props","forwardedRef","theme","useTheme","size","rows","maxRows","labelPosition","primary","width","defaultInputControlsWidth","autosize","rounded","color","placeholderColor","autoRows","resize","contrast","inline","secondary","success","error","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","sizes","sizeUnits","margin","marginXXS","marginXS","marginS","marginM","marginL","marginXL","marginTop","marginTopXXS","marginTopXS","marginTopS","marginTopM","marginTopL","marginTopXL","marginRight","marginRightXXS","marginRightXS","marginRightS","marginRightM","marginRightL","marginRightXL","marginBottom","marginBottomXXS","marginBottomXS","marginBottomS","marginBottomM","marginBottomL","marginBottomXL","marginLeft","marginLeftXXS","marginLeftXS","marginLeftS","marginLeftM","marginLeftL","marginLeftXL","widthXXS","widthXS","widthS","widthM","widthL","widthXL","preset","palette","label","fluid","className","style","disabled","textareaProps","sizeProps","textareaRef","useRef","textareaMimicRef","formInputLabelRef","useImperativeHandle","current","resizing","handleResizeStart","handleResizeOnNudge","useResizable","target","direction","labelId","useMemo","nanoid","active","setActive","useState","valueInit","value","defaultValue","length","autoRowsCount","setAutoRowsCount","Math","min","rowsVisible","cursorResize","updateAutoRowsCount","useCallback","nextRows","max","round","scrollHeight","clientHeight","styles","getComputedStyle","lineHeight","parseFloat","paddingTop","paddingBottom","Number","isNaN","fontSize","prevRows","useLayoutEffect","document","activeElement","useEffect","handleResize","createThrottledCallback","window","addEventListener","removeEventListener","_jsx","Styled","ref","onChange","evt","FormInputLabel","colorDisabled","backgroundColor","backgroundColorDisabled","backgroundColorHover","borderColor","borderColorDisabled","onClick","focus","onFocus","onPointerDown","Node","preventDefault","onBlur","currentTarget","contains","relatedTarget","Boolean","overflow","input","_jsxs","InputLabel","SIZES_FORM_INPUT","children","undefined","placeholderColorDisabled","addon","_Fragment","cursor","icon","ResizeHandle","tabIndex","onKeyDown","displayName","SIZES"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- 'use strict';var React=require('react');var withMergedProps=require('../../hocs/withMergedProps.js');var constants=require('./constants.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var index=require('../../icon-pack/src/icons/Close/index.js');var Text=require('../Text/Text.js');const TooltipComponent=withMergedProps.withMergedProps(React.forwardRef(((e,t)=>{const{size:s="s",titleProps:o={},contentProps:i={},closeButtonProps:n={},sizeXXS:r,sizeXS:c,sizeS:a,sizeM:l,sizeL:p,sizeXL:x,title:u,content:m,footer:d,closeFn:z,showCloseButton:j,...T}=e;const S={size:s,sizeXXS:r,sizeXS:c,sizeS:a,sizeM:l,sizeL:p,sizeXL:x};return jsxRuntime.jsxs(style.Root,{...T,...S,ref:t,children:[j?jsxRuntime.jsx(style.CloseButton,{size:"s",icon:jsxRuntime.jsx(index.Close,{}),secondary:T.black,contrast:T.black||T.contrast,...n,onClick:e=>{typeof z=='function'&&z(),n.onClick&&n.onClick(e)}}):null,u?jsxRuntime.jsx(Text.Text,{appearance:"body",color:"inherit",weight:700,marginRight:j?16:void 0,marginBottom:m||d?'0.3em':void 0,sizes:constants.SIZES_TEXT,...S,...o,children:u}):null,m?jsxRuntime.jsx(Text.Text,{appearance:"body",color:"inherit",marginRight:!u&&j?16:void 0,marginBottom:d?'0.2em':void 0,sizes:constants.SIZES_TEXT,...S,...i,children:m}):null,typeof d=='function'?d(S):d]})})),{sizes:constants.SIZES,displayName:"TooltipComponent"});exports.SIZES=constants.SIZES,exports.COMPONENT_NAME="TooltipComponent",exports.TooltipComponent=TooltipComponent;
1
+ 'use strict';var React=require('react');var withMergedProps=require('../../hocs/withMergedProps.js');var constants=require('./constants.js');var style=require('./style.js');var jsxRuntime=require('react/jsx-runtime');var Text=require('../Text/Text.js');const TooltipComponent=withMergedProps.withMergedProps(React.forwardRef(((e,t)=>{const{size:o="s",titleProps:s={},contentProps:i={},closeButtonProps:n={},sizeXXS:r,sizeXS:c,sizeS:a,sizeM:l,sizeL:p,sizeXL:u,title:m,content:x,footer:z,closeFn:T,showCloseButton:d,...S}=e;const h={size:o,sizeXXS:r,sizeXS:c,sizeS:a,sizeM:l,sizeL:p,sizeXL:u};return jsxRuntime.jsxs(style.Root,{...S,...h,ref:t,children:[d?jsxRuntime.jsx(style.CloseButton,{size:"s",icon:"close",secondary:S.black,contrast:S.black||S.contrast,...n,onClick:e=>{typeof T=='function'&&T(),n.onClick&&n.onClick(e)}}):null,m?jsxRuntime.jsx(Text.Text,{appearance:"body",color:"inherit",weight:700,marginRight:d?16:void 0,marginBottom:x||z?'0.3em':void 0,sizes:constants.SIZES_TEXT,...h,...s,children:m}):null,x?jsxRuntime.jsx(Text.Text,{appearance:"body",color:"inherit",marginRight:!m&&d?16:void 0,marginBottom:z?'0.2em':void 0,sizes:constants.SIZES_TEXT,...h,...i,children:x}):null,typeof z=='function'?z(h):z]})})),{sizes:constants.SIZES,displayName:"TooltipComponent"});exports.SIZES=constants.SIZES,exports.COMPONENT_NAME="TooltipComponent",exports.TooltipComponent=TooltipComponent;
2
2
  //# sourceMappingURL=TooltipComponent.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"TooltipComponent.js","sources":["../../../../src/components/TooltipComponent/TooltipComponent.tsx"],"sourcesContent":["import { forwardRef } from 'react'\nimport { Close } from '@foxford/icon-pack'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { Text } from 'components/Text'\nimport { SIZES, SIZES_TEXT } from './constants'\nimport type { TooltipComponentProps } from './types'\nimport * as Styled from './style'\n\nconst COMPONENT_NAME = 'TooltipComponent'\n\n/**\n *\n * Компонент поддерживает все атрибуты \\<div\\> элемента.\n *\n * Можно передать \"ref\", который будет ассоциирован с рутовым элементом.\n *\n * Поддерживаются пропсы определения размеров в зависимости от ширины вьюпорта.\n *\n * Полный интерфейс `TooltipComponent` можно посмотреть [тут](https://github.com/foxford/ui/blob/master/packages/ui/src/components/TooltipComponent/types.ts).\n */\nconst TooltipComponent: React.ForwardRefExoticComponent<TooltipComponentProps> = withMergedProps<\n TooltipComponentProps,\n HTMLDivElement\n>(\n forwardRef<HTMLDivElement, MergedProps<TooltipComponentProps>>((props, ref) => {\n const {\n size = 's',\n titleProps = {},\n contentProps = {},\n closeButtonProps = {},\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n title,\n content,\n footer,\n closeFn,\n showCloseButton,\n ...restProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n return (\n <Styled.Root {...restProps} {...sizeProps} ref={ref}>\n {showCloseButton ? (\n <Styled.CloseButton\n size='s'\n icon={<Close />}\n secondary={restProps.black}\n contrast={restProps.black || restProps.contrast}\n {...closeButtonProps}\n onClick={(evt) => {\n if (typeof closeFn === 'function') closeFn()\n if (closeButtonProps.onClick) closeButtonProps.onClick(evt)\n }}\n />\n ) : null}\n {title ? (\n <Text\n appearance='body'\n color='inherit'\n weight={700}\n marginRight={showCloseButton ? 16 : undefined}\n marginBottom={content || footer ? '0.3em' : undefined}\n sizes={SIZES_TEXT}\n {...sizeProps}\n {...titleProps}\n >\n {title}\n </Text>\n ) : null}\n {content ? (\n <Text\n appearance='body'\n color='inherit'\n marginRight={!title && showCloseButton ? 16 : undefined}\n marginBottom={footer ? '0.2em' : undefined}\n sizes={SIZES_TEXT}\n {...sizeProps}\n {...contentProps}\n >\n {content}\n </Text>\n ) : null}\n {typeof footer === 'function' ? footer(sizeProps) : footer}\n </Styled.Root>\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { TooltipComponent }\n\nexport { COMPONENT_NAME, SIZES }\n"],"names":["TooltipComponent","withMergedProps","forwardRef","props","ref","size","titleProps","contentProps","closeButtonProps","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","title","content","footer","closeFn","showCloseButton","restProps","sizeProps","_jsxs","Styled","children","_jsx","jsx","icon","Close","secondary","black","contrast","onClick","evt","Text","appearance","color","weight","marginRight","undefined","marginBottom","sizes","SIZES_TEXT","SIZES","displayName"],"mappings":"2TAqBMA,MAAAA,iBAA2EC,gBAAAA,gBAI/EC,MAAAA,YAA+D,CAACC,EAAOC,KACrE,MAAMC,KACJA,EAAO,IAAGC,WACVA,EAAa,CAAE,EAAAC,aACfA,EAAe,CAAE,EAAAC,iBACjBA,EAAmB,CAAE,EAAAC,QACrBA,EAAOC,OACPA,EAAMC,MACNA,EAAKC,MACLA,EAAKC,MACLA,EAAKC,OACLA,EAAMC,MACNA,EAAKC,QACLA,EAAOC,OACPA,EAAMC,QACNA,EAAOC,gBACPA,KACGC,GACDjB,EAEJ,MAAMkB,EAAY,CAChBhB,OACAI,UACAC,SACAC,QACAC,QACAC,QACAC,UAGF,OACEQ,WAAAA,KAACC,MAAAA,KAAW,IAAKH,KAAeC,EAAWjB,IAAKA,EAAIoB,UACjDL,EACCM,WAAAC,IAACH,kBAAkB,CACjBlB,KAAK,IACLsB,KAAMF,WAAAA,IAACG,MAAKA,UACZC,UAAWT,EAAUU,MACrBC,SAAUX,EAAUU,OAASV,EAAUW,YACnCvB,EACJwB,QAAUC,WACGf,GAAY,YAAYA,IAC/BV,EAAiBwB,SAASxB,EAAiBwB,QAAQC,EAAI,IAG7D,KACHlB,EACCU,WAAAA,IAACS,KAAAA,KAAI,CACHC,WAAW,OACXC,MAAM,UACNC,OAAQ,IACRC,YAAanB,EAAkB,QAAKoB,EACpCC,aAAcxB,GAAWC,EAAS,aAAUsB,EAC5CE,MAAOC,UAAWA,cACdrB,KACAf,EAAUkB,SAEbT,IAED,KACHC,EACCS,WAAAA,IAACS,KAAAA,KAAI,CACHC,WAAW,OACXC,MAAM,UACNE,aAAcvB,GAASI,EAAkB,QAAKoB,EAC9CC,aAAcvB,EAAS,aAAUsB,EACjCE,MAAOC,UAAWA,cACdrB,KACAd,EAAYiB,SAEfR,IAED,YACIC,GAAW,WAAaA,EAAOI,GAAaJ,IACxC,IAGlB,CACEwB,MAAOE,UAAKA,MACZC,YA9FmB,0EAAA"}
1
+ {"version":3,"file":"TooltipComponent.js","sources":["../../../../src/components/TooltipComponent/TooltipComponent.tsx"],"sourcesContent":["import { forwardRef } from 'react'\nimport { withMergedProps } from 'hocs/withMergedProps'\nimport type { MergedProps } from 'hocs/withMergedProps'\nimport { Text } from 'components/Text'\nimport { SIZES, SIZES_TEXT } from './constants'\nimport type { TooltipComponentProps } from './types'\nimport * as Styled from './style'\n\nconst COMPONENT_NAME = 'TooltipComponent'\n\n/**\n *\n * Компонент поддерживает все атрибуты \\<div\\> элемента.\n *\n * Можно передать \"ref\", который будет ассоциирован с рутовым элементом.\n *\n * Поддерживаются пропсы определения размеров в зависимости от ширины вьюпорта.\n *\n * Полный интерфейс `TooltipComponent` можно посмотреть [тут](https://github.com/foxford/ui/blob/master/packages/ui/src/components/TooltipComponent/types.ts).\n */\nconst TooltipComponent: React.ForwardRefExoticComponent<TooltipComponentProps> = withMergedProps<\n TooltipComponentProps,\n HTMLDivElement\n>(\n forwardRef<HTMLDivElement, MergedProps<TooltipComponentProps>>((props, ref) => {\n const {\n size = 's',\n titleProps = {},\n contentProps = {},\n closeButtonProps = {},\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n title,\n content,\n footer,\n closeFn,\n showCloseButton,\n ...restProps\n } = props\n\n const sizeProps = {\n size,\n sizeXXS,\n sizeXS,\n sizeS,\n sizeM,\n sizeL,\n sizeXL,\n }\n\n return (\n <Styled.Root {...restProps} {...sizeProps} ref={ref}>\n {showCloseButton ? (\n <Styled.CloseButton\n size='s'\n icon='close'\n secondary={restProps.black}\n contrast={restProps.black || restProps.contrast}\n {...closeButtonProps}\n onClick={(evt) => {\n if (typeof closeFn === 'function') closeFn()\n if (closeButtonProps.onClick) closeButtonProps.onClick(evt)\n }}\n />\n ) : null}\n {title ? (\n <Text\n appearance='body'\n color='inherit'\n weight={700}\n marginRight={showCloseButton ? 16 : undefined}\n marginBottom={content || footer ? '0.3em' : undefined}\n sizes={SIZES_TEXT}\n {...sizeProps}\n {...titleProps}\n >\n {title}\n </Text>\n ) : null}\n {content ? (\n <Text\n appearance='body'\n color='inherit'\n marginRight={!title && showCloseButton ? 16 : undefined}\n marginBottom={footer ? '0.2em' : undefined}\n sizes={SIZES_TEXT}\n {...sizeProps}\n {...contentProps}\n >\n {content}\n </Text>\n ) : null}\n {typeof footer === 'function' ? footer(sizeProps) : footer}\n </Styled.Root>\n )\n }),\n {\n sizes: SIZES,\n displayName: COMPONENT_NAME,\n }\n)\n\nexport { TooltipComponent }\n\nexport { COMPONENT_NAME, SIZES }\n"],"names":["TooltipComponent","withMergedProps","forwardRef","props","ref","size","titleProps","contentProps","closeButtonProps","sizeXXS","sizeXS","sizeS","sizeM","sizeL","sizeXL","title","content","footer","closeFn","showCloseButton","restProps","sizeProps","_jsxs","Styled","children","_jsx","jsx","icon","secondary","black","contrast","onClick","evt","Text","appearance","color","weight","marginRight","undefined","marginBottom","sizes","SIZES_TEXT","SIZES","displayName"],"mappings":"6PAoBMA,MAAAA,iBAA2EC,gBAAAA,gBAI/EC,MAAAA,YAA+D,CAACC,EAAOC,KACrE,MAAMC,KACJA,EAAO,IAAGC,WACVA,EAAa,CAAE,EAAAC,aACfA,EAAe,CAAE,EAAAC,iBACjBA,EAAmB,CAAE,EAAAC,QACrBA,EAAOC,OACPA,EAAMC,MACNA,EAAKC,MACLA,EAAKC,MACLA,EAAKC,OACLA,EAAMC,MACNA,EAAKC,QACLA,EAAOC,OACPA,EAAMC,QACNA,EAAOC,gBACPA,KACGC,GACDjB,EAEJ,MAAMkB,EAAY,CAChBhB,OACAI,UACAC,SACAC,QACAC,QACAC,QACAC,UAGF,OACEQ,WAAAA,KAACC,MAAAA,KAAW,IAAKH,KAAeC,EAAWjB,IAAKA,EAAIoB,UACjDL,EACCM,WAAAC,IAACH,kBAAkB,CACjBlB,KAAK,IACLsB,KAAK,QACLC,UAAWR,EAAUS,MACrBC,SAAUV,EAAUS,OAAST,EAAUU,YACnCtB,EACJuB,QAAUC,WACGd,GAAY,YAAYA,IAC/BV,EAAiBuB,SAASvB,EAAiBuB,QAAQC,EAAI,IAG7D,KACHjB,EACCU,WAAAA,IAACQ,KAAAA,KAAI,CACHC,WAAW,OACXC,MAAM,UACNC,OAAQ,IACRC,YAAalB,EAAkB,QAAKmB,EACpCC,aAAcvB,GAAWC,EAAS,aAAUqB,EAC5CE,MAAOC,UAAWA,cACdpB,KACAf,EAAUkB,SAEbT,IAED,KACHC,EACCS,WAAAA,IAACQ,KAAAA,KAAI,CACHC,WAAW,OACXC,MAAM,UACNE,aAActB,GAASI,EAAkB,QAAKmB,EAC9CC,aAActB,EAAS,aAAUqB,EACjCE,MAAOC,UAAWA,cACdpB,KACAd,EAAYiB,SAEfR,IAED,YACIC,GAAW,WAAaA,EAAOI,GAAaJ,IACxC,IAGlB,CACEuB,MAAOE,UAAKA,MACZC,YA9FmB,0EAAA"}
@@ -1,2 +1,2 @@
1
- import{forwardRef}from'react';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{SIZES,SIZES_TEXT}from'./constants.mjs';import{Root,CloseButton}from'./style.mjs';import{jsxs,jsx}from'react/jsx-runtime';import{Close}from'../../icon-pack/src/icons/Close/index.mjs';import{Text}from'../Text/Text.mjs';const COMPONENT_NAME='TooltipComponent';const TooltipComponent=withMergedProps(forwardRef(((o,e)=>{const{size:t="s",titleProps:s={},contentProps:i={},closeButtonProps:n={},sizeXXS:r,sizeXS:c,sizeS:m,sizeM:l,sizeL:p,sizeXL:a,title:z,content:S,footer:d,closeFn:f,showCloseButton:T,...x}=o;const C={size:t,sizeXXS:r,sizeXS:c,sizeS:m,sizeM:l,sizeL:p,sizeXL:a};return jsxs(Root,{...x,...C,ref:e,children:[T?jsx(CloseButton,{size:"s",icon:jsx(Close,{}),secondary:x.black,contrast:x.black||x.contrast,...n,onClick:o=>{typeof f=='function'&&f(),n.onClick&&n.onClick(o)}}):null,z?jsx(Text,{appearance:"body",color:"inherit",weight:700,marginRight:T?16:void 0,marginBottom:S||d?'0.3em':void 0,sizes:SIZES_TEXT,...C,...s,children:z}):null,S?jsx(Text,{appearance:"body",color:"inherit",marginRight:!z&&T?16:void 0,marginBottom:d?'0.2em':void 0,sizes:SIZES_TEXT,...C,...i,children:S}):null,typeof d=='function'?d(C):d]})})),{sizes:SIZES,displayName:"TooltipComponent"});export{COMPONENT_NAME,SIZES,TooltipComponent};
1
+ import{forwardRef}from'react';import{withMergedProps}from'../../hocs/withMergedProps.mjs';import{SIZES,SIZES_TEXT}from'./constants.mjs';import{Root,CloseButton}from'./style.mjs';import{jsxs,jsx}from'react/jsx-runtime';import{Text}from'../Text/Text.mjs';const COMPONENT_NAME='TooltipComponent';const TooltipComponent=withMergedProps(forwardRef(((o,t)=>{const{size:e="s",titleProps:s={},contentProps:i={},closeButtonProps:n={},sizeXXS:r,sizeXS:c,sizeS:l,sizeM:m,sizeL:p,sizeXL:a,title:z,content:S,footer:T,closeFn:d,showCloseButton:f,...h}=o;const x={size:e,sizeXXS:r,sizeXS:c,sizeS:l,sizeM:m,sizeL:p,sizeXL:a};return jsxs(Root,{...h,...x,ref:t,children:[f?jsx(CloseButton,{size:"s",icon:"close",secondary:h.black,contrast:h.black||h.contrast,...n,onClick:o=>{typeof d=='function'&&d(),n.onClick&&n.onClick(o)}}):null,z?jsx(Text,{appearance:"body",color:"inherit",weight:700,marginRight:f?16:void 0,marginBottom:S||T?'0.3em':void 0,sizes:SIZES_TEXT,...x,...s,children:z}):null,S?jsx(Text,{appearance:"body",color:"inherit",marginRight:!z&&f?16:void 0,marginBottom:T?'0.2em':void 0,sizes:SIZES_TEXT,...x,...i,children:S}):null,typeof T=='function'?T(x):T]})})),{sizes:SIZES,displayName:"TooltipComponent"});export{COMPONENT_NAME,SIZES,TooltipComponent};
2
2
  //# sourceMappingURL=TooltipComponent.mjs.map