@qite/tide-booking-component 1.3.2 → 1.3.3

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 (305) hide show
  1. package/.vs/ProjectSettings.json +3 -3
  2. package/.vs/VSWorkspaceState.json +5 -5
  3. package/README.md +8 -8
  4. package/build/build-cjs/booking-product/components/age-select.d.ts +8 -8
  5. package/build/build-cjs/booking-product/components/amount-input.d.ts +10 -10
  6. package/build/build-cjs/booking-product/components/date-range-picker/calendar-day.d.ts +12 -12
  7. package/build/build-cjs/booking-product/components/date-range-picker/calendar.d.ts +19 -19
  8. package/build/build-cjs/booking-product/components/date-range-picker/index.d.ts +20 -23
  9. package/build/build-cjs/booking-product/components/dates.d.ts +9 -9
  10. package/build/build-cjs/booking-product/components/footer.d.ts +10 -10
  11. package/build/build-cjs/booking-product/components/header.d.ts +11 -11
  12. package/build/build-cjs/booking-product/components/icon.d.ts +10 -10
  13. package/build/build-cjs/booking-product/components/product.d.ts +9 -9
  14. package/build/build-cjs/booking-product/components/rating.d.ts +6 -6
  15. package/build/build-cjs/booking-product/components/rooms.d.ts +10 -10
  16. package/build/build-cjs/booking-product/index.d.ts +10 -10
  17. package/build/build-cjs/booking-product/settings-context.d.ts +5 -6
  18. package/build/build-cjs/booking-product/types.d.ts +25 -25
  19. package/build/build-cjs/booking-product/utils/api.d.ts +16 -6
  20. package/build/build-cjs/booking-product/utils/price.d.ts +9 -1
  21. package/build/build-cjs/booking-wizard/api-settings-slice.d.ts +14 -4
  22. package/build/build-cjs/booking-wizard/components/icon.d.ts +10 -10
  23. package/build/build-cjs/booking-wizard/components/labeled-input.d.ts +18 -18
  24. package/build/build-cjs/booking-wizard/components/labeled-select.d.ts +21 -21
  25. package/build/build-cjs/booking-wizard/components/message.d.ts +9 -9
  26. package/build/build-cjs/booking-wizard/components/multi-range-filter.d.ts +11 -11
  27. package/build/build-cjs/booking-wizard/components/print-offer-button.d.ts +17 -17
  28. package/build/build-cjs/booking-wizard/components/product-card.d.ts +8 -8
  29. package/build/build-cjs/booking-wizard/components/step-indicator.d.ts +6 -6
  30. package/build/build-cjs/booking-wizard/components/step-route.d.ts +9 -9
  31. package/build/build-cjs/booking-wizard/features/booking/api.d.ts +29 -10
  32. package/build/build-cjs/booking-wizard/features/booking/booking-self-contained.d.ts +8 -8
  33. package/build/build-cjs/booking-wizard/features/booking/booking-slice.d.ts +177 -46
  34. package/build/build-cjs/booking-wizard/features/booking/booking.d.ts +8 -8
  35. package/build/build-cjs/booking-wizard/features/booking/constants.d.ts +15 -8
  36. package/build/build-cjs/booking-wizard/features/booking/selectors.d.ts +308 -136
  37. package/build/build-cjs/booking-wizard/features/confirmation/confirmation.d.ts +4 -5
  38. package/build/build-cjs/booking-wizard/features/error/error.d.ts +4 -5
  39. package/build/build-cjs/booking-wizard/features/flight-options/flight-filter.d.ts +9 -9
  40. package/build/build-cjs/booking-wizard/features/flight-options/flight-option-flight.d.ts +8 -8
  41. package/build/build-cjs/booking-wizard/features/flight-options/flight-option-modal.d.ts +3 -3
  42. package/build/build-cjs/booking-wizard/features/flight-options/flight-option.d.ts +10 -10
  43. package/build/build-cjs/booking-wizard/features/flight-options/flight-utils.d.ts +16 -6
  44. package/build/build-cjs/booking-wizard/features/flight-options/index.d.ts +4 -5
  45. package/build/build-cjs/booking-wizard/features/price-details/price-details-api.d.ts +15 -6
  46. package/build/build-cjs/booking-wizard/features/price-details/price-details-slice.d.ts +121 -80
  47. package/build/build-cjs/booking-wizard/features/price-details/util.d.ts +5 -2
  48. package/build/build-cjs/booking-wizard/features/product-options/no-options.d.ts +3 -3
  49. package/build/build-cjs/booking-wizard/features/product-options/none-option.d.ts +17 -9
  50. package/build/build-cjs/booking-wizard/features/product-options/option-booking-airline-group.d.ts +17 -8
  51. package/build/build-cjs/booking-wizard/features/product-options/option-booking-group.d.ts +18 -12
  52. package/build/build-cjs/booking-wizard/features/product-options/option-item.d.ts +11 -11
  53. package/build/build-cjs/booking-wizard/features/product-options/option-pax-card.d.ts +13 -10
  54. package/build/build-cjs/booking-wizard/features/product-options/option-pax-group.d.ts +20 -13
  55. package/build/build-cjs/booking-wizard/features/product-options/option-room.d.ts +18 -10
  56. package/build/build-cjs/booking-wizard/features/product-options/option-unit-group.d.ts +20 -13
  57. package/build/build-cjs/booking-wizard/features/product-options/option-units-card.d.ts +9 -9
  58. package/build/build-cjs/booking-wizard/features/product-options/options-form.d.ts +4 -5
  59. package/build/build-cjs/booking-wizard/features/room-options/index.d.ts +4 -5
  60. package/build/build-cjs/booking-wizard/features/room-options/room-utils.d.ts +29 -9
  61. package/build/build-cjs/booking-wizard/features/room-options/room.d.ts +15 -12
  62. package/build/build-cjs/booking-wizard/features/room-options/traveler-rooms.d.ts +13 -9
  63. package/build/build-cjs/booking-wizard/features/sidebar/index.d.ts +7 -7
  64. package/build/build-cjs/booking-wizard/features/sidebar/sidebar-flight.d.ts +8 -8
  65. package/build/build-cjs/booking-wizard/features/sidebar/sidebar-util.d.ts +31 -12
  66. package/build/build-cjs/booking-wizard/features/sidebar/sidebar.d.ts +29 -25
  67. package/build/build-cjs/booking-wizard/features/summary/summary-booking-option-pax.d.ts +7 -7
  68. package/build/build-cjs/booking-wizard/features/summary/summary-booking-option-unit.d.ts +7 -7
  69. package/build/build-cjs/booking-wizard/features/summary/summary-flight.d.ts +8 -8
  70. package/build/build-cjs/booking-wizard/features/summary/summary-per-booking-option-group.d.ts +10 -7
  71. package/build/build-cjs/booking-wizard/features/summary/summary-per-pax-option-group.d.ts +10 -7
  72. package/build/build-cjs/booking-wizard/features/summary/summary-per-unit-option-group.d.ts +10 -7
  73. package/build/build-cjs/booking-wizard/features/summary/summary-slice.d.ts +14 -8
  74. package/build/build-cjs/booking-wizard/features/summary/summary.d.ts +4 -5
  75. package/build/build-cjs/booking-wizard/features/travelers-form/travelers-form-slice.d.ts +75 -49
  76. package/build/build-cjs/booking-wizard/features/travelers-form/travelers-form.d.ts +4 -5
  77. package/build/build-cjs/booking-wizard/features/travelers-form/type-ahead-input.d.ts +16 -16
  78. package/build/build-cjs/booking-wizard/features/travelers-form/validate-form.d.ts +9 -4
  79. package/build/build-cjs/booking-wizard/index.d.ts +12 -12
  80. package/build/build-cjs/booking-wizard/settings-context.d.ts +5 -6
  81. package/build/build-cjs/booking-wizard/store.d.ts +44 -24
  82. package/build/build-cjs/booking-wizard/types.d.ts +253 -257
  83. package/build/build-cjs/booking-wizard/use-offer-printer.d.ts +19 -13
  84. package/build/build-cjs/index.d.ts +3 -3
  85. package/build/build-cjs/index.js +16332 -7414
  86. package/build/build-cjs/shared/components/loader.d.ts +6 -6
  87. package/build/build-cjs/shared/types.d.ts +4 -4
  88. package/build/build-cjs/shared/utils/class-util.d.ts +1 -1
  89. package/build/build-cjs/shared/utils/localization-util.d.ts +248 -248
  90. package/build/build-cjs/shared/utils/query-string-util.d.ts +29 -8
  91. package/build/build-cjs/shared/utils/tide-api-utils.d.ts +6 -4
  92. package/build/build-esm/booking-product/components/age-select.d.ts +8 -8
  93. package/build/build-esm/booking-product/components/amount-input.d.ts +10 -10
  94. package/build/build-esm/booking-product/components/date-range-picker/calendar-day.d.ts +12 -12
  95. package/build/build-esm/booking-product/components/date-range-picker/calendar.d.ts +19 -19
  96. package/build/build-esm/booking-product/components/date-range-picker/index.d.ts +20 -23
  97. package/build/build-esm/booking-product/components/dates.d.ts +9 -9
  98. package/build/build-esm/booking-product/components/footer.d.ts +10 -10
  99. package/build/build-esm/booking-product/components/header.d.ts +11 -11
  100. package/build/build-esm/booking-product/components/icon.d.ts +10 -10
  101. package/build/build-esm/booking-product/components/product.d.ts +9 -9
  102. package/build/build-esm/booking-product/components/rating.d.ts +6 -6
  103. package/build/build-esm/booking-product/components/rooms.d.ts +10 -10
  104. package/build/build-esm/booking-product/index.d.ts +10 -10
  105. package/build/build-esm/booking-product/settings-context.d.ts +5 -6
  106. package/build/build-esm/booking-product/types.d.ts +25 -25
  107. package/build/build-esm/booking-product/utils/api.d.ts +16 -6
  108. package/build/build-esm/booking-product/utils/price.d.ts +9 -1
  109. package/build/build-esm/booking-wizard/api-settings-slice.d.ts +14 -4
  110. package/build/build-esm/booking-wizard/components/icon.d.ts +10 -10
  111. package/build/build-esm/booking-wizard/components/labeled-input.d.ts +18 -18
  112. package/build/build-esm/booking-wizard/components/labeled-select.d.ts +21 -21
  113. package/build/build-esm/booking-wizard/components/message.d.ts +9 -9
  114. package/build/build-esm/booking-wizard/components/multi-range-filter.d.ts +11 -11
  115. package/build/build-esm/booking-wizard/components/print-offer-button.d.ts +17 -17
  116. package/build/build-esm/booking-wizard/components/product-card.d.ts +8 -8
  117. package/build/build-esm/booking-wizard/components/step-indicator.d.ts +6 -6
  118. package/build/build-esm/booking-wizard/components/step-route.d.ts +9 -9
  119. package/build/build-esm/booking-wizard/features/booking/api.d.ts +29 -10
  120. package/build/build-esm/booking-wizard/features/booking/booking-self-contained.d.ts +8 -8
  121. package/build/build-esm/booking-wizard/features/booking/booking-slice.d.ts +177 -46
  122. package/build/build-esm/booking-wizard/features/booking/booking.d.ts +8 -8
  123. package/build/build-esm/booking-wizard/features/booking/constants.d.ts +15 -8
  124. package/build/build-esm/booking-wizard/features/booking/selectors.d.ts +308 -136
  125. package/build/build-esm/booking-wizard/features/confirmation/confirmation.d.ts +4 -5
  126. package/build/build-esm/booking-wizard/features/error/error.d.ts +4 -5
  127. package/build/build-esm/booking-wizard/features/flight-options/flight-filter.d.ts +9 -9
  128. package/build/build-esm/booking-wizard/features/flight-options/flight-option-flight.d.ts +8 -8
  129. package/build/build-esm/booking-wizard/features/flight-options/flight-option-modal.d.ts +3 -3
  130. package/build/build-esm/booking-wizard/features/flight-options/flight-option.d.ts +10 -10
  131. package/build/build-esm/booking-wizard/features/flight-options/flight-utils.d.ts +16 -6
  132. package/build/build-esm/booking-wizard/features/flight-options/index.d.ts +4 -5
  133. package/build/build-esm/booking-wizard/features/price-details/price-details-api.d.ts +15 -6
  134. package/build/build-esm/booking-wizard/features/price-details/price-details-slice.d.ts +121 -80
  135. package/build/build-esm/booking-wizard/features/price-details/util.d.ts +5 -2
  136. package/build/build-esm/booking-wizard/features/product-options/no-options.d.ts +3 -3
  137. package/build/build-esm/booking-wizard/features/product-options/none-option.d.ts +17 -9
  138. package/build/build-esm/booking-wizard/features/product-options/option-booking-airline-group.d.ts +17 -8
  139. package/build/build-esm/booking-wizard/features/product-options/option-booking-group.d.ts +18 -12
  140. package/build/build-esm/booking-wizard/features/product-options/option-item.d.ts +11 -11
  141. package/build/build-esm/booking-wizard/features/product-options/option-pax-card.d.ts +13 -10
  142. package/build/build-esm/booking-wizard/features/product-options/option-pax-group.d.ts +20 -13
  143. package/build/build-esm/booking-wizard/features/product-options/option-room.d.ts +18 -10
  144. package/build/build-esm/booking-wizard/features/product-options/option-unit-group.d.ts +20 -13
  145. package/build/build-esm/booking-wizard/features/product-options/option-units-card.d.ts +9 -9
  146. package/build/build-esm/booking-wizard/features/product-options/options-form.d.ts +4 -5
  147. package/build/build-esm/booking-wizard/features/room-options/index.d.ts +4 -5
  148. package/build/build-esm/booking-wizard/features/room-options/room-utils.d.ts +29 -9
  149. package/build/build-esm/booking-wizard/features/room-options/room.d.ts +15 -12
  150. package/build/build-esm/booking-wizard/features/room-options/traveler-rooms.d.ts +13 -9
  151. package/build/build-esm/booking-wizard/features/sidebar/index.d.ts +7 -7
  152. package/build/build-esm/booking-wizard/features/sidebar/sidebar-flight.d.ts +8 -8
  153. package/build/build-esm/booking-wizard/features/sidebar/sidebar-util.d.ts +31 -12
  154. package/build/build-esm/booking-wizard/features/sidebar/sidebar.d.ts +29 -25
  155. package/build/build-esm/booking-wizard/features/summary/summary-booking-option-pax.d.ts +7 -7
  156. package/build/build-esm/booking-wizard/features/summary/summary-booking-option-unit.d.ts +7 -7
  157. package/build/build-esm/booking-wizard/features/summary/summary-flight.d.ts +8 -8
  158. package/build/build-esm/booking-wizard/features/summary/summary-per-booking-option-group.d.ts +10 -7
  159. package/build/build-esm/booking-wizard/features/summary/summary-per-pax-option-group.d.ts +10 -7
  160. package/build/build-esm/booking-wizard/features/summary/summary-per-unit-option-group.d.ts +10 -7
  161. package/build/build-esm/booking-wizard/features/summary/summary-slice.d.ts +14 -8
  162. package/build/build-esm/booking-wizard/features/summary/summary.d.ts +4 -5
  163. package/build/build-esm/booking-wizard/features/travelers-form/travelers-form-slice.d.ts +75 -49
  164. package/build/build-esm/booking-wizard/features/travelers-form/travelers-form.d.ts +4 -5
  165. package/build/build-esm/booking-wizard/features/travelers-form/type-ahead-input.d.ts +16 -16
  166. package/build/build-esm/booking-wizard/features/travelers-form/validate-form.d.ts +9 -4
  167. package/build/build-esm/booking-wizard/index.d.ts +12 -12
  168. package/build/build-esm/booking-wizard/settings-context.d.ts +5 -6
  169. package/build/build-esm/booking-wizard/store.d.ts +44 -24
  170. package/build/build-esm/booking-wizard/types.d.ts +253 -257
  171. package/build/build-esm/booking-wizard/use-offer-printer.d.ts +19 -13
  172. package/build/build-esm/index.d.ts +3 -3
  173. package/build/build-esm/index.js +15926 -7396
  174. package/build/build-esm/shared/components/loader.d.ts +6 -6
  175. package/build/build-esm/shared/types.d.ts +4 -4
  176. package/build/build-esm/shared/utils/class-util.d.ts +1 -1
  177. package/build/build-esm/shared/utils/localization-util.d.ts +248 -248
  178. package/build/build-esm/shared/utils/query-string-util.d.ts +29 -8
  179. package/build/build-esm/shared/utils/tide-api-utils.d.ts +6 -4
  180. package/package.json +75 -75
  181. package/rollup.config.js +23 -23
  182. package/src/booking-product/components/age-select.tsx +35 -35
  183. package/src/booking-product/components/amount-input.tsx +78 -78
  184. package/src/booking-product/components/date-range-picker/calendar-day.tsx +58 -58
  185. package/src/booking-product/components/date-range-picker/calendar.tsx +178 -178
  186. package/src/booking-product/components/date-range-picker/index.tsx +196 -196
  187. package/src/booking-product/components/dates.tsx +136 -136
  188. package/src/booking-product/components/footer.tsx +69 -69
  189. package/src/booking-product/components/header.tsx +79 -79
  190. package/src/booking-product/components/icon.tsx +251 -251
  191. package/src/booking-product/components/product.tsx +314 -314
  192. package/src/booking-product/components/rating.tsx +21 -21
  193. package/src/booking-product/components/rooms.tsx +195 -195
  194. package/src/booking-product/index.tsx +30 -30
  195. package/src/booking-product/settings-context.ts +14 -14
  196. package/src/booking-product/types.ts +28 -28
  197. package/src/booking-product/utils/api.ts +25 -25
  198. package/src/booking-product/utils/price.ts +29 -29
  199. package/src/booking-wizard/api-settings-slice.ts +24 -24
  200. package/src/booking-wizard/components/icon.tsx +508 -508
  201. package/src/booking-wizard/components/labeled-input.tsx +64 -64
  202. package/src/booking-wizard/components/labeled-select.tsx +69 -69
  203. package/src/booking-wizard/components/message.tsx +34 -34
  204. package/src/booking-wizard/components/multi-range-filter.tsx +113 -113
  205. package/src/booking-wizard/components/print-offer-button.tsx +63 -66
  206. package/src/booking-wizard/components/product-card.tsx +37 -37
  207. package/src/booking-wizard/components/step-indicator.tsx +51 -51
  208. package/src/booking-wizard/components/step-route.tsx +27 -27
  209. package/src/booking-wizard/declarations.d.ts +4 -4
  210. package/src/booking-wizard/features/booking/api.ts +49 -49
  211. package/src/booking-wizard/features/booking/booking-self-contained.tsx +389 -389
  212. package/src/booking-wizard/features/booking/booking-slice.ts +665 -663
  213. package/src/booking-wizard/features/booking/booking.tsx +361 -361
  214. package/src/booking-wizard/features/booking/constants.ts +16 -16
  215. package/src/booking-wizard/features/booking/selectors.ts +441 -441
  216. package/src/booking-wizard/features/confirmation/confirmation.tsx +97 -97
  217. package/src/booking-wizard/features/error/error.tsx +78 -78
  218. package/src/booking-wizard/features/flight-options/flight-filter.tsx +432 -432
  219. package/src/booking-wizard/features/flight-options/flight-option-flight.tsx +385 -385
  220. package/src/booking-wizard/features/flight-options/flight-option-modal.tsx +229 -229
  221. package/src/booking-wizard/features/flight-options/flight-option.tsx +81 -81
  222. package/src/booking-wizard/features/flight-options/flight-utils.ts +516 -516
  223. package/src/booking-wizard/features/flight-options/index.tsx +196 -196
  224. package/src/booking-wizard/features/price-details/price-details-api.ts +24 -24
  225. package/src/booking-wizard/features/price-details/price-details-slice.ts +178 -178
  226. package/src/booking-wizard/features/price-details/util.ts +155 -155
  227. package/src/booking-wizard/features/product-options/no-options.tsx +21 -21
  228. package/src/booking-wizard/features/product-options/none-option.tsx +120 -120
  229. package/src/booking-wizard/features/product-options/option-booking-airline-group.tsx +64 -64
  230. package/src/booking-wizard/features/product-options/option-booking-group.tsx +216 -216
  231. package/src/booking-wizard/features/product-options/option-item.tsx +317 -317
  232. package/src/booking-wizard/features/product-options/option-pax-card.tsx +201 -201
  233. package/src/booking-wizard/features/product-options/option-pax-group.tsx +175 -175
  234. package/src/booking-wizard/features/product-options/option-room.tsx +321 -321
  235. package/src/booking-wizard/features/product-options/option-unit-group.tsx +198 -198
  236. package/src/booking-wizard/features/product-options/option-units-card.tsx +185 -185
  237. package/src/booking-wizard/features/product-options/options-form.tsx +481 -563
  238. package/src/booking-wizard/features/room-options/index.tsx +187 -187
  239. package/src/booking-wizard/features/room-options/room-utils.ts +190 -190
  240. package/src/booking-wizard/features/room-options/room.tsx +160 -160
  241. package/src/booking-wizard/features/room-options/traveler-rooms.tsx +75 -75
  242. package/src/booking-wizard/features/sidebar/index.tsx +76 -76
  243. package/src/booking-wizard/features/sidebar/sidebar-flight.tsx +68 -68
  244. package/src/booking-wizard/features/sidebar/sidebar-util.ts +177 -177
  245. package/src/booking-wizard/features/sidebar/sidebar.tsx +364 -364
  246. package/src/booking-wizard/features/summary/summary-booking-option-pax.tsx +25 -25
  247. package/src/booking-wizard/features/summary/summary-booking-option-unit.tsx +25 -25
  248. package/src/booking-wizard/features/summary/summary-flight.tsx +39 -39
  249. package/src/booking-wizard/features/summary/summary-per-booking-option-group.tsx +69 -69
  250. package/src/booking-wizard/features/summary/summary-per-pax-option-group.tsx +63 -63
  251. package/src/booking-wizard/features/summary/summary-per-unit-option-group.tsx +66 -66
  252. package/src/booking-wizard/features/summary/summary-slice.ts +28 -28
  253. package/src/booking-wizard/features/summary/summary.tsx +674 -674
  254. package/src/booking-wizard/features/travelers-form/travelers-form-slice.ts +164 -164
  255. package/src/booking-wizard/features/travelers-form/travelers-form.tsx +754 -754
  256. package/src/booking-wizard/features/travelers-form/type-ahead-input.tsx +101 -101
  257. package/src/booking-wizard/features/travelers-form/validate-form.ts +245 -245
  258. package/src/booking-wizard/index.tsx +36 -36
  259. package/src/booking-wizard/settings-context.ts +62 -62
  260. package/src/booking-wizard/store.ts +31 -31
  261. package/src/booking-wizard/types.ts +279 -279
  262. package/src/booking-wizard/use-offer-printer.ts +117 -136
  263. package/src/index.ts +4 -4
  264. package/src/shared/components/loader.tsx +16 -16
  265. package/src/shared/translations/en-GB.json +237 -237
  266. package/src/shared/translations/fr-BE.json +238 -238
  267. package/src/shared/translations/nl-BE.json +237 -237
  268. package/src/shared/types.ts +4 -4
  269. package/src/shared/utils/class-util.ts +9 -9
  270. package/src/shared/utils/localization-util.ts +62 -62
  271. package/src/shared/utils/query-string-util.ts +119 -119
  272. package/src/shared/utils/tide-api-utils.ts +36 -36
  273. package/styles/booking-product-variables.scss +394 -394
  274. package/styles/booking-product.scss +446 -446
  275. package/styles/booking-wizard-variables.scss +873 -873
  276. package/styles/booking-wizard.scss +59 -59
  277. package/styles/components/_animations.scss +39 -39
  278. package/styles/components/_base.scss +107 -107
  279. package/styles/components/_booking.scss +879 -879
  280. package/styles/components/_button.scss +238 -238
  281. package/styles/components/_checkbox.scss +219 -219
  282. package/styles/components/_cta.scss +208 -208
  283. package/styles/components/_date-list.scss +41 -41
  284. package/styles/components/_date-range-picker.scss +225 -225
  285. package/styles/components/_decrement-increment.scss +35 -35
  286. package/styles/components/_dropdown.scss +72 -72
  287. package/styles/components/_flight-option.scss +1429 -1429
  288. package/styles/components/_form.scss +1583 -1583
  289. package/styles/components/_info-message.scss +71 -71
  290. package/styles/components/_input.scss +25 -25
  291. package/styles/components/_list.scss +187 -187
  292. package/styles/components/_loader.scss +72 -72
  293. package/styles/components/_mixins.scss +550 -550
  294. package/styles/components/_placeholders.scss +166 -166
  295. package/styles/components/_pricing-summary.scss +155 -155
  296. package/styles/components/_qsm.scss +17 -17
  297. package/styles/components/_radiobutton.scss +170 -170
  298. package/styles/components/_select-wrapper.scss +80 -80
  299. package/styles/components/_spinner.scss +29 -29
  300. package/styles/components/_step-indicators.scss +168 -168
  301. package/styles/components/_table.scss +81 -81
  302. package/styles/components/_tree.scss +530 -530
  303. package/styles/components/_typeahead.scss +281 -281
  304. package/styles/components/_variables.scss +89 -89
  305. package/tsconfig.json +24 -24
@@ -1,508 +1,508 @@
1
- import { isEmpty } from "lodash";
2
- import React, { useContext } from "react";
3
- import SettingsContext from "../settings-context";
4
- import HTMLComment from "react-html-comment";
5
-
6
- interface IconProps {
7
- name: string;
8
- className?: string;
9
- title?: string;
10
- width?: number;
11
- height?: number;
12
- }
13
-
14
- const Icon: React.FC<IconProps> = ({
15
- name,
16
- className,
17
- title,
18
- width,
19
- height,
20
- }) => {
21
- const { icons } = useContext(SettingsContext);
22
-
23
- if (icons) {
24
- return (
25
- <svg
26
- className={["icon", `icon--${name}`, className]
27
- .filter((className) => !isEmpty(className))
28
- .join(" ")}
29
- width={width}
30
- height={height}
31
- >
32
- {title && <title>{title}</title>}
33
- <use href={`${icons}#${name}`}></use>
34
- </svg>
35
- );
36
- }
37
-
38
- switch (name) {
39
- case "ui-chevron":
40
- return (
41
- <svg
42
- className={["icon", `icon--${name}`, className]
43
- .filter((className) => !isEmpty(className))
44
- .join(" ")}
45
- width={width}
46
- height={height}
47
- viewBox="0 0 320 512"
48
- >
49
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
50
- {title && <title>{title}</title>}
51
- <path d="M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z" />
52
- </svg>
53
- );
54
-
55
- case "ui-error":
56
- return (
57
- <svg
58
- className={["icon", `icon--${name}`, className]
59
- .filter((className) => !isEmpty(className))
60
- .join(" ")}
61
- width={width}
62
- height={height}
63
- viewBox="0 0 512 512"
64
- >
65
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
66
- {title && <title>{title}</title>}
67
- <path d="M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm0-384c13.3 0 24 10.7 24 24l0 112c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-112c0-13.3 10.7-24 24-24zM224 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z" />
68
- </svg>
69
- );
70
-
71
- case "ui-tel":
72
- return (
73
- <svg
74
- className={["icon", `icon--${name}`, className]
75
- .filter((className) => !isEmpty(className))
76
- .join(" ")}
77
- width={width}
78
- height={height}
79
- viewBox="0 0 512 512"
80
- >
81
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
82
- {title && <title>{title}</title>}
83
- <path d="M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z" />
84
- </svg>
85
- );
86
-
87
- case "ui-mail":
88
- return (
89
- <svg
90
- className={["icon", `icon--${name}`, className]
91
- .filter((className) => !isEmpty(className))
92
- .join(" ")}
93
- width={width}
94
- height={height}
95
- viewBox="0 0 512 512"
96
- >
97
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
98
- {title && <title>{title}</title>}
99
- <path d="M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0L492.8 150.4c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48L48 64zM0 176L0 384c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-208L294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176z" />
100
- </svg>
101
- );
102
-
103
- case "ui-trashcan":
104
- return (
105
- <svg
106
- className={["icon", `icon--${name}`, className]
107
- .filter((className) => !isEmpty(className))
108
- .join(" ")}
109
- width={width}
110
- height={height}
111
- viewBox="0 0 448 512"
112
- >
113
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
114
- {title && <title>{title}</title>}
115
- <path d="M135.2 17.7L128 32 32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0-7.2-14.3C307.4 6.8 296.3 0 284.2 0L163.8 0c-12.1 0-23.2 6.8-28.6 17.7zM416 128L32 128 53.2 467c1.6 25.3 22.6 45 47.9 45l245.8 0c25.3 0 46.3-19.7 47.9-45L416 128z" />
116
- </svg>
117
- );
118
-
119
- case "ui-home":
120
-
121
- case "ui-filter":
122
- return (
123
- <svg
124
- className={["icon", `icon--${name}`, className]
125
- .filter((className) => !isEmpty(className))
126
- .join(" ")}
127
- width={width}
128
- height={height}
129
- viewBox="0 0 10.701 9.698"
130
- >
131
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
132
- {title && <title>{title}</title>}
133
- <g id="filter-solid" transform="translate(-2.667 -5.333)">
134
- <path
135
- id="Path_54"
136
- data-name="Path 54"
137
- d="M9.355,15.031V10.517l3.836-3.846a.605.605,0,0,0,.177-.435V5.668a.334.334,0,0,0-.334-.334H3a.334.334,0,0,0-.334.334v.558a.6.6,0,0,0,.177.425L6.68,10.544v3.411Z"
138
- transform="translate(0 0)"
139
- fill="#12aad8"
140
- />
141
- <path
142
- id="Path_55"
143
- data-name="Path 55"
144
- d="M13.194,5.333H2.827a.174.174,0,0,0-.161.174v.575A.445.445,0,0,0,2.8,6.4L6.81,10.413v3.344l2.425,1.207V10.406l4.013-4.013a.451.451,0,0,0,.12-.3V5.507a.174.174,0,0,0-.174-.174Z"
145
- />
146
- </g>
147
- </svg>
148
- );
149
-
150
- case "ui-close":
151
- return (
152
- <svg
153
- className={["icon", `icon--${name}`, className]
154
- .filter((className) => !isEmpty(className))
155
- .join(" ")}
156
- width={width}
157
- height={height}
158
- viewBox="0 0 384 512"
159
- >
160
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
161
- {title && <title>{title}</title>}
162
- <path d="M342.6 150.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L192 210.7 86.6 105.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L146.7 256 41.4 361.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L192 301.3 297.4 406.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L237.3 256 342.6 150.6z" />
163
- </svg>
164
- );
165
-
166
- case "ui-ticket":
167
- return (
168
- <svg
169
- className={["icon", `icon--${name}`, className]
170
- .filter((className) => !isEmpty(className))
171
- .join(" ")}
172
- width={width}
173
- height={height}
174
- viewBox="0 0 20 20"
175
- >
176
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
177
- {title && <title>{title}</title>}
178
- <g id="ticket" transform="translate(0.439 1.629)">
179
- <path
180
- id="Path_14"
181
- data-name="Path 14"
182
- d="M12.125,5.335l3.751,3.751L9.086,15.875,5.335,12.125Zm-2.5,11.62L16.955,9.62a.745.745,0,0,0,0-1.068l-4.3-4.3a.774.774,0,0,0-1.068,0L4.255,11.59a.745.745,0,0,0,0,1.068l4.3,4.3a.774.774,0,0,0,1.068,0ZM20.172,9.395,9.406,20.172a1.533,1.533,0,0,1-2.148,0l-1.5-1.5a2.293,2.293,0,0,0,0-3.228,2.2,2.2,0,0,0-1.614-.665,2.2,2.2,0,0,0-1.614.665l-1.484-1.5a1.533,1.533,0,0,1,0-2.148L11.816,1.05a1.533,1.533,0,0,1,2.148,0l1.484,1.484a2.2,2.2,0,0,0-.665,1.614,2.2,2.2,0,0,0,.665,1.614,2.293,2.293,0,0,0,3.228,0l1.5,1.484a1.533,1.533,0,0,1,0,2.148Z"
183
- transform="translate(-1.05 -2.24)"
184
- />
185
- </g>
186
- </svg>
187
- );
188
-
189
- case "ui-payback":
190
- return (
191
- <svg
192
- className={["icon", `icon--${name}`, className]
193
- .filter((className) => !isEmpty(className))
194
- .join(" ")}
195
- width={width}
196
- height={height}
197
- viewBox="0 0 20 20.154"
198
- >
199
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
200
- {title && <title>{title}</title>}
201
- <g id="layer1" transform="translate(-205.148 -293.014)">
202
- <path
203
- id="path453469"
204
- d="M223.472,306.895a1.674,1.674,0,0,0-1.188.487l-1.971,1.972a1.67,1.67,0,0,0-.978-.726l-4.652-1.247a2.766,2.766,0,0,0-2.182.331l-2.9,1.832-.235-.408a1.089,1.089,0,0,0-1.471-.394l-2.209,1.274a1.089,1.089,0,0,0-.394,1.471l3.291,5.7a1.088,1.088,0,0,0,1.47.4l2.209-1.276a1.09,1.09,0,0,0,.395-1.471l-.043-.076,1.258-.85,4.63.911a1.742,1.742,0,0,0,1.653-.514c1.493-1.527,2.988-3.048,4.505-4.544l0,0a1.675,1.675,0,0,0-1.189-2.863Zm0,1.332a.336.336,0,0,1,.238.1.323.323,0,0,1,0,.476c-1.525,1.5-3.024,3.031-4.518,4.559a1.847,1.847,0,0,1-.433.134l-4.9-.963a.672.672,0,0,0-.507.1l-1.411.954-1.667-2.886,2.947-1.858a1.411,1.411,0,0,1,1.118-.171l4.652,1.247a.336.336,0,1,1-.175.65l-2.92-.782a.672.672,0,0,0-.348,1.3l2.92.782a1.693,1.693,0,0,0,1.741-.572.672.672,0,0,0,.177-.118l2.85-2.852A.336.336,0,0,1,223.472,308.226Zm-15.14,1.812.325.564a.615.615,0,0,0,.253.438l2.445,4.235-1.745,1.008-3.024-5.237Z"
205
- transform="translate(0 -4.554)"
206
- fill-rule="evenodd"
207
- />
208
- <path
209
- id="path453459"
210
- d="M223.672,301.014a.672.672,0,1,0,0,1.344h1.344a.672.672,0,1,0,0-1.344Z"
211
- transform="translate(-5.857 -2.625)"
212
- fill-rule="evenodd"
213
- />
214
- <path
215
- id="path453437"
216
- d="M223.672,297.014a.672.672,0,0,0,0,1.344h1.344a.672.672,0,0,0,0-1.344Z"
217
- transform="translate(-5.857 -1.312)"
218
- fill-rule="evenodd"
219
- />
220
- <path
221
- id="rect18334"
222
- d="M222.7,293.014a4.7,4.7,0,1,0,4.7,4.7A4.714,4.714,0,0,0,222.7,293.014Zm0,1.344a3.359,3.359,0,1,1-3.359,3.359A3.349,3.349,0,0,1,222.7,294.357Z"
223
- transform="translate(-4.217)"
224
- fill-rule="evenodd"
225
- />
226
- </g>
227
- </svg>
228
- );
229
-
230
- case "ui-backpack":
231
- return (
232
- <svg
233
- className={["icon", `icon--${name}`, className]
234
- .filter((className) => !isEmpty(className))
235
- .join(" ")}
236
- width={width}
237
- height={height}
238
- viewBox="0 0 14.499 16.11"
239
- >
240
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
241
- {title && <title>{title}</title>}
242
- <path
243
- id="Path_2"
244
- data-name="Path 2"
245
- d="M22.444,28.805A.805.805,0,0,0,21.639,28H16.806a.806.806,0,0,0-.806.806v1.611h6.444ZM16,32.027h6.444v2.417H16Z"
246
- transform="translate(-11.972 -18.334)"
247
- />
248
- <path
249
- id="Path_3"
250
- data-name="Path 3"
251
- d="M20.5,12.055a4.837,4.837,0,0,0-4.028-4.761V6.417A2.419,2.419,0,0,0,14.055,4H12.444a2.419,2.419,0,0,0-2.417,2.417v.878A4.837,4.837,0,0,0,6,12.055V18.5A1.613,1.613,0,0,0,7.611,20.11h.806V14.472a2.419,2.419,0,0,1,2.417-2.417h4.833a2.419,2.419,0,0,1,2.417,2.417V20.11h.806A1.613,1.613,0,0,0,20.5,18.5ZM11.639,6.417a.806.806,0,0,1,.806-.806h1.611a.805.805,0,0,1,.805.806v.806H11.639Z"
252
- transform="translate(-6 -4)"
253
- />
254
- </svg>
255
- );
256
-
257
- case "ui-suitcase":
258
- return (
259
- <svg
260
- className={["icon", `icon--${name}`, className]
261
- .filter((className) => !isEmpty(className))
262
- .join(" ")}
263
- width={width}
264
- height={height}
265
- viewBox="0 0 15.992 13.708"
266
- >
267
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
268
- {title && <title>{title}</title>}
269
- <path
270
- id="Path_21"
271
- data-name="Path 21"
272
- d="M5.712,2.285h4.569V1.142H5.712Zm-3.141,0V13.708H2a1.924,1.924,0,0,1-1.41-.589A1.924,1.924,0,0,1,0,11.709V4.284a1.924,1.924,0,0,1,.589-1.41A1.924,1.924,0,0,1,2,2.285Zm10,0V13.708H3.427V2.285H4.569V.857A.826.826,0,0,1,4.819.25.826.826,0,0,1,5.426,0h5.14a.826.826,0,0,1,.607.25.826.826,0,0,1,.25.607V2.285Zm3.427,2v7.425a2.011,2.011,0,0,1-2,2h-.571V2.285h.571a1.924,1.924,0,0,1,1.41.589A1.924,1.924,0,0,1,15.992,4.284Z"
273
- transform="translate(0 0)"
274
- />
275
- </svg>
276
- );
277
-
278
- case "ui-business-lounge":
279
- return (
280
- <svg
281
- className={["icon", `icon--${name}`, className]
282
- .filter((className) => !isEmpty(className))
283
- .join(" ")}
284
- width={width}
285
- height={height}
286
- viewBox="0 0 20 19.999"
287
- >
288
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
289
- {title && <title>{title}</title>}
290
- <g id="waiting-room-svgrepo-com" transform="translate(0 -0.008)">
291
- <g
292
- id="Group_46"
293
- data-name="Group 46"
294
- transform="translate(0 0.008)"
295
- >
296
- <g id="Group_45" data-name="Group 45" transform="translate(0)">
297
- <path
298
- id="Path_33"
299
- data-name="Path 33"
300
- d="M65.683,110.007a1.667,1.667,0,1,0-1.667-1.667A1.666,1.666,0,0,0,65.683,110.007Z"
301
- transform="translate(-61.515 -102.507)"
302
- />
303
- <path
304
- id="Path_34"
305
- data-name="Path 34"
306
- d="M6.25,242.2H2.418L.824,235.025a.417.417,0,1,0-.814.181l1.657,7.455v2.454a.417.417,0,1,0,.833,0v-2.083H5v2.083a.417.417,0,1,0,.833,0v-2.083h.417a.417.417,0,0,0,0-.833Z"
307
- transform="translate(0 -225.532)"
308
- />
309
- <path
310
- id="Path_35"
311
- data-name="Path 35"
312
- d="M281.933.008a4.583,4.583,0,1,0,4.583,4.583A4.588,4.588,0,0,0,281.933.008Zm1.667,5h-1.667a.417.417,0,0,1-.417-.417v-2.5a.417.417,0,0,1,.833,0V4.175h1.25a.417.417,0,1,1,0,.833Z"
313
- transform="translate(-266.516 -0.008)"
314
- />
315
- <path
316
- id="Path_36"
317
- data-name="Path 36"
318
- d="M70.265,218.341H67.348v-3.333a1.667,1.667,0,0,0-3.333,0v4.583a1.251,1.251,0,0,0,1.25,1.25h3.75v2.917a1.25,1.25,0,1,0,2.5,0v-4.167A1.251,1.251,0,0,0,70.265,218.341Z"
319
- transform="translate(-61.514 -205.008)"
320
- />
321
- </g>
322
- </g>
323
- </g>
324
- </svg>
325
- );
326
-
327
- case "ui-shopping-bag":
328
- return (
329
- <svg
330
- className={["icon", `icon--${name}`, className]
331
- .filter((className) => !isEmpty(className))
332
- .join(" ")}
333
- width={width}
334
- height={height}
335
- viewBox="0 0 13.299 14.65"
336
- >
337
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
338
- {title && <title>{title}</title>}
339
- <path
340
- id="Path_22"
341
- data-name="Path 22"
342
- d="M9.135.6A3.523,3.523,0,0,0,5.612,4.123V5.691A2.455,2.455,0,0,0,5,5.869,2.967,2.967,0,0,0,3.842,6.8,6.951,6.951,0,0,0,3,9.393c-.452,2.056-.678,3.083-.392,3.885A2.967,2.967,0,0,0,3.835,14.8c.721.451,1.774.451,3.878.451h2.843c2.1,0,3.157,0,3.878-.451a2.967,2.967,0,0,0,1.223-1.521c.285-.8.059-1.829-.392-3.885a6.951,6.951,0,0,0-.837-2.59,2.967,2.967,0,0,0-1.162-.934,2.456,2.456,0,0,0-.608-.178V4.123A3.523,3.523,0,0,0,9.135.6Zm2.411,5.012V4.123a2.411,2.411,0,0,0-4.821,0V5.612c.287,0,.613,0,.989,0h2.843C10.933,5.607,11.259,5.607,11.546,5.612ZM6.168,8.574a.742.742,0,1,0-.742-.742A.742.742,0,0,0,6.168,8.574Zm6.676-.742A.742.742,0,1,1,12.1,7.09.742.742,0,0,1,12.844,7.832Z"
343
- transform="translate(-2.486 -0.6)"
344
- fill-rule="evenodd"
345
- />
346
- </svg>
347
- );
348
-
349
- case "ui-priority":
350
- return (
351
- <svg
352
- className={["icon", `icon--${name}`, className]
353
- .filter((className) => !isEmpty(className))
354
- .join(" ")}
355
- width={width}
356
- height={height}
357
- viewBox="0 0 20 17.533"
358
- >
359
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
360
- {title && <title>{title}</title>}
361
- <g id="list-high-priority" transform="translate(-1.5 -2.552)">
362
- <path
363
- id="Path_24"
364
- data-name="Path 24"
365
- d="M24,39H34v1.333H24Z"
366
- transform="translate(-12.5 -20.249)"
367
- />
368
- <path
369
- id="Path_25"
370
- data-name="Path 25"
371
- d="M24,29H34v1.333H24Z"
372
- transform="translate(-12.5 -14.694)"
373
- />
374
- <path
375
- id="Path_26"
376
- data-name="Path 26"
377
- d="M24,19H34v1.333H24Z"
378
- transform="translate(-12.5 -9.138)"
379
- />
380
- <path
381
- id="Path_27"
382
- data-name="Path 27"
383
- d="M30.75,9h7v1.333h-7Z"
384
- transform="translate(-16.25 -3.583)"
385
- />
386
- <path
387
- id="Path_28"
388
- data-name="Path 28"
389
- d="M13.417,6.043,7.8,2.551V5.418H7.551a5.544,5.544,0,0,0-4.326,2.2A8.164,8.164,0,0,0,1.5,12.751a8.164,8.164,0,0,0,1.725,5.133,5.544,5.544,0,0,0,4.326,2.2H9.833V18.751H7.551c-2.6,0-4.718-2.692-4.718-6s2.117-6,4.718-6H7.8V9.635ZM9.133,4.95l1.783,1.109L9.133,7.2Z"
390
- />
391
- </g>
392
- </svg>
393
- );
394
-
395
- case "ui-tooltip":
396
- return (
397
- <svg
398
- className={["icon", `icon--${name}`, className]
399
- .filter((className) => !isEmpty(className))
400
- .join(" ")}
401
- width={width}
402
- height={height}
403
- viewBox="0 0 512 512"
404
- >
405
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
406
- {title && <title>{title}</title>}
407
- <path d="M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM216 336l24 0 0-64-24 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 88 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zm40-208a32 32 0 1 1 0 64 32 32 0 1 1 0-64z" />
408
- </svg>
409
- );
410
-
411
- case "ui-qsm-location":
412
- return (
413
- <svg
414
- className={["icon", `icon--${name}`, className]
415
- .filter((className) => !isEmpty(className))
416
- .join(" ")}
417
- width={width}
418
- height={height}
419
- viewBox="0 0 384 512"
420
- >
421
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
422
- {title && <title>{title}</title>}
423
- <path d="M215.7 499.2C267 435 384 279.4 384 192C384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 128a64 64 0 1 1 0 128 64 64 0 1 1 0-128z" />
424
- </svg>
425
- );
426
-
427
- case "ui-plane-depart":
428
- return (
429
- <svg
430
- className={["icon", `icon--${name}`, className]
431
- .filter((className) => !isEmpty(className))
432
- .join(" ")}
433
- width={width}
434
- height={height}
435
- viewBox="0 0 640 512"
436
- >
437
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
438
- {title && <title>{title}</title>}
439
- <path d="M381 114.9L186.1 41.8c-16.7-6.2-35.2-5.3-51.1 2.7L89.1 67.4C78 73 77.2 88.5 87.6 95.2l146.9 94.5L136 240 77.8 214.1c-8.7-3.9-18.8-3.7-27.3 .6L18.3 230.8c-9.3 4.7-11.8 16.8-5 24.7l73.1 85.3c6.1 7.1 15 11.2 24.3 11.2l137.7 0c5 0 9.9-1.2 14.3-3.4L535.6 212.2c46.5-23.3 82.5-63.3 100.8-112C645.9 75 627.2 48 600.2 48l-57.4 0c-20.2 0-40.2 4.8-58.2 14L381 114.9zM0 480c0 17.7 14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 448c-17.7 0-32 14.3-32 32z" />
440
- </svg>
441
- );
442
-
443
- case "ui-plane-arrive":
444
- return (
445
- <svg
446
- className={["icon", `icon--${name}`, className]
447
- .filter((className) => !isEmpty(className))
448
- .join(" ")}
449
- width={width}
450
- height={height}
451
- viewBox="0 0 640 512"
452
- >
453
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
454
- {title && <title>{title}</title>}
455
- <path d="M.3 166.9L0 68C0 57.7 9.5 50.1 19.5 52.3l35.6 7.9c10.6 2.3 19.2 9.9 23 20L96 128l127.3 37.6L181.8 20.4C178.9 10.2 186.6 0 197.2 0l40.1 0c11.6 0 22.2 6.2 27.9 16.3l109 193.8 107.2 31.7c15.9 4.7 30.8 12.5 43.7 22.8l34.4 27.6c24 19.2 18.1 57.3-10.7 68.2c-41.2 15.6-86.2 18.1-128.8 7L121.7 289.8c-11.1-2.9-21.2-8.7-29.3-16.9L9.5 189.4c-5.9-6-9.3-14.1-9.3-22.5zM32 448l576 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32zm96-80a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm128-16a32 32 0 1 1 0 64 32 32 0 1 1 0-64z" />
456
- </svg>
457
- );
458
-
459
- case "ui-clock":
460
- return (
461
- <svg
462
- className={["icon", `icon--${name}`, className]
463
- .filter((className) => !isEmpty(className))
464
- .join(" ")}
465
- width={width}
466
- height={height}
467
- viewBox="0 0 19 19"
468
- >
469
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
470
- {title && <title>{title}</title>}
471
- <g
472
- id="Group_56"
473
- data-name="Group 56"
474
- transform="translate(-390 -665)"
475
- >
476
- <circle
477
- id="Ellipse_5"
478
- data-name="Ellipse 5"
479
- cx="9.5"
480
- cy="9.5"
481
- r="9.5"
482
- transform="translate(390 665)"
483
- fill="#fff"
484
- />
485
- <g id="time" transform="translate(391.211 666.211)">
486
- <path
487
- id="Path_11"
488
- data-name="Path 11"
489
- d="M8.289,13.578a5.289,5.289,0,1,1,5.289-5.289A5.289,5.289,0,0,1,8.289,13.578Zm0-9.823a4.534,4.534,0,1,0,4.534,4.534A4.534,4.534,0,0,0,8.289,3.756Z"
490
- transform="translate(0 0)"
491
- />
492
- <path
493
- id="Path_12"
494
- data-name="Path 12"
495
- d="M24.612,16.167,22.5,14.055V10.5h.756v3.241l1.889,1.893Z"
496
- transform="translate(-14.589 -5.611)"
497
- />
498
- </g>
499
- </g>
500
- </svg>
501
- );
502
-
503
- default:
504
- return null;
505
- }
506
- };
507
-
508
- export default Icon;
1
+ import { isEmpty } from "lodash";
2
+ import React, { useContext } from "react";
3
+ import SettingsContext from "../settings-context";
4
+ import HTMLComment from "react-html-comment";
5
+
6
+ interface IconProps {
7
+ name: string;
8
+ className?: string;
9
+ title?: string;
10
+ width?: number;
11
+ height?: number;
12
+ }
13
+
14
+ const Icon: React.FC<IconProps> = ({
15
+ name,
16
+ className,
17
+ title,
18
+ width,
19
+ height,
20
+ }) => {
21
+ const { icons } = useContext(SettingsContext);
22
+
23
+ if (icons) {
24
+ return (
25
+ <svg
26
+ className={["icon", `icon--${name}`, className]
27
+ .filter((className) => !isEmpty(className))
28
+ .join(" ")}
29
+ width={width}
30
+ height={height}
31
+ >
32
+ {title && <title>{title}</title>}
33
+ <use href={`${icons}#${name}`}></use>
34
+ </svg>
35
+ );
36
+ }
37
+
38
+ switch (name) {
39
+ case "ui-chevron":
40
+ return (
41
+ <svg
42
+ className={["icon", `icon--${name}`, className]
43
+ .filter((className) => !isEmpty(className))
44
+ .join(" ")}
45
+ width={width}
46
+ height={height}
47
+ viewBox="0 0 320 512"
48
+ >
49
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
50
+ {title && <title>{title}</title>}
51
+ <path d="M310.6 233.4c12.5 12.5 12.5 32.8 0 45.3l-192 192c-12.5 12.5-32.8 12.5-45.3 0s-12.5-32.8 0-45.3L242.7 256 73.4 86.6c-12.5-12.5-12.5-32.8 0-45.3s32.8-12.5 45.3 0l192 192z" />
52
+ </svg>
53
+ );
54
+
55
+ case "ui-error":
56
+ return (
57
+ <svg
58
+ className={["icon", `icon--${name}`, className]
59
+ .filter((className) => !isEmpty(className))
60
+ .join(" ")}
61
+ width={width}
62
+ height={height}
63
+ viewBox="0 0 512 512"
64
+ >
65
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
66
+ {title && <title>{title}</title>}
67
+ <path d="M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zm0-384c13.3 0 24 10.7 24 24l0 112c0 13.3-10.7 24-24 24s-24-10.7-24-24l0-112c0-13.3 10.7-24 24-24zM224 352a32 32 0 1 1 64 0 32 32 0 1 1 -64 0z" />
68
+ </svg>
69
+ );
70
+
71
+ case "ui-tel":
72
+ return (
73
+ <svg
74
+ className={["icon", `icon--${name}`, className]
75
+ .filter((className) => !isEmpty(className))
76
+ .join(" ")}
77
+ width={width}
78
+ height={height}
79
+ viewBox="0 0 512 512"
80
+ >
81
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
82
+ {title && <title>{title}</title>}
83
+ <path d="M164.9 24.6c-7.7-18.6-28-28.5-47.4-23.2l-88 24C12.1 30.2 0 46 0 64C0 311.4 200.6 512 448 512c18 0 33.8-12.1 38.6-29.5l24-88c5.3-19.4-4.6-39.7-23.2-47.4l-96-40c-16.3-6.8-35.2-2.1-46.3 11.6L304.7 368C234.3 334.7 177.3 277.7 144 207.3L193.3 167c13.7-11.2 18.4-30 11.6-46.3l-40-96z" />
84
+ </svg>
85
+ );
86
+
87
+ case "ui-mail":
88
+ return (
89
+ <svg
90
+ className={["icon", `icon--${name}`, className]
91
+ .filter((className) => !isEmpty(className))
92
+ .join(" ")}
93
+ width={width}
94
+ height={height}
95
+ viewBox="0 0 512 512"
96
+ >
97
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
98
+ {title && <title>{title}</title>}
99
+ <path d="M48 64C21.5 64 0 85.5 0 112c0 15.1 7.1 29.3 19.2 38.4L236.8 313.6c11.4 8.5 27 8.5 38.4 0L492.8 150.4c12.1-9.1 19.2-23.3 19.2-38.4c0-26.5-21.5-48-48-48L48 64zM0 176L0 384c0 35.3 28.7 64 64 64l384 0c35.3 0 64-28.7 64-64l0-208L294.4 339.2c-22.8 17.1-54 17.1-76.8 0L0 176z" />
100
+ </svg>
101
+ );
102
+
103
+ case "ui-trashcan":
104
+ return (
105
+ <svg
106
+ className={["icon", `icon--${name}`, className]
107
+ .filter((className) => !isEmpty(className))
108
+ .join(" ")}
109
+ width={width}
110
+ height={height}
111
+ viewBox="0 0 448 512"
112
+ >
113
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
114
+ {title && <title>{title}</title>}
115
+ <path d="M135.2 17.7L128 32 32 32C14.3 32 0 46.3 0 64S14.3 96 32 96l384 0c17.7 0 32-14.3 32-32s-14.3-32-32-32l-96 0-7.2-14.3C307.4 6.8 296.3 0 284.2 0L163.8 0c-12.1 0-23.2 6.8-28.6 17.7zM416 128L32 128 53.2 467c1.6 25.3 22.6 45 47.9 45l245.8 0c25.3 0 46.3-19.7 47.9-45L416 128z" />
116
+ </svg>
117
+ );
118
+
119
+ case "ui-home":
120
+
121
+ case "ui-filter":
122
+ return (
123
+ <svg
124
+ className={["icon", `icon--${name}`, className]
125
+ .filter((className) => !isEmpty(className))
126
+ .join(" ")}
127
+ width={width}
128
+ height={height}
129
+ viewBox="0 0 10.701 9.698"
130
+ >
131
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
132
+ {title && <title>{title}</title>}
133
+ <g id="filter-solid" transform="translate(-2.667 -5.333)">
134
+ <path
135
+ id="Path_54"
136
+ data-name="Path 54"
137
+ d="M9.355,15.031V10.517l3.836-3.846a.605.605,0,0,0,.177-.435V5.668a.334.334,0,0,0-.334-.334H3a.334.334,0,0,0-.334.334v.558a.6.6,0,0,0,.177.425L6.68,10.544v3.411Z"
138
+ transform="translate(0 0)"
139
+ fill="#12aad8"
140
+ />
141
+ <path
142
+ id="Path_55"
143
+ data-name="Path 55"
144
+ d="M13.194,5.333H2.827a.174.174,0,0,0-.161.174v.575A.445.445,0,0,0,2.8,6.4L6.81,10.413v3.344l2.425,1.207V10.406l4.013-4.013a.451.451,0,0,0,.12-.3V5.507a.174.174,0,0,0-.174-.174Z"
145
+ />
146
+ </g>
147
+ </svg>
148
+ );
149
+
150
+ case "ui-close":
151
+ return (
152
+ <svg
153
+ className={["icon", `icon--${name}`, className]
154
+ .filter((className) => !isEmpty(className))
155
+ .join(" ")}
156
+ width={width}
157
+ height={height}
158
+ viewBox="0 0 384 512"
159
+ >
160
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
161
+ {title && <title>{title}</title>}
162
+ <path d="M342.6 150.6c12.5-12.5 12.5-32.8 0-45.3s-32.8-12.5-45.3 0L192 210.7 86.6 105.4c-12.5-12.5-32.8-12.5-45.3 0s-12.5 32.8 0 45.3L146.7 256 41.4 361.4c-12.5 12.5-12.5 32.8 0 45.3s32.8 12.5 45.3 0L192 301.3 297.4 406.6c12.5 12.5 32.8 12.5 45.3 0s12.5-32.8 0-45.3L237.3 256 342.6 150.6z" />
163
+ </svg>
164
+ );
165
+
166
+ case "ui-ticket":
167
+ return (
168
+ <svg
169
+ className={["icon", `icon--${name}`, className]
170
+ .filter((className) => !isEmpty(className))
171
+ .join(" ")}
172
+ width={width}
173
+ height={height}
174
+ viewBox="0 0 20 20"
175
+ >
176
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
177
+ {title && <title>{title}</title>}
178
+ <g id="ticket" transform="translate(0.439 1.629)">
179
+ <path
180
+ id="Path_14"
181
+ data-name="Path 14"
182
+ d="M12.125,5.335l3.751,3.751L9.086,15.875,5.335,12.125Zm-2.5,11.62L16.955,9.62a.745.745,0,0,0,0-1.068l-4.3-4.3a.774.774,0,0,0-1.068,0L4.255,11.59a.745.745,0,0,0,0,1.068l4.3,4.3a.774.774,0,0,0,1.068,0ZM20.172,9.395,9.406,20.172a1.533,1.533,0,0,1-2.148,0l-1.5-1.5a2.293,2.293,0,0,0,0-3.228,2.2,2.2,0,0,0-1.614-.665,2.2,2.2,0,0,0-1.614.665l-1.484-1.5a1.533,1.533,0,0,1,0-2.148L11.816,1.05a1.533,1.533,0,0,1,2.148,0l1.484,1.484a2.2,2.2,0,0,0-.665,1.614,2.2,2.2,0,0,0,.665,1.614,2.293,2.293,0,0,0,3.228,0l1.5,1.484a1.533,1.533,0,0,1,0,2.148Z"
183
+ transform="translate(-1.05 -2.24)"
184
+ />
185
+ </g>
186
+ </svg>
187
+ );
188
+
189
+ case "ui-payback":
190
+ return (
191
+ <svg
192
+ className={["icon", `icon--${name}`, className]
193
+ .filter((className) => !isEmpty(className))
194
+ .join(" ")}
195
+ width={width}
196
+ height={height}
197
+ viewBox="0 0 20 20.154"
198
+ >
199
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
200
+ {title && <title>{title}</title>}
201
+ <g id="layer1" transform="translate(-205.148 -293.014)">
202
+ <path
203
+ id="path453469"
204
+ d="M223.472,306.895a1.674,1.674,0,0,0-1.188.487l-1.971,1.972a1.67,1.67,0,0,0-.978-.726l-4.652-1.247a2.766,2.766,0,0,0-2.182.331l-2.9,1.832-.235-.408a1.089,1.089,0,0,0-1.471-.394l-2.209,1.274a1.089,1.089,0,0,0-.394,1.471l3.291,5.7a1.088,1.088,0,0,0,1.47.4l2.209-1.276a1.09,1.09,0,0,0,.395-1.471l-.043-.076,1.258-.85,4.63.911a1.742,1.742,0,0,0,1.653-.514c1.493-1.527,2.988-3.048,4.505-4.544l0,0a1.675,1.675,0,0,0-1.189-2.863Zm0,1.332a.336.336,0,0,1,.238.1.323.323,0,0,1,0,.476c-1.525,1.5-3.024,3.031-4.518,4.559a1.847,1.847,0,0,1-.433.134l-4.9-.963a.672.672,0,0,0-.507.1l-1.411.954-1.667-2.886,2.947-1.858a1.411,1.411,0,0,1,1.118-.171l4.652,1.247a.336.336,0,1,1-.175.65l-2.92-.782a.672.672,0,0,0-.348,1.3l2.92.782a1.693,1.693,0,0,0,1.741-.572.672.672,0,0,0,.177-.118l2.85-2.852A.336.336,0,0,1,223.472,308.226Zm-15.14,1.812.325.564a.615.615,0,0,0,.253.438l2.445,4.235-1.745,1.008-3.024-5.237Z"
205
+ transform="translate(0 -4.554)"
206
+ fill-rule="evenodd"
207
+ />
208
+ <path
209
+ id="path453459"
210
+ d="M223.672,301.014a.672.672,0,1,0,0,1.344h1.344a.672.672,0,1,0,0-1.344Z"
211
+ transform="translate(-5.857 -2.625)"
212
+ fill-rule="evenodd"
213
+ />
214
+ <path
215
+ id="path453437"
216
+ d="M223.672,297.014a.672.672,0,0,0,0,1.344h1.344a.672.672,0,0,0,0-1.344Z"
217
+ transform="translate(-5.857 -1.312)"
218
+ fill-rule="evenodd"
219
+ />
220
+ <path
221
+ id="rect18334"
222
+ d="M222.7,293.014a4.7,4.7,0,1,0,4.7,4.7A4.714,4.714,0,0,0,222.7,293.014Zm0,1.344a3.359,3.359,0,1,1-3.359,3.359A3.349,3.349,0,0,1,222.7,294.357Z"
223
+ transform="translate(-4.217)"
224
+ fill-rule="evenodd"
225
+ />
226
+ </g>
227
+ </svg>
228
+ );
229
+
230
+ case "ui-backpack":
231
+ return (
232
+ <svg
233
+ className={["icon", `icon--${name}`, className]
234
+ .filter((className) => !isEmpty(className))
235
+ .join(" ")}
236
+ width={width}
237
+ height={height}
238
+ viewBox="0 0 14.499 16.11"
239
+ >
240
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
241
+ {title && <title>{title}</title>}
242
+ <path
243
+ id="Path_2"
244
+ data-name="Path 2"
245
+ d="M22.444,28.805A.805.805,0,0,0,21.639,28H16.806a.806.806,0,0,0-.806.806v1.611h6.444ZM16,32.027h6.444v2.417H16Z"
246
+ transform="translate(-11.972 -18.334)"
247
+ />
248
+ <path
249
+ id="Path_3"
250
+ data-name="Path 3"
251
+ d="M20.5,12.055a4.837,4.837,0,0,0-4.028-4.761V6.417A2.419,2.419,0,0,0,14.055,4H12.444a2.419,2.419,0,0,0-2.417,2.417v.878A4.837,4.837,0,0,0,6,12.055V18.5A1.613,1.613,0,0,0,7.611,20.11h.806V14.472a2.419,2.419,0,0,1,2.417-2.417h4.833a2.419,2.419,0,0,1,2.417,2.417V20.11h.806A1.613,1.613,0,0,0,20.5,18.5ZM11.639,6.417a.806.806,0,0,1,.806-.806h1.611a.805.805,0,0,1,.805.806v.806H11.639Z"
252
+ transform="translate(-6 -4)"
253
+ />
254
+ </svg>
255
+ );
256
+
257
+ case "ui-suitcase":
258
+ return (
259
+ <svg
260
+ className={["icon", `icon--${name}`, className]
261
+ .filter((className) => !isEmpty(className))
262
+ .join(" ")}
263
+ width={width}
264
+ height={height}
265
+ viewBox="0 0 15.992 13.708"
266
+ >
267
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
268
+ {title && <title>{title}</title>}
269
+ <path
270
+ id="Path_21"
271
+ data-name="Path 21"
272
+ d="M5.712,2.285h4.569V1.142H5.712Zm-3.141,0V13.708H2a1.924,1.924,0,0,1-1.41-.589A1.924,1.924,0,0,1,0,11.709V4.284a1.924,1.924,0,0,1,.589-1.41A1.924,1.924,0,0,1,2,2.285Zm10,0V13.708H3.427V2.285H4.569V.857A.826.826,0,0,1,4.819.25.826.826,0,0,1,5.426,0h5.14a.826.826,0,0,1,.607.25.826.826,0,0,1,.25.607V2.285Zm3.427,2v7.425a2.011,2.011,0,0,1-2,2h-.571V2.285h.571a1.924,1.924,0,0,1,1.41.589A1.924,1.924,0,0,1,15.992,4.284Z"
273
+ transform="translate(0 0)"
274
+ />
275
+ </svg>
276
+ );
277
+
278
+ case "ui-business-lounge":
279
+ return (
280
+ <svg
281
+ className={["icon", `icon--${name}`, className]
282
+ .filter((className) => !isEmpty(className))
283
+ .join(" ")}
284
+ width={width}
285
+ height={height}
286
+ viewBox="0 0 20 19.999"
287
+ >
288
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
289
+ {title && <title>{title}</title>}
290
+ <g id="waiting-room-svgrepo-com" transform="translate(0 -0.008)">
291
+ <g
292
+ id="Group_46"
293
+ data-name="Group 46"
294
+ transform="translate(0 0.008)"
295
+ >
296
+ <g id="Group_45" data-name="Group 45" transform="translate(0)">
297
+ <path
298
+ id="Path_33"
299
+ data-name="Path 33"
300
+ d="M65.683,110.007a1.667,1.667,0,1,0-1.667-1.667A1.666,1.666,0,0,0,65.683,110.007Z"
301
+ transform="translate(-61.515 -102.507)"
302
+ />
303
+ <path
304
+ id="Path_34"
305
+ data-name="Path 34"
306
+ d="M6.25,242.2H2.418L.824,235.025a.417.417,0,1,0-.814.181l1.657,7.455v2.454a.417.417,0,1,0,.833,0v-2.083H5v2.083a.417.417,0,1,0,.833,0v-2.083h.417a.417.417,0,0,0,0-.833Z"
307
+ transform="translate(0 -225.532)"
308
+ />
309
+ <path
310
+ id="Path_35"
311
+ data-name="Path 35"
312
+ d="M281.933.008a4.583,4.583,0,1,0,4.583,4.583A4.588,4.588,0,0,0,281.933.008Zm1.667,5h-1.667a.417.417,0,0,1-.417-.417v-2.5a.417.417,0,0,1,.833,0V4.175h1.25a.417.417,0,1,1,0,.833Z"
313
+ transform="translate(-266.516 -0.008)"
314
+ />
315
+ <path
316
+ id="Path_36"
317
+ data-name="Path 36"
318
+ d="M70.265,218.341H67.348v-3.333a1.667,1.667,0,0,0-3.333,0v4.583a1.251,1.251,0,0,0,1.25,1.25h3.75v2.917a1.25,1.25,0,1,0,2.5,0v-4.167A1.251,1.251,0,0,0,70.265,218.341Z"
319
+ transform="translate(-61.514 -205.008)"
320
+ />
321
+ </g>
322
+ </g>
323
+ </g>
324
+ </svg>
325
+ );
326
+
327
+ case "ui-shopping-bag":
328
+ return (
329
+ <svg
330
+ className={["icon", `icon--${name}`, className]
331
+ .filter((className) => !isEmpty(className))
332
+ .join(" ")}
333
+ width={width}
334
+ height={height}
335
+ viewBox="0 0 13.299 14.65"
336
+ >
337
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
338
+ {title && <title>{title}</title>}
339
+ <path
340
+ id="Path_22"
341
+ data-name="Path 22"
342
+ d="M9.135.6A3.523,3.523,0,0,0,5.612,4.123V5.691A2.455,2.455,0,0,0,5,5.869,2.967,2.967,0,0,0,3.842,6.8,6.951,6.951,0,0,0,3,9.393c-.452,2.056-.678,3.083-.392,3.885A2.967,2.967,0,0,0,3.835,14.8c.721.451,1.774.451,3.878.451h2.843c2.1,0,3.157,0,3.878-.451a2.967,2.967,0,0,0,1.223-1.521c.285-.8.059-1.829-.392-3.885a6.951,6.951,0,0,0-.837-2.59,2.967,2.967,0,0,0-1.162-.934,2.456,2.456,0,0,0-.608-.178V4.123A3.523,3.523,0,0,0,9.135.6Zm2.411,5.012V4.123a2.411,2.411,0,0,0-4.821,0V5.612c.287,0,.613,0,.989,0h2.843C10.933,5.607,11.259,5.607,11.546,5.612ZM6.168,8.574a.742.742,0,1,0-.742-.742A.742.742,0,0,0,6.168,8.574Zm6.676-.742A.742.742,0,1,1,12.1,7.09.742.742,0,0,1,12.844,7.832Z"
343
+ transform="translate(-2.486 -0.6)"
344
+ fill-rule="evenodd"
345
+ />
346
+ </svg>
347
+ );
348
+
349
+ case "ui-priority":
350
+ return (
351
+ <svg
352
+ className={["icon", `icon--${name}`, className]
353
+ .filter((className) => !isEmpty(className))
354
+ .join(" ")}
355
+ width={width}
356
+ height={height}
357
+ viewBox="0 0 20 17.533"
358
+ >
359
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
360
+ {title && <title>{title}</title>}
361
+ <g id="list-high-priority" transform="translate(-1.5 -2.552)">
362
+ <path
363
+ id="Path_24"
364
+ data-name="Path 24"
365
+ d="M24,39H34v1.333H24Z"
366
+ transform="translate(-12.5 -20.249)"
367
+ />
368
+ <path
369
+ id="Path_25"
370
+ data-name="Path 25"
371
+ d="M24,29H34v1.333H24Z"
372
+ transform="translate(-12.5 -14.694)"
373
+ />
374
+ <path
375
+ id="Path_26"
376
+ data-name="Path 26"
377
+ d="M24,19H34v1.333H24Z"
378
+ transform="translate(-12.5 -9.138)"
379
+ />
380
+ <path
381
+ id="Path_27"
382
+ data-name="Path 27"
383
+ d="M30.75,9h7v1.333h-7Z"
384
+ transform="translate(-16.25 -3.583)"
385
+ />
386
+ <path
387
+ id="Path_28"
388
+ data-name="Path 28"
389
+ d="M13.417,6.043,7.8,2.551V5.418H7.551a5.544,5.544,0,0,0-4.326,2.2A8.164,8.164,0,0,0,1.5,12.751a8.164,8.164,0,0,0,1.725,5.133,5.544,5.544,0,0,0,4.326,2.2H9.833V18.751H7.551c-2.6,0-4.718-2.692-4.718-6s2.117-6,4.718-6H7.8V9.635ZM9.133,4.95l1.783,1.109L9.133,7.2Z"
390
+ />
391
+ </g>
392
+ </svg>
393
+ );
394
+
395
+ case "ui-tooltip":
396
+ return (
397
+ <svg
398
+ className={["icon", `icon--${name}`, className]
399
+ .filter((className) => !isEmpty(className))
400
+ .join(" ")}
401
+ width={width}
402
+ height={height}
403
+ viewBox="0 0 512 512"
404
+ >
405
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
406
+ {title && <title>{title}</title>}
407
+ <path d="M256 512A256 256 0 1 0 256 0a256 256 0 1 0 0 512zM216 336l24 0 0-64-24 0c-13.3 0-24-10.7-24-24s10.7-24 24-24l48 0c13.3 0 24 10.7 24 24l0 88 8 0c13.3 0 24 10.7 24 24s-10.7 24-24 24l-80 0c-13.3 0-24-10.7-24-24s10.7-24 24-24zm40-208a32 32 0 1 1 0 64 32 32 0 1 1 0-64z" />
408
+ </svg>
409
+ );
410
+
411
+ case "ui-qsm-location":
412
+ return (
413
+ <svg
414
+ className={["icon", `icon--${name}`, className]
415
+ .filter((className) => !isEmpty(className))
416
+ .join(" ")}
417
+ width={width}
418
+ height={height}
419
+ viewBox="0 0 384 512"
420
+ >
421
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
422
+ {title && <title>{title}</title>}
423
+ <path d="M215.7 499.2C267 435 384 279.4 384 192C384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 128a64 64 0 1 1 0 128 64 64 0 1 1 0-128z" />
424
+ </svg>
425
+ );
426
+
427
+ case "ui-plane-depart":
428
+ return (
429
+ <svg
430
+ className={["icon", `icon--${name}`, className]
431
+ .filter((className) => !isEmpty(className))
432
+ .join(" ")}
433
+ width={width}
434
+ height={height}
435
+ viewBox="0 0 640 512"
436
+ >
437
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
438
+ {title && <title>{title}</title>}
439
+ <path d="M381 114.9L186.1 41.8c-16.7-6.2-35.2-5.3-51.1 2.7L89.1 67.4C78 73 77.2 88.5 87.6 95.2l146.9 94.5L136 240 77.8 214.1c-8.7-3.9-18.8-3.7-27.3 .6L18.3 230.8c-9.3 4.7-11.8 16.8-5 24.7l73.1 85.3c6.1 7.1 15 11.2 24.3 11.2l137.7 0c5 0 9.9-1.2 14.3-3.4L535.6 212.2c46.5-23.3 82.5-63.3 100.8-112C645.9 75 627.2 48 600.2 48l-57.4 0c-20.2 0-40.2 4.8-58.2 14L381 114.9zM0 480c0 17.7 14.3 32 32 32l576 0c17.7 0 32-14.3 32-32s-14.3-32-32-32L32 448c-17.7 0-32 14.3-32 32z" />
440
+ </svg>
441
+ );
442
+
443
+ case "ui-plane-arrive":
444
+ return (
445
+ <svg
446
+ className={["icon", `icon--${name}`, className]
447
+ .filter((className) => !isEmpty(className))
448
+ .join(" ")}
449
+ width={width}
450
+ height={height}
451
+ viewBox="0 0 640 512"
452
+ >
453
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
454
+ {title && <title>{title}</title>}
455
+ <path d="M.3 166.9L0 68C0 57.7 9.5 50.1 19.5 52.3l35.6 7.9c10.6 2.3 19.2 9.9 23 20L96 128l127.3 37.6L181.8 20.4C178.9 10.2 186.6 0 197.2 0l40.1 0c11.6 0 22.2 6.2 27.9 16.3l109 193.8 107.2 31.7c15.9 4.7 30.8 12.5 43.7 22.8l34.4 27.6c24 19.2 18.1 57.3-10.7 68.2c-41.2 15.6-86.2 18.1-128.8 7L121.7 289.8c-11.1-2.9-21.2-8.7-29.3-16.9L9.5 189.4c-5.9-6-9.3-14.1-9.3-22.5zM32 448l576 0c17.7 0 32 14.3 32 32s-14.3 32-32 32L32 512c-17.7 0-32-14.3-32-32s14.3-32 32-32zm96-80a32 32 0 1 1 64 0 32 32 0 1 1 -64 0zm128-16a32 32 0 1 1 0 64 32 32 0 1 1 0-64z" />
456
+ </svg>
457
+ );
458
+
459
+ case "ui-clock":
460
+ return (
461
+ <svg
462
+ className={["icon", `icon--${name}`, className]
463
+ .filter((className) => !isEmpty(className))
464
+ .join(" ")}
465
+ width={width}
466
+ height={height}
467
+ viewBox="0 0 19 19"
468
+ >
469
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
470
+ {title && <title>{title}</title>}
471
+ <g
472
+ id="Group_56"
473
+ data-name="Group 56"
474
+ transform="translate(-390 -665)"
475
+ >
476
+ <circle
477
+ id="Ellipse_5"
478
+ data-name="Ellipse 5"
479
+ cx="9.5"
480
+ cy="9.5"
481
+ r="9.5"
482
+ transform="translate(390 665)"
483
+ fill="#fff"
484
+ />
485
+ <g id="time" transform="translate(391.211 666.211)">
486
+ <path
487
+ id="Path_11"
488
+ data-name="Path 11"
489
+ d="M8.289,13.578a5.289,5.289,0,1,1,5.289-5.289A5.289,5.289,0,0,1,8.289,13.578Zm0-9.823a4.534,4.534,0,1,0,4.534,4.534A4.534,4.534,0,0,0,8.289,3.756Z"
490
+ transform="translate(0 0)"
491
+ />
492
+ <path
493
+ id="Path_12"
494
+ data-name="Path 12"
495
+ d="M24.612,16.167,22.5,14.055V10.5h.756v3.241l1.889,1.893Z"
496
+ transform="translate(-14.589 -5.611)"
497
+ />
498
+ </g>
499
+ </g>
500
+ </svg>
501
+ );
502
+
503
+ default:
504
+ return null;
505
+ }
506
+ };
507
+
508
+ export default Icon;