@qite/tide-booking-component 1.4.93 → 1.4.95

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 (181) hide show
  1. package/.prettierrc +9 -9
  2. package/.vs/ProjectSettings.json +3 -3
  3. package/.vs/VSWorkspaceState.json +5 -5
  4. package/build/build-cjs/index.js +81 -27
  5. package/build/build-cjs/src/booking-wizard/features/booking/booking-slice.d.ts +2 -1
  6. package/build/build-cjs/src/booking-wizard/features/booking/selectors.d.ts +4 -3
  7. package/build/build-cjs/src/booking-wizard/features/price-details/price-details-slice.d.ts +1 -0
  8. package/build/build-cjs/src/booking-wizard/features/price-details/selectors.d.ts +1 -0
  9. package/build/build-cjs/src/booking-wizard/features/sidebar/sidebar.d.ts +1 -0
  10. package/build/build-cjs/src/booking-wizard/types.d.ts +1 -0
  11. package/build/build-cjs/src/shared/utils/localization-util.d.ts +1 -0
  12. package/build/build-esm/index.js +81 -27
  13. package/build/build-esm/src/booking-wizard/features/booking/booking-slice.d.ts +2 -1
  14. package/build/build-esm/src/booking-wizard/features/booking/selectors.d.ts +4 -3
  15. package/build/build-esm/src/booking-wizard/features/price-details/price-details-slice.d.ts +1 -0
  16. package/build/build-esm/src/booking-wizard/features/price-details/selectors.d.ts +1 -0
  17. package/build/build-esm/src/booking-wizard/features/sidebar/sidebar.d.ts +1 -0
  18. package/build/build-esm/src/booking-wizard/types.d.ts +1 -0
  19. package/build/build-esm/src/shared/utils/localization-util.d.ts +1 -0
  20. package/package.json +83 -83
  21. package/src/booking-product/components/age-select.tsx +35 -35
  22. package/src/booking-product/components/amount-input.tsx +51 -51
  23. package/src/booking-product/components/date-range-picker/calendar.tsx +155 -155
  24. package/src/booking-product/components/footer.tsx +54 -54
  25. package/src/booking-product/components/header.tsx +57 -57
  26. package/src/booking-product/components/icon.tsx +200 -200
  27. package/src/booking-product/components/list-view.tsx +54 -54
  28. package/src/booking-product/components/rating.tsx +21 -21
  29. package/src/booking-product/components/rooms.tsx +171 -171
  30. package/src/booking-product/constants.ts +1 -1
  31. package/src/booking-product/index.tsx +21 -21
  32. package/src/booking-product/settings-context.ts +16 -16
  33. package/src/booking-product/types.ts +30 -30
  34. package/src/booking-product/utils/api.ts +26 -26
  35. package/src/booking-product/utils/price.ts +28 -28
  36. package/src/booking-wizard/api-settings-slice.ts +24 -24
  37. package/src/booking-wizard/components/icon.tsx +398 -398
  38. package/src/booking-wizard/components/labeled-input.tsx +56 -56
  39. package/src/booking-wizard/components/labeled-select.tsx +54 -54
  40. package/src/booking-wizard/components/message.tsx +21 -21
  41. package/src/booking-wizard/components/multi-range-filter.tsx +99 -99
  42. package/src/booking-wizard/components/phone-input.tsx +146 -146
  43. package/src/booking-wizard/components/print-offer-button.tsx +53 -53
  44. package/src/booking-wizard/components/product-card.tsx +23 -23
  45. package/src/booking-wizard/declarations.d.ts +4 -4
  46. package/src/booking-wizard/features/booking/booking-self-contained.tsx +16 -1
  47. package/src/booking-wizard/features/booking/booking-slice.ts +9 -1
  48. package/src/booking-wizard/features/booking/booking.tsx +16 -1
  49. package/src/booking-wizard/features/booking/selectors.ts +5 -0
  50. package/src/booking-wizard/features/flight-options/flight-filter.tsx +371 -371
  51. package/src/booking-wizard/features/flight-options/flight-option-flight.tsx +354 -354
  52. package/src/booking-wizard/features/flight-options/flight-option-modal.tsx +211 -211
  53. package/src/booking-wizard/features/flight-options/flight-option.tsx +57 -57
  54. package/src/booking-wizard/features/flight-options/flight-utils.ts +423 -423
  55. package/src/booking-wizard/features/price-details/price-details-api.ts +20 -20
  56. package/src/booking-wizard/features/price-details/price-details-slice.ts +2 -0
  57. package/src/booking-wizard/features/price-details/selectors.ts +1 -0
  58. package/src/booking-wizard/features/price-details/util.ts +115 -115
  59. package/src/booking-wizard/features/product-options/no-options.tsx +18 -18
  60. package/src/booking-wizard/features/product-options/none-option.tsx +73 -73
  61. package/src/booking-wizard/features/product-options/option-booking-airline-group.tsx +53 -53
  62. package/src/booking-wizard/features/product-options/option-booking-group.tsx +152 -152
  63. package/src/booking-wizard/features/product-options/option-item.tsx +236 -236
  64. package/src/booking-wizard/features/product-options/option-pax-card.tsx +159 -159
  65. package/src/booking-wizard/features/product-options/option-pax-group.tsx +122 -122
  66. package/src/booking-wizard/features/product-options/option-room.tsx +226 -226
  67. package/src/booking-wizard/features/product-options/option-unit-group.tsx +138 -138
  68. package/src/booking-wizard/features/room-options/room-utils.ts +154 -154
  69. package/src/booking-wizard/features/room-options/room.tsx +123 -123
  70. package/src/booking-wizard/features/room-options/traveler-rooms.tsx +64 -64
  71. package/src/booking-wizard/features/sidebar/index.tsx +2 -0
  72. package/src/booking-wizard/features/sidebar/sidebar-flight.tsx +66 -66
  73. package/src/booking-wizard/features/sidebar/sidebar.tsx +17 -1
  74. package/src/booking-wizard/features/summary/summary-booking-option-pax.tsx +23 -23
  75. package/src/booking-wizard/features/summary/summary-booking-option-unit.tsx +23 -23
  76. package/src/booking-wizard/features/summary/summary-flight.tsx +36 -36
  77. package/src/booking-wizard/features/summary/summary-per-booking-option-group.tsx +60 -60
  78. package/src/booking-wizard/features/summary/summary-per-pax-option-group.tsx +56 -56
  79. package/src/booking-wizard/features/summary/summary-per-unit-option-group.tsx +58 -58
  80. package/src/booking-wizard/features/summary/summary-slice.ts +27 -27
  81. package/src/booking-wizard/features/travelers-form/travelers-form-slice.ts +157 -157
  82. package/src/booking-wizard/features/travelers-form/travelers-form-util.ts +10 -10
  83. package/src/booking-wizard/features/travelers-form/type-ahead-input.tsx +85 -85
  84. package/src/booking-wizard/features/travelers-form/validate-form.ts +178 -178
  85. package/src/booking-wizard/index.tsx +27 -27
  86. package/src/booking-wizard/store.ts +26 -26
  87. package/src/booking-wizard/types.ts +1 -0
  88. package/src/booking-wizard/use-offer-printer.ts +108 -108
  89. package/src/content/components/LanguageSwitcher.tsx +158 -158
  90. package/src/content/components/accordion.tsx +30 -30
  91. package/src/content/components/contact.tsx +211 -211
  92. package/src/content/components/personal-contact-form.tsx +809 -809
  93. package/src/content/header/index.tsx +43 -43
  94. package/src/content/header/types.ts +26 -26
  95. package/src/qsm/components/date-picker/index.tsx +152 -152
  96. package/src/qsm/components/date-range-picker/calendar-day.tsx +49 -49
  97. package/src/qsm/components/date-range-picker/calendar.tsx +211 -211
  98. package/src/qsm/components/date-range-picker/index.tsx +404 -404
  99. package/src/qsm/index.tsx +26 -26
  100. package/src/qsm/store/qsm-store.ts +13 -13
  101. package/src/search-results/components/flight/flight-card.tsx +38 -38
  102. package/src/search-results/components/flight/flight-leg.tsx +61 -61
  103. package/src/search-results/components/flight/flight-path.tsx +23 -23
  104. package/src/search-results/components/multi-range-filter.tsx +104 -104
  105. package/src/search-results/components/search-results-container/search-results-container.tsx +2 -2
  106. package/src/search-results/index.tsx +24 -24
  107. package/src/search-results/search-results-configuration-context.ts +6 -6
  108. package/src/search-results/store/search-results-store.ts +13 -13
  109. package/src/shared/components/loader.tsx +16 -16
  110. package/src/shared/translations/ar-SA.json +2 -1
  111. package/src/shared/translations/da-DK.json +2 -1
  112. package/src/shared/translations/de-DE.json +2 -1
  113. package/src/shared/translations/en-GB.json +2 -1
  114. package/src/shared/translations/es-ES.json +2 -1
  115. package/src/shared/translations/fr-BE.json +2 -1
  116. package/src/shared/translations/fr-FR.json +2 -1
  117. package/src/shared/translations/is-IS.json +2 -1
  118. package/src/shared/translations/it-IT.json +2 -1
  119. package/src/shared/translations/ja-JP.json +2 -1
  120. package/src/shared/translations/nl-BE.json +2 -1
  121. package/src/shared/translations/nl-NL.json +2 -1
  122. package/src/shared/translations/no-NO.json +2 -1
  123. package/src/shared/translations/pl-PL.json +2 -1
  124. package/src/shared/translations/pt-PT.json +2 -1
  125. package/src/shared/translations/sv-SE.json +2 -1
  126. package/src/shared/utils/class-util.ts +7 -7
  127. package/src/shared/utils/query-string-util.ts +91 -91
  128. package/src/shared/utils/tide-api-utils.ts +34 -34
  129. package/src/shared/utils/use-media-query-util.ts +19 -19
  130. package/styles/abstracts/_mixins.scss +74 -74
  131. package/styles/abstracts/_variables.scss +57 -57
  132. package/styles/base/_fonts.scss +2 -2
  133. package/styles/base/_normalize.scss +227 -227
  134. package/styles/base/_typography.scss +35 -35
  135. package/styles/booking-joker-variables.scss +596 -596
  136. package/styles/booking-product-variables.scss +330 -330
  137. package/styles/booking-product.scss +438 -438
  138. package/styles/booking-qsm-variables.scss +501 -501
  139. package/styles/booking-qsm.scss +52 -52
  140. package/styles/booking-wizard-variables.scss +603 -603
  141. package/styles/booking-wizard.scss +61 -61
  142. package/styles/components/_accordion.scss +67 -67
  143. package/styles/components/_animations.scss +39 -39
  144. package/styles/components/_base.scss +107 -107
  145. package/styles/components/_breadcrumb.scss +92 -92
  146. package/styles/components/_button.scss +238 -238
  147. package/styles/components/_checkbox.scss +230 -230
  148. package/styles/components/_contact.scss +239 -239
  149. package/styles/components/_cta.scss +238 -238
  150. package/styles/components/_date-list.scss +41 -41
  151. package/styles/components/_date-range-picker.scss +223 -223
  152. package/styles/components/_decrement-increment.scss +35 -35
  153. package/styles/components/_dropdown.scss +72 -72
  154. package/styles/components/_faq.scss +27 -27
  155. package/styles/components/_flight-option.scss +1419 -1419
  156. package/styles/components/_gallery.scss +314 -314
  157. package/styles/components/_header.scss +113 -113
  158. package/styles/components/_img-slider.scss +175 -175
  159. package/styles/components/_info-message.scss +75 -75
  160. package/styles/components/_input.scss +35 -35
  161. package/styles/components/_list.scss +185 -185
  162. package/styles/components/_loader.scss +70 -70
  163. package/styles/components/_mixins.scss +579 -579
  164. package/styles/components/_passenger-picker.scss +306 -306
  165. package/styles/components/_phone-input.scss +8 -8
  166. package/styles/components/_placeholders.scss +165 -165
  167. package/styles/components/_qsm.scss +17 -17
  168. package/styles/components/_radiobutton.scss +170 -170
  169. package/styles/components/_select-wrapper.scss +76 -76
  170. package/styles/components/_slider.scss +128 -128
  171. package/styles/components/_spinner.scss +29 -29
  172. package/styles/components/_step-indicators.scss +161 -161
  173. package/styles/components/_table.scss +81 -81
  174. package/styles/components/_typeahead.scss +275 -275
  175. package/styles/components/_variables.scss +89 -89
  176. package/styles/content-blocks-variables.scss +507 -507
  177. package/styles/font.scss +2 -2
  178. package/styles/qsm/_calendar.scss +274 -274
  179. package/styles/qsm/_qsm.scss +1094 -1094
  180. package/styles/search.scss +1200 -1200
  181. package/tsconfig.json +24 -24
@@ -1,398 +1,398 @@
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> = ({ name, className, title, width, height }) => {
15
- const { icons } = useContext(SettingsContext);
16
-
17
- if (icons) {
18
- return (
19
- <svg className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')} width={width} height={height}>
20
- {title && <title>{title}</title>}
21
- <use href={`${icons}#${name}`}></use>
22
- </svg>
23
- );
24
- }
25
-
26
- switch (name) {
27
- case 'ui-chevron':
28
- return (
29
- <svg
30
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
31
- width={width}
32
- height={height}
33
- viewBox="0 0 320 512">
34
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
35
- {title && <title>{title}</title>}
36
- <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" />
37
- </svg>
38
- );
39
-
40
- case 'ui-error':
41
- return (
42
- <svg
43
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
44
- width={width}
45
- height={height}
46
- viewBox="0 0 512 512">
47
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
48
- {title && <title>{title}</title>}
49
- <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" />
50
- </svg>
51
- );
52
-
53
- case 'ui-tel':
54
- return (
55
- <svg
56
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
57
- width={width}
58
- height={height}
59
- viewBox="0 0 512 512">
60
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
61
- {title && <title>{title}</title>}
62
- <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" />
63
- </svg>
64
- );
65
-
66
- case 'ui-mail':
67
- return (
68
- <svg
69
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
70
- width={width}
71
- height={height}
72
- viewBox="0 0 512 512">
73
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
74
- {title && <title>{title}</title>}
75
- <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" />
76
- </svg>
77
- );
78
-
79
- case 'ui-trashcan':
80
- return (
81
- <svg
82
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
83
- width={width}
84
- height={height}
85
- viewBox="0 0 448 512">
86
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
87
- {title && <title>{title}</title>}
88
- <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" />
89
- </svg>
90
- );
91
-
92
- case 'ui-home':
93
-
94
- case 'ui-filter':
95
- return (
96
- <svg
97
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
98
- width={width}
99
- height={height}
100
- viewBox="0 0 10.701 9.698">
101
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
102
- {title && <title>{title}</title>}
103
- <g id="filter-solid" transform="translate(-2.667 -5.333)">
104
- <path
105
- id="Path_54"
106
- data-name="Path 54"
107
- 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"
108
- transform="translate(0 0)"
109
- fill="#12aad8"
110
- />
111
- <path
112
- id="Path_55"
113
- data-name="Path 55"
114
- 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"
115
- />
116
- </g>
117
- </svg>
118
- );
119
-
120
- case 'ui-close':
121
- return (
122
- <svg
123
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
124
- width={width}
125
- height={height}
126
- viewBox="0 0 384 512">
127
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
128
- {title && <title>{title}</title>}
129
- <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" />
130
- </svg>
131
- );
132
-
133
- case 'ui-ticket':
134
- return (
135
- <svg
136
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
137
- width={width}
138
- height={height}
139
- viewBox="0 0 20 20">
140
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
141
- {title && <title>{title}</title>}
142
- <g id="ticket" transform="translate(0.439 1.629)">
143
- <path
144
- id="Path_14"
145
- data-name="Path 14"
146
- 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"
147
- transform="translate(-1.05 -2.24)"
148
- />
149
- </g>
150
- </svg>
151
- );
152
-
153
- case 'ui-payback':
154
- return (
155
- <svg
156
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
157
- width={width}
158
- height={height}
159
- viewBox="0 0 20 20.154">
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
- <g id="layer1" transform="translate(-205.148 -293.014)">
163
- <path
164
- id="path453469"
165
- 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"
166
- transform="translate(0 -4.554)"
167
- fill-rule="evenodd"
168
- />
169
- <path
170
- id="path453459"
171
- d="M223.672,301.014a.672.672,0,1,0,0,1.344h1.344a.672.672,0,1,0,0-1.344Z"
172
- transform="translate(-5.857 -2.625)"
173
- fill-rule="evenodd"
174
- />
175
- <path
176
- id="path453437"
177
- d="M223.672,297.014a.672.672,0,0,0,0,1.344h1.344a.672.672,0,0,0,0-1.344Z"
178
- transform="translate(-5.857 -1.312)"
179
- fill-rule="evenodd"
180
- />
181
- <path
182
- id="rect18334"
183
- 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"
184
- transform="translate(-4.217)"
185
- fill-rule="evenodd"
186
- />
187
- </g>
188
- </svg>
189
- );
190
-
191
- case 'ui-backpack':
192
- return (
193
- <svg
194
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
195
- width={width}
196
- height={height}
197
- viewBox="0 0 14.499 16.11">
198
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
199
- {title && <title>{title}</title>}
200
- <path
201
- id="Path_2"
202
- data-name="Path 2"
203
- 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"
204
- transform="translate(-11.972 -18.334)"
205
- />
206
- <path
207
- id="Path_3"
208
- data-name="Path 3"
209
- 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"
210
- transform="translate(-6 -4)"
211
- />
212
- </svg>
213
- );
214
-
215
- case 'ui-suitcase':
216
- return (
217
- <svg
218
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
219
- width={width}
220
- height={height}
221
- viewBox="0 0 15.992 13.708">
222
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
223
- {title && <title>{title}</title>}
224
- <path
225
- id="Path_21"
226
- data-name="Path 21"
227
- 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"
228
- transform="translate(0 0)"
229
- />
230
- </svg>
231
- );
232
-
233
- case 'ui-business-lounge':
234
- return (
235
- <svg
236
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
237
- width={width}
238
- height={height}
239
- viewBox="0 0 20 19.999">
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
- <g id="waiting-room-svgrepo-com" transform="translate(0 -0.008)">
243
- <g id="Group_46" data-name="Group 46" transform="translate(0 0.008)">
244
- <g id="Group_45" data-name="Group 45" transform="translate(0)">
245
- <path
246
- id="Path_33"
247
- data-name="Path 33"
248
- 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"
249
- transform="translate(-61.515 -102.507)"
250
- />
251
- <path
252
- id="Path_34"
253
- data-name="Path 34"
254
- 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"
255
- transform="translate(0 -225.532)"
256
- />
257
- <path
258
- id="Path_35"
259
- data-name="Path 35"
260
- 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"
261
- transform="translate(-266.516 -0.008)"
262
- />
263
- <path
264
- id="Path_36"
265
- data-name="Path 36"
266
- 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"
267
- transform="translate(-61.514 -205.008)"
268
- />
269
- </g>
270
- </g>
271
- </g>
272
- </svg>
273
- );
274
-
275
- case 'ui-shopping-bag':
276
- return (
277
- <svg
278
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
279
- width={width}
280
- height={height}
281
- viewBox="0 0 13.299 14.65">
282
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
283
- {title && <title>{title}</title>}
284
- <path
285
- id="Path_22"
286
- data-name="Path 22"
287
- 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"
288
- transform="translate(-2.486 -0.6)"
289
- fill-rule="evenodd"
290
- />
291
- </svg>
292
- );
293
-
294
- case 'ui-priority':
295
- return (
296
- <svg
297
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
298
- width={width}
299
- height={height}
300
- viewBox="0 0 20 17.533">
301
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
302
- {title && <title>{title}</title>}
303
- <g id="list-high-priority" transform="translate(-1.5 -2.552)">
304
- <path id="Path_24" data-name="Path 24" d="M24,39H34v1.333H24Z" transform="translate(-12.5 -20.249)" />
305
- <path id="Path_25" data-name="Path 25" d="M24,29H34v1.333H24Z" transform="translate(-12.5 -14.694)" />
306
- <path id="Path_26" data-name="Path 26" d="M24,19H34v1.333H24Z" transform="translate(-12.5 -9.138)" />
307
- <path id="Path_27" data-name="Path 27" d="M30.75,9h7v1.333h-7Z" transform="translate(-16.25 -3.583)" />
308
- <path
309
- id="Path_28"
310
- data-name="Path 28"
311
- 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"
312
- />
313
- </g>
314
- </svg>
315
- );
316
-
317
- case 'ui-tooltip':
318
- return (
319
- <svg
320
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
321
- width={width}
322
- height={height}
323
- viewBox="0 0 512 512">
324
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
325
- {title && <title>{title}</title>}
326
- <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" />
327
- </svg>
328
- );
329
-
330
- case 'ui-qsm-location':
331
- return (
332
- <svg
333
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
334
- width={width}
335
- height={height}
336
- viewBox="0 0 384 512">
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 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" />
340
- </svg>
341
- );
342
-
343
- case 'ui-plane-depart':
344
- return (
345
- <svg
346
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
347
- width={width}
348
- height={height}
349
- viewBox="0 0 640 512">
350
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
351
- {title && <title>{title}</title>}
352
- <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" />
353
- </svg>
354
- );
355
-
356
- case 'ui-plane-arrive':
357
- return (
358
- <svg
359
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
360
- width={width}
361
- height={height}
362
- viewBox="0 0 640 512">
363
- <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
364
- {title && <title>{title}</title>}
365
- <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" />
366
- </svg>
367
- );
368
-
369
- case 'ui-clock':
370
- return (
371
- <svg
372
- className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
373
- width={width}
374
- height={height}
375
- viewBox="0 0 19 19">
376
- {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
377
- {title && <title>{title}</title>}
378
- <g id="Group_56" data-name="Group 56" transform="translate(-390 -665)">
379
- <circle id="Ellipse_5" data-name="Ellipse 5" cx="9.5" cy="9.5" r="9.5" transform="translate(390 665)" fill="#fff" />
380
- <g id="time" transform="translate(391.211 666.211)">
381
- <path
382
- id="Path_11"
383
- data-name="Path 11"
384
- 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"
385
- transform="translate(0 0)"
386
- />
387
- <path id="Path_12" data-name="Path 12" d="M24.612,16.167,22.5,14.055V10.5h.756v3.241l1.889,1.893Z" transform="translate(-14.589 -5.611)" />
388
- </g>
389
- </g>
390
- </svg>
391
- );
392
-
393
- default:
394
- return null;
395
- }
396
- };
397
-
398
- 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> = ({ name, className, title, width, height }) => {
15
+ const { icons } = useContext(SettingsContext);
16
+
17
+ if (icons) {
18
+ return (
19
+ <svg className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')} width={width} height={height}>
20
+ {title && <title>{title}</title>}
21
+ <use href={`${icons}#${name}`}></use>
22
+ </svg>
23
+ );
24
+ }
25
+
26
+ switch (name) {
27
+ case 'ui-chevron':
28
+ return (
29
+ <svg
30
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
31
+ width={width}
32
+ height={height}
33
+ viewBox="0 0 320 512">
34
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
35
+ {title && <title>{title}</title>}
36
+ <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" />
37
+ </svg>
38
+ );
39
+
40
+ case 'ui-error':
41
+ return (
42
+ <svg
43
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
44
+ width={width}
45
+ height={height}
46
+ viewBox="0 0 512 512">
47
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
48
+ {title && <title>{title}</title>}
49
+ <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" />
50
+ </svg>
51
+ );
52
+
53
+ case 'ui-tel':
54
+ return (
55
+ <svg
56
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
57
+ width={width}
58
+ height={height}
59
+ viewBox="0 0 512 512">
60
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
61
+ {title && <title>{title}</title>}
62
+ <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" />
63
+ </svg>
64
+ );
65
+
66
+ case 'ui-mail':
67
+ return (
68
+ <svg
69
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
70
+ width={width}
71
+ height={height}
72
+ viewBox="0 0 512 512">
73
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
74
+ {title && <title>{title}</title>}
75
+ <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" />
76
+ </svg>
77
+ );
78
+
79
+ case 'ui-trashcan':
80
+ return (
81
+ <svg
82
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
83
+ width={width}
84
+ height={height}
85
+ viewBox="0 0 448 512">
86
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
87
+ {title && <title>{title}</title>}
88
+ <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" />
89
+ </svg>
90
+ );
91
+
92
+ case 'ui-home':
93
+
94
+ case 'ui-filter':
95
+ return (
96
+ <svg
97
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
98
+ width={width}
99
+ height={height}
100
+ viewBox="0 0 10.701 9.698">
101
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
102
+ {title && <title>{title}</title>}
103
+ <g id="filter-solid" transform="translate(-2.667 -5.333)">
104
+ <path
105
+ id="Path_54"
106
+ data-name="Path 54"
107
+ 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"
108
+ transform="translate(0 0)"
109
+ fill="#12aad8"
110
+ />
111
+ <path
112
+ id="Path_55"
113
+ data-name="Path 55"
114
+ 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"
115
+ />
116
+ </g>
117
+ </svg>
118
+ );
119
+
120
+ case 'ui-close':
121
+ return (
122
+ <svg
123
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
124
+ width={width}
125
+ height={height}
126
+ viewBox="0 0 384 512">
127
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
128
+ {title && <title>{title}</title>}
129
+ <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" />
130
+ </svg>
131
+ );
132
+
133
+ case 'ui-ticket':
134
+ return (
135
+ <svg
136
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
137
+ width={width}
138
+ height={height}
139
+ viewBox="0 0 20 20">
140
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
141
+ {title && <title>{title}</title>}
142
+ <g id="ticket" transform="translate(0.439 1.629)">
143
+ <path
144
+ id="Path_14"
145
+ data-name="Path 14"
146
+ 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"
147
+ transform="translate(-1.05 -2.24)"
148
+ />
149
+ </g>
150
+ </svg>
151
+ );
152
+
153
+ case 'ui-payback':
154
+ return (
155
+ <svg
156
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
157
+ width={width}
158
+ height={height}
159
+ viewBox="0 0 20 20.154">
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
+ <g id="layer1" transform="translate(-205.148 -293.014)">
163
+ <path
164
+ id="path453469"
165
+ 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"
166
+ transform="translate(0 -4.554)"
167
+ fill-rule="evenodd"
168
+ />
169
+ <path
170
+ id="path453459"
171
+ d="M223.672,301.014a.672.672,0,1,0,0,1.344h1.344a.672.672,0,1,0,0-1.344Z"
172
+ transform="translate(-5.857 -2.625)"
173
+ fill-rule="evenodd"
174
+ />
175
+ <path
176
+ id="path453437"
177
+ d="M223.672,297.014a.672.672,0,0,0,0,1.344h1.344a.672.672,0,0,0,0-1.344Z"
178
+ transform="translate(-5.857 -1.312)"
179
+ fill-rule="evenodd"
180
+ />
181
+ <path
182
+ id="rect18334"
183
+ 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"
184
+ transform="translate(-4.217)"
185
+ fill-rule="evenodd"
186
+ />
187
+ </g>
188
+ </svg>
189
+ );
190
+
191
+ case 'ui-backpack':
192
+ return (
193
+ <svg
194
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
195
+ width={width}
196
+ height={height}
197
+ viewBox="0 0 14.499 16.11">
198
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
199
+ {title && <title>{title}</title>}
200
+ <path
201
+ id="Path_2"
202
+ data-name="Path 2"
203
+ 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"
204
+ transform="translate(-11.972 -18.334)"
205
+ />
206
+ <path
207
+ id="Path_3"
208
+ data-name="Path 3"
209
+ 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"
210
+ transform="translate(-6 -4)"
211
+ />
212
+ </svg>
213
+ );
214
+
215
+ case 'ui-suitcase':
216
+ return (
217
+ <svg
218
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
219
+ width={width}
220
+ height={height}
221
+ viewBox="0 0 15.992 13.708">
222
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
223
+ {title && <title>{title}</title>}
224
+ <path
225
+ id="Path_21"
226
+ data-name="Path 21"
227
+ 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"
228
+ transform="translate(0 0)"
229
+ />
230
+ </svg>
231
+ );
232
+
233
+ case 'ui-business-lounge':
234
+ return (
235
+ <svg
236
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
237
+ width={width}
238
+ height={height}
239
+ viewBox="0 0 20 19.999">
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
+ <g id="waiting-room-svgrepo-com" transform="translate(0 -0.008)">
243
+ <g id="Group_46" data-name="Group 46" transform="translate(0 0.008)">
244
+ <g id="Group_45" data-name="Group 45" transform="translate(0)">
245
+ <path
246
+ id="Path_33"
247
+ data-name="Path 33"
248
+ 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"
249
+ transform="translate(-61.515 -102.507)"
250
+ />
251
+ <path
252
+ id="Path_34"
253
+ data-name="Path 34"
254
+ 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"
255
+ transform="translate(0 -225.532)"
256
+ />
257
+ <path
258
+ id="Path_35"
259
+ data-name="Path 35"
260
+ 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"
261
+ transform="translate(-266.516 -0.008)"
262
+ />
263
+ <path
264
+ id="Path_36"
265
+ data-name="Path 36"
266
+ 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"
267
+ transform="translate(-61.514 -205.008)"
268
+ />
269
+ </g>
270
+ </g>
271
+ </g>
272
+ </svg>
273
+ );
274
+
275
+ case 'ui-shopping-bag':
276
+ return (
277
+ <svg
278
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
279
+ width={width}
280
+ height={height}
281
+ viewBox="0 0 13.299 14.65">
282
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
283
+ {title && <title>{title}</title>}
284
+ <path
285
+ id="Path_22"
286
+ data-name="Path 22"
287
+ 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"
288
+ transform="translate(-2.486 -0.6)"
289
+ fill-rule="evenodd"
290
+ />
291
+ </svg>
292
+ );
293
+
294
+ case 'ui-priority':
295
+ return (
296
+ <svg
297
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
298
+ width={width}
299
+ height={height}
300
+ viewBox="0 0 20 17.533">
301
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
302
+ {title && <title>{title}</title>}
303
+ <g id="list-high-priority" transform="translate(-1.5 -2.552)">
304
+ <path id="Path_24" data-name="Path 24" d="M24,39H34v1.333H24Z" transform="translate(-12.5 -20.249)" />
305
+ <path id="Path_25" data-name="Path 25" d="M24,29H34v1.333H24Z" transform="translate(-12.5 -14.694)" />
306
+ <path id="Path_26" data-name="Path 26" d="M24,19H34v1.333H24Z" transform="translate(-12.5 -9.138)" />
307
+ <path id="Path_27" data-name="Path 27" d="M30.75,9h7v1.333h-7Z" transform="translate(-16.25 -3.583)" />
308
+ <path
309
+ id="Path_28"
310
+ data-name="Path 28"
311
+ 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"
312
+ />
313
+ </g>
314
+ </svg>
315
+ );
316
+
317
+ case 'ui-tooltip':
318
+ return (
319
+ <svg
320
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
321
+ width={width}
322
+ height={height}
323
+ viewBox="0 0 512 512">
324
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
325
+ {title && <title>{title}</title>}
326
+ <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" />
327
+ </svg>
328
+ );
329
+
330
+ case 'ui-qsm-location':
331
+ return (
332
+ <svg
333
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
334
+ width={width}
335
+ height={height}
336
+ viewBox="0 0 384 512">
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 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" />
340
+ </svg>
341
+ );
342
+
343
+ case 'ui-plane-depart':
344
+ return (
345
+ <svg
346
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
347
+ width={width}
348
+ height={height}
349
+ viewBox="0 0 640 512">
350
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
351
+ {title && <title>{title}</title>}
352
+ <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" />
353
+ </svg>
354
+ );
355
+
356
+ case 'ui-plane-arrive':
357
+ return (
358
+ <svg
359
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
360
+ width={width}
361
+ height={height}
362
+ viewBox="0 0 640 512">
363
+ <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." />
364
+ {title && <title>{title}</title>}
365
+ <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" />
366
+ </svg>
367
+ );
368
+
369
+ case 'ui-clock':
370
+ return (
371
+ <svg
372
+ className={['icon', `icon--${name}`, className].filter((className) => !isEmpty(className)).join(' ')}
373
+ width={width}
374
+ height={height}
375
+ viewBox="0 0 19 19">
376
+ {/* <HTMLComment text="!Font Awesome Free 6.7.2 by @fontawesome - https://fontawesome.com License - https://fontawesome.com/license/free Copyright 2025 Fonticons, Inc." /> */}
377
+ {title && <title>{title}</title>}
378
+ <g id="Group_56" data-name="Group 56" transform="translate(-390 -665)">
379
+ <circle id="Ellipse_5" data-name="Ellipse 5" cx="9.5" cy="9.5" r="9.5" transform="translate(390 665)" fill="#fff" />
380
+ <g id="time" transform="translate(391.211 666.211)">
381
+ <path
382
+ id="Path_11"
383
+ data-name="Path 11"
384
+ 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"
385
+ transform="translate(0 0)"
386
+ />
387
+ <path id="Path_12" data-name="Path 12" d="M24.612,16.167,22.5,14.055V10.5h.756v3.241l1.889,1.893Z" transform="translate(-14.589 -5.611)" />
388
+ </g>
389
+ </g>
390
+ </svg>
391
+ );
392
+
393
+ default:
394
+ return null;
395
+ }
396
+ };
397
+
398
+ export default Icon;