@next-degree/pickle-shared-js 0.13.6 → 0.14.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. package/dist/{chunk-KQLHT5UE.js → chunk-3XO3AJR4.js} +3 -3
  2. package/dist/{chunk-KQLHT5UE.js.map → chunk-3XO3AJR4.js.map} +1 -1
  3. package/dist/{chunk-XC3HIJM3.cjs → chunk-4FETL23S.cjs} +16 -13
  4. package/dist/chunk-4FETL23S.cjs.map +1 -0
  5. package/dist/chunk-5GODYRZA.js +138 -0
  6. package/dist/chunk-5GODYRZA.js.map +1 -0
  7. package/dist/{chunk-KJ5X2ZKA.js → chunk-5REFGTWO.js} +3 -3
  8. package/dist/{chunk-KJ5X2ZKA.js.map → chunk-5REFGTWO.js.map} +1 -1
  9. package/dist/{chunk-CEA4U6AR.js → chunk-62HL22CD.js} +13 -6
  10. package/dist/chunk-62HL22CD.js.map +1 -0
  11. package/dist/chunk-6KGXXX6X.cjs +140 -0
  12. package/dist/chunk-6KGXXX6X.cjs.map +1 -0
  13. package/dist/{chunk-WOD47B4V.js → chunk-6Z6T5WWS.js} +4 -4
  14. package/dist/{chunk-WOD47B4V.js.map → chunk-6Z6T5WWS.js.map} +1 -1
  15. package/dist/chunk-73JL5O6N.cjs +95 -0
  16. package/dist/chunk-73JL5O6N.cjs.map +1 -0
  17. package/dist/{chunk-54CL72AL.cjs → chunk-7NP3NX67.cjs} +3 -3
  18. package/dist/{chunk-54CL72AL.cjs.map → chunk-7NP3NX67.cjs.map} +1 -1
  19. package/dist/{chunk-6EW2D7K7.cjs → chunk-7TFFAGVB.cjs} +33 -8
  20. package/dist/chunk-7TFFAGVB.cjs.map +1 -0
  21. package/dist/{chunk-MLV2TE6H.cjs → chunk-CGCGALTZ.cjs} +8 -8
  22. package/dist/{chunk-MLV2TE6H.cjs.map → chunk-CGCGALTZ.cjs.map} +1 -1
  23. package/dist/{chunk-NEIGOAE6.cjs → chunk-EYN3RHOF.cjs} +19 -12
  24. package/dist/chunk-EYN3RHOF.cjs.map +1 -0
  25. package/dist/{chunk-3FQTSGHL.cjs → chunk-F567WG2X.cjs} +47 -35
  26. package/dist/chunk-F567WG2X.cjs.map +1 -0
  27. package/dist/{chunk-DUVGFEGU.js → chunk-G4KDEQIL.js} +28 -18
  28. package/dist/chunk-G4KDEQIL.js.map +1 -0
  29. package/dist/chunk-IPP5X4TY.js +53 -0
  30. package/dist/chunk-IPP5X4TY.js.map +1 -0
  31. package/dist/{chunk-XGQU7BQK.js → chunk-JZLJVA4I.js} +47 -35
  32. package/dist/chunk-JZLJVA4I.js.map +1 -0
  33. package/dist/{chunk-C3DCFPJC.cjs → chunk-KBAY4F7D.cjs} +23 -16
  34. package/dist/chunk-KBAY4F7D.cjs.map +1 -0
  35. package/dist/{chunk-VB32IBQC.cjs → chunk-N7GS4DZD.cjs} +8 -6
  36. package/dist/chunk-N7GS4DZD.cjs.map +1 -0
  37. package/dist/{chunk-ZCBOREOG.js → chunk-PU4O76IS.js} +11 -8
  38. package/dist/chunk-PU4O76IS.js.map +1 -0
  39. package/dist/chunk-PVW2B7IC.js +73 -0
  40. package/dist/chunk-PVW2B7IC.js.map +1 -0
  41. package/dist/{chunk-GKL5KEO4.js → chunk-PWKRCU2K.js} +32 -9
  42. package/dist/chunk-PWKRCU2K.js.map +1 -0
  43. package/dist/{chunk-B472HOM3.js → chunk-QYSTBZXD.js} +7 -7
  44. package/dist/{chunk-B472HOM3.js.map → chunk-QYSTBZXD.js.map} +1 -1
  45. package/dist/{chunk-62OBBM7T.js → chunk-SNHRG4TY.js} +23 -16
  46. package/dist/chunk-SNHRG4TY.js.map +1 -0
  47. package/dist/{chunk-RO6NJGYB.cjs → chunk-SPAVM3EE.cjs} +3 -3
  48. package/dist/{chunk-RO6NJGYB.cjs.map → chunk-SPAVM3EE.cjs.map} +1 -1
  49. package/dist/{chunk-6CSDTWDX.cjs → chunk-TOEADI6J.cjs} +4 -4
  50. package/dist/{chunk-6CSDTWDX.cjs.map → chunk-TOEADI6J.cjs.map} +1 -1
  51. package/dist/{chunk-DURKKV2E.js → chunk-TXSLKNR3.js} +6 -4
  52. package/dist/chunk-TXSLKNR3.js.map +1 -0
  53. package/dist/{chunk-FAMHC5MQ.cjs → chunk-Z2I2265Q.cjs} +32 -9
  54. package/dist/chunk-Z2I2265Q.cjs.map +1 -0
  55. package/dist/{chunk-UW6NEKBF.cjs → chunk-ZLANEWSF.cjs} +28 -18
  56. package/dist/chunk-ZLANEWSF.cjs.map +1 -0
  57. package/dist/{company_service_sanity-DF01qvTz.d.ts → company_service_sanity-B1Xg7ISJ.d.ts} +271 -271
  58. package/dist/{company_service_sanity-Br0R7m-A.d.cts → company_service_sanity-CCbS8ElX.d.cts} +271 -271
  59. package/dist/components/buttons/BackButton.cjs +1 -1
  60. package/dist/components/buttons/BackButton.js +1 -1
  61. package/dist/components/jobCard/JobLocation.cjs +1 -1
  62. package/dist/components/jobCard/JobLocation.d.cts +1 -1
  63. package/dist/components/jobCard/JobLocation.d.ts +1 -1
  64. package/dist/components/jobCard/JobLocation.js +1 -1
  65. package/dist/components/jobPost/JobHeader.cjs +5 -5
  66. package/dist/components/jobPost/JobHeader.js +4 -4
  67. package/dist/components/jobPost/JobPost.cjs +20 -20
  68. package/dist/components/jobPost/JobPost.d.cts +1 -1
  69. package/dist/components/jobPost/JobPost.d.ts +1 -1
  70. package/dist/components/jobPost/JobPost.js +19 -19
  71. package/dist/components/primitives/command.cjs +10 -10
  72. package/dist/components/primitives/command.d.cts +1 -1
  73. package/dist/components/primitives/command.d.ts +1 -1
  74. package/dist/components/primitives/command.js +1 -1
  75. package/dist/components/primitives/radio-group.cjs +3 -3
  76. package/dist/components/primitives/radio-group.d.cts +9 -1
  77. package/dist/components/primitives/radio-group.d.ts +9 -1
  78. package/dist/components/primitives/radio-group.js +1 -1
  79. package/dist/components/ui/Button.d.cts +1 -1
  80. package/dist/components/ui/Button.d.ts +1 -1
  81. package/dist/components/ui/Combobox.cjs +4 -4
  82. package/dist/components/ui/Combobox.d.cts +2 -1
  83. package/dist/components/ui/Combobox.d.ts +2 -1
  84. package/dist/components/ui/Combobox.js +3 -3
  85. package/dist/components/ui/Counter.cjs +2 -2
  86. package/dist/components/ui/Counter.d.cts +2 -2
  87. package/dist/components/ui/Counter.d.ts +2 -2
  88. package/dist/components/ui/Counter.js +1 -1
  89. package/dist/components/ui/DatePicker.cjs +2 -2
  90. package/dist/components/ui/DatePicker.d.cts +8 -3
  91. package/dist/components/ui/DatePicker.d.ts +8 -3
  92. package/dist/components/ui/DatePicker.js +1 -1
  93. package/dist/components/ui/Input.cjs +2 -2
  94. package/dist/components/ui/Input.d.cts +2 -1
  95. package/dist/components/ui/Input.d.ts +2 -1
  96. package/dist/components/ui/Input.js +1 -1
  97. package/dist/components/ui/Map/MapComponent.cjs +5 -5
  98. package/dist/components/ui/Map/MapComponent.js +4 -4
  99. package/dist/components/ui/Map/MapContent.cjs +1 -1
  100. package/dist/components/ui/Map/MapContent.js +1 -1
  101. package/dist/components/ui/Map/index.cjs +5 -5
  102. package/dist/components/ui/Map/index.js +4 -4
  103. package/dist/components/ui/PlacesQueryInput.cjs +4 -4
  104. package/dist/components/ui/PlacesQueryInput.d.cts +3 -1
  105. package/dist/components/ui/PlacesQueryInput.d.ts +3 -1
  106. package/dist/components/ui/PlacesQueryInput.js +3 -3
  107. package/dist/components/ui/Radio.cjs +3 -3
  108. package/dist/components/ui/Radio.d.cts +4 -1
  109. package/dist/components/ui/Radio.d.ts +4 -1
  110. package/dist/components/ui/Radio.js +2 -2
  111. package/dist/components/ui/Select.cjs +2 -2
  112. package/dist/components/ui/Select.d.cts +9 -1
  113. package/dist/components/ui/Select.d.ts +9 -1
  114. package/dist/components/ui/Select.js +1 -1
  115. package/dist/components/ui/Switch.cjs +2 -2
  116. package/dist/components/ui/Switch.d.cts +7 -1
  117. package/dist/components/ui/Switch.d.ts +7 -1
  118. package/dist/components/ui/Switch.js +1 -1
  119. package/dist/components/ui/buttonShadcn.d.cts +1 -1
  120. package/dist/components/ui/buttonShadcn.d.ts +1 -1
  121. package/dist/{displayText-BDPndCI9.d.cts → displayText-Ck0qovrl.d.cts} +2 -2
  122. package/dist/{displayText-EpnIpZ38.d.ts → displayText-ClDGmi1J.d.ts} +2 -2
  123. package/dist/hooks/useDisplayText.d.cts +3 -3
  124. package/dist/hooks/useDisplayText.d.ts +3 -3
  125. package/dist/index.cjs +72 -72
  126. package/dist/index.d.cts +6 -6
  127. package/dist/index.d.ts +6 -6
  128. package/dist/index.js +34 -34
  129. package/dist/{job_posting_service_latest-BKz5U2Gp.d.cts → job_posting_service_latest-Bk53vj02.d.cts} +177 -177
  130. package/dist/{job_posting_service_latest-BKz5U2Gp.d.ts → job_posting_service_latest-Bk53vj02.d.ts} +177 -177
  131. package/dist/{job_posting_service_latest-B6Trs6sX.d.cts → job_posting_service_latest-DfX8Y4gB.d.cts} +177 -177
  132. package/dist/{job_posting_service_latest-B6Trs6sX.d.ts → job_posting_service_latest-DfX8Y4gB.d.ts} +177 -177
  133. package/dist/{job_posting_service_sanity-BN7XcVxU.d.cts → job_posting_service_sanity-BSxLNte3.d.cts} +357 -357
  134. package/dist/{job_posting_service_sanity-BNQsNQs2.d.ts → job_posting_service_sanity-C6aPb8kp.d.ts} +357 -357
  135. package/dist/lib/locations.d.cts +3 -3
  136. package/dist/lib/locations.d.ts +3 -3
  137. package/dist/lib/mappings.d.cts +3 -3
  138. package/dist/lib/mappings.d.ts +3 -3
  139. package/dist/lib/salaryRange.cjs +2 -2
  140. package/dist/lib/salaryRange.d.cts +1 -1
  141. package/dist/lib/salaryRange.d.ts +1 -1
  142. package/dist/lib/salaryRange.js +2 -2
  143. package/dist/services/displayText.d.cts +3 -3
  144. package/dist/services/displayText.d.ts +3 -3
  145. package/dist/styles/globals.css +53 -26
  146. package/dist/styles/globals.css.map +1 -1
  147. package/dist/types/data/company_service_latest.d.cts +1 -1
  148. package/dist/types/data/company_service_latest.d.ts +1 -1
  149. package/dist/types/data/job_posting_service_latest.d.cts +1 -1
  150. package/dist/types/data/job_posting_service_latest.d.ts +1 -1
  151. package/dist/types/data/shared_pickle_output_latest.d.cts +1 -1
  152. package/dist/types/data/shared_pickle_output_latest.d.ts +1 -1
  153. package/dist/types/index.cjs +7 -7
  154. package/dist/types/index.d.cts +5 -5
  155. package/dist/types/index.d.ts +5 -5
  156. package/dist/types/index.js +2 -2
  157. package/dist/types/latest/company_service_latest.d.cts +1 -1
  158. package/dist/types/latest/company_service_latest.d.ts +1 -1
  159. package/dist/types/latest/custom/company_service_sanity.d.cts +3 -3
  160. package/dist/types/latest/custom/company_service_sanity.d.ts +3 -3
  161. package/dist/types/latest/custom/job_posting_service_sanity.cjs +12 -12
  162. package/dist/types/latest/custom/job_posting_service_sanity.d.cts +3 -3
  163. package/dist/types/latest/custom/job_posting_service_sanity.d.ts +3 -3
  164. package/dist/types/latest/custom/job_posting_service_sanity.js +2 -2
  165. package/dist/types/latest/job_posting_service_latest.d.cts +1 -1
  166. package/dist/types/latest/job_posting_service_latest.d.ts +1 -1
  167. package/dist/types/latest/shared_pickle_output_latest.d.cts +1 -1
  168. package/dist/types/latest/shared_pickle_output_latest.d.ts +1 -1
  169. package/package.json +1 -1
  170. package/dist/chunk-2I2TWTPC.js +0 -115
  171. package/dist/chunk-2I2TWTPC.js.map +0 -1
  172. package/dist/chunk-3FQTSGHL.cjs.map +0 -1
  173. package/dist/chunk-62OBBM7T.js.map +0 -1
  174. package/dist/chunk-6EW2D7K7.cjs.map +0 -1
  175. package/dist/chunk-B7NHA4GE.js +0 -33
  176. package/dist/chunk-B7NHA4GE.js.map +0 -1
  177. package/dist/chunk-C3DCFPJC.cjs.map +0 -1
  178. package/dist/chunk-CEA4U6AR.js.map +0 -1
  179. package/dist/chunk-DURKKV2E.js.map +0 -1
  180. package/dist/chunk-DUVGFEGU.js.map +0 -1
  181. package/dist/chunk-FAMHC5MQ.cjs.map +0 -1
  182. package/dist/chunk-GKL5KEO4.js.map +0 -1
  183. package/dist/chunk-NEIGOAE6.cjs.map +0 -1
  184. package/dist/chunk-ORVF255B.cjs +0 -55
  185. package/dist/chunk-ORVF255B.cjs.map +0 -1
  186. package/dist/chunk-U7LTIWUS.js +0 -28
  187. package/dist/chunk-U7LTIWUS.js.map +0 -1
  188. package/dist/chunk-UW6NEKBF.cjs.map +0 -1
  189. package/dist/chunk-VAHZQJTA.cjs +0 -117
  190. package/dist/chunk-VAHZQJTA.cjs.map +0 -1
  191. package/dist/chunk-VB32IBQC.cjs.map +0 -1
  192. package/dist/chunk-XC3HIJM3.cjs.map +0 -1
  193. package/dist/chunk-XGQU7BQK.js.map +0 -1
  194. package/dist/chunk-ZCBOREOG.js.map +0 -1
  195. package/dist/{company_service_latest-C7Moeufo.d.cts → company_service_latest-CVgoQ8Mc.d.cts} +174 -174
  196. package/dist/{company_service_latest-C7Moeufo.d.ts → company_service_latest-CVgoQ8Mc.d.ts} +174 -174
  197. package/dist/{company_service_latest-CITz7F53.d.cts → company_service_latest-oWEnaiRd.d.cts} +174 -174
  198. package/dist/{company_service_latest-CITz7F53.d.ts → company_service_latest-oWEnaiRd.d.ts} +174 -174
  199. package/dist/{shared_pickle_output_latest--XZhOUyE.d.ts → shared_pickle_output_latest-BVF7Zh2H.d.cts} +11 -11
  200. package/dist/{shared_pickle_output_latest--XZhOUyE.d.cts → shared_pickle_output_latest-BVF7Zh2H.d.ts} +11 -11
  201. package/dist/{shared_pickle_output_latest-DKOmTyYk.d.cts → shared_pickle_output_latest-BjRRmT8R.d.cts} +11 -11
  202. package/dist/{shared_pickle_output_latest-DKOmTyYk.d.ts → shared_pickle_output_latest-BjRRmT8R.d.ts} +11 -11
@@ -1,5 +1,5 @@
1
- import { useMapBounds, useZoomLevel, useClusters } from './chunk-FSMBDLNU.js';
2
1
  import { MapContent } from './chunk-KM5XDOAL.js';
2
+ import { useMapBounds, useZoomLevel, useClusters } from './chunk-FSMBDLNU.js';
3
3
  import { getCenterForCoordinates, getZoomForCoordinates } from './chunk-5H35ZVLR.js';
4
4
  import { DEFAULT_ZOOM, DEFAULT_POSITION } from './chunk-LQQ244AY.js';
5
5
  import { APIProvider } from '@vis.gl/react-google-maps';
@@ -44,5 +44,5 @@ function MapComponent({
44
44
  }
45
45
 
46
46
  export { MapComponent };
47
- //# sourceMappingURL=chunk-KQLHT5UE.js.map
48
- //# sourceMappingURL=chunk-KQLHT5UE.js.map
47
+ //# sourceMappingURL=chunk-3XO3AJR4.js.map
48
+ //# sourceMappingURL=chunk-3XO3AJR4.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/components/ui/Map/MapComponent.tsx"],"names":[],"mappings":";;;;;;;AAUO,SAAS,YAA0B,CAAA;AAAA,EACxC,MAAA;AAAA,EACA,KAAA;AAAA,EACA,QAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,IAAO,GAAA;AACT,CAAmC,EAAA;AACjC,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAI,aAAa,WAAW,CAAA;AACtD,EAAA,MAAM,EAAE,SAAW,EAAA,YAAA,EAAiB,GAAA,YAAA,CAAa,QAAQ,YAAY,CAAA;AACrE,EAAA,MAAM,EAAE,QAAU,EAAA,YAAA,KAAiB,WAAY,CAAA,WAAA,EAAa,QAAQ,SAAS,CAAA;AAE7E,EAAM,MAAA,SAAA,GACJ,eAAe,WAAY,CAAA,MAAA,GAAS,IAChC,uBAAwB,CAAA,WAAW,IACnC,QAAY,IAAA,gBAAA;AAElB,EAAM,MAAA,OAAA,GACJ,WAAe,IAAA,WAAA,CAAY,MAAS,GAAA,CAAA,GAChC,sBAAsB,WAAa,EAAA,IAAI,CACvC,GAAA,QAAA,GACE,IACA,GAAA,YAAA;AAER,EACE,uBAAA,GAAA,CAAC,eAAY,MACX,EAAA,QAAA,kBAAA,GAAA;AAAA,IAAC,UAAA;AAAA,IAAA;AAAA,MACC,KAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA,QAAA;AAAA,MACA,YAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,WAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA;AAAA,GAEJ,EAAA,CAAA;AAEJ","file":"chunk-KQLHT5UE.js","sourcesContent":["'use client'\n\nimport { APIProvider } from '@vis.gl/react-google-maps'\n\nimport { DEFAULT_POSITION, DEFAULT_ZOOM } from '@/components/ui/Map/constants'\nimport { useClusters, useMapBounds, useZoomLevel } from '@/components/ui/Map/hooks'\nimport { MapContent } from '@/components/ui/Map/MapContent'\nimport type { MapComponentProps, PinData } from '@/components/ui/Map/types'\nimport { getCenterForCoordinates, getZoomForCoordinates } from '@/components/ui/Map/utils'\n\nexport function MapComponent<T = PinData>({\n apiKey,\n mapId,\n position,\n coordinates,\n onPinHover,\n onPinClick,\n focusPoint,\n radiusMiles,\n className,\n zoom = 10,\n}: Readonly<MapComponentProps<T>>) {\n const { bounds, setBounds } = useMapBounds(coordinates)\n const { zoomLevel, setZoomLevel } = useZoomLevel(zoom || DEFAULT_ZOOM)\n const { clusters, supercluster } = useClusters(coordinates, bounds, zoomLevel)\n\n const mapCenter =\n coordinates && coordinates.length > 0\n ? getCenterForCoordinates(coordinates)\n : position || DEFAULT_POSITION\n\n const mapZoom =\n coordinates && coordinates.length > 1\n ? getZoomForCoordinates(coordinates, zoom)\n : position\n ? zoom\n : DEFAULT_ZOOM\n\n return (\n <APIProvider apiKey={apiKey}>\n <MapContent\n mapId={mapId}\n mapCenter={mapCenter}\n mapZoom={mapZoom}\n position={position}\n coordinates={coordinates}\n clusters={clusters}\n supercluster={supercluster}\n onPinHover={onPinHover}\n onPinClick={onPinClick}\n focusPoint={focusPoint}\n radiusMiles={radiusMiles}\n className={className}\n setBounds={setBounds}\n setZoomLevel={setZoomLevel}\n />\n </APIProvider>\n )\n}\n"]}
1
+ {"version":3,"sources":["../src/components/ui/Map/MapComponent.tsx"],"names":[],"mappings":";;;;;;;AAUO,SAAS,YAA0B,CAAA;AAAA,EACxC,MAAA;AAAA,EACA,KAAA;AAAA,EACA,QAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,WAAA;AAAA,EACA,SAAA;AAAA,EACA,IAAO,GAAA;AACT,CAAmC,EAAA;AACjC,EAAA,MAAM,EAAE,MAAA,EAAQ,SAAU,EAAA,GAAI,aAAa,WAAW,CAAA;AACtD,EAAA,MAAM,EAAE,SAAW,EAAA,YAAA,EAAiB,GAAA,YAAA,CAAa,QAAQ,YAAY,CAAA;AACrE,EAAA,MAAM,EAAE,QAAU,EAAA,YAAA,KAAiB,WAAY,CAAA,WAAA,EAAa,QAAQ,SAAS,CAAA;AAE7E,EAAM,MAAA,SAAA,GACJ,eAAe,WAAY,CAAA,MAAA,GAAS,IAChC,uBAAwB,CAAA,WAAW,IACnC,QAAY,IAAA,gBAAA;AAElB,EAAM,MAAA,OAAA,GACJ,WAAe,IAAA,WAAA,CAAY,MAAS,GAAA,CAAA,GAChC,sBAAsB,WAAa,EAAA,IAAI,CACvC,GAAA,QAAA,GACE,IACA,GAAA,YAAA;AAER,EACE,uBAAA,GAAA,CAAC,eAAY,MACX,EAAA,QAAA,kBAAA,GAAA;AAAA,IAAC,UAAA;AAAA,IAAA;AAAA,MACC,KAAA;AAAA,MACA,SAAA;AAAA,MACA,OAAA;AAAA,MACA,QAAA;AAAA,MACA,WAAA;AAAA,MACA,QAAA;AAAA,MACA,YAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,WAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA;AAAA,GAEJ,EAAA,CAAA;AAEJ","file":"chunk-3XO3AJR4.js","sourcesContent":["'use client'\n\nimport { APIProvider } from '@vis.gl/react-google-maps'\n\nimport { DEFAULT_POSITION, DEFAULT_ZOOM } from '@/components/ui/Map/constants'\nimport { useClusters, useMapBounds, useZoomLevel } from '@/components/ui/Map/hooks'\nimport { MapContent } from '@/components/ui/Map/MapContent'\nimport type { MapComponentProps, PinData } from '@/components/ui/Map/types'\nimport { getCenterForCoordinates, getZoomForCoordinates } from '@/components/ui/Map/utils'\n\nexport function MapComponent<T = PinData>({\n apiKey,\n mapId,\n position,\n coordinates,\n onPinHover,\n onPinClick,\n focusPoint,\n radiusMiles,\n className,\n zoom = 10,\n}: Readonly<MapComponentProps<T>>) {\n const { bounds, setBounds } = useMapBounds(coordinates)\n const { zoomLevel, setZoomLevel } = useZoomLevel(zoom || DEFAULT_ZOOM)\n const { clusters, supercluster } = useClusters(coordinates, bounds, zoomLevel)\n\n const mapCenter =\n coordinates && coordinates.length > 0\n ? getCenterForCoordinates(coordinates)\n : position || DEFAULT_POSITION\n\n const mapZoom =\n coordinates && coordinates.length > 1\n ? getZoomForCoordinates(coordinates, zoom)\n : position\n ? zoom\n : DEFAULT_ZOOM\n\n return (\n <APIProvider apiKey={apiKey}>\n <MapContent\n mapId={mapId}\n mapCenter={mapCenter}\n mapZoom={mapZoom}\n position={position}\n coordinates={coordinates}\n clusters={clusters}\n supercluster={supercluster}\n onPinHover={onPinHover}\n onPinClick={onPinClick}\n focusPoint={focusPoint}\n radiusMiles={radiusMiles}\n className={className}\n setBounds={setBounds}\n setZoomLevel={setZoomLevel}\n />\n </APIProvider>\n )\n}\n"]}
@@ -6,7 +6,7 @@ var chunkLTJXX7NG_cjs = require('./chunk-LTJXX7NG.cjs');
6
6
  var chunkRKLUMDJB_cjs = require('./chunk-RKLUMDJB.cjs');
7
7
  var chunkXO6LO5CU_cjs = require('./chunk-XO6LO5CU.cjs');
8
8
  var chunkYNREEZ75_cjs = require('./chunk-YNREEZ75.cjs');
9
- var chunkC3DCFPJC_cjs = require('./chunk-C3DCFPJC.cjs');
9
+ var chunkKBAY4F7D_cjs = require('./chunk-KBAY4F7D.cjs');
10
10
  var chunkMGWZXPMF_cjs = require('./chunk-MGWZXPMF.cjs');
11
11
  var cva = require('cva');
12
12
  var lucideReact = require('lucide-react');
@@ -66,7 +66,7 @@ var Combobox = react.forwardRef((props, ref) => {
66
66
  };
67
67
  const handleSelect = (value2) => {
68
68
  const option = options.find((o) => o.value === value2);
69
- if (!option) return;
69
+ if (!option || option.disabled) return;
70
70
  isUserUpdate.current = true;
71
71
  if (multiselect) {
72
72
  setSelected((prev) => updateMultiSelect(prev, option));
@@ -120,7 +120,7 @@ var Combobox = react.forwardRef((props, ref) => {
120
120
  {
121
121
  className: chunkMGWZXPMF_cjs.cn(
122
122
  "w-full truncate leading-normal",
123
- isDefault && isEmpty && "text-grey-40"
123
+ isDefault && isEmpty && "text-grey-50"
124
124
  ),
125
125
  children: handleDisplayValue()
126
126
  }
@@ -148,15 +148,17 @@ var Combobox = react.forwardRef((props, ref) => {
148
148
  collisionPadding: 8,
149
149
  sideOffset: 4,
150
150
  align: "start",
151
- children: /* @__PURE__ */ jsxRuntime.jsxs(chunkC3DCFPJC_cjs.Command, { children: [
152
- !hideSearchBox && /* @__PURE__ */ jsxRuntime.jsx(chunkC3DCFPJC_cjs.CommandInput, { placeholder: "Search..." }),
153
- /* @__PURE__ */ jsxRuntime.jsxs(chunkC3DCFPJC_cjs.CommandList, { children: [
154
- /* @__PURE__ */ jsxRuntime.jsx(chunkC3DCFPJC_cjs.CommandEmpty, { children: "No results" }),
155
- /* @__PURE__ */ jsxRuntime.jsx(chunkC3DCFPJC_cjs.CommandGroup, { children: options.map(({ id: id2, ...option }) => /* @__PURE__ */ jsxRuntime.jsx(
156
- chunkC3DCFPJC_cjs.CommandItem,
151
+ children: /* @__PURE__ */ jsxRuntime.jsxs(chunkKBAY4F7D_cjs.Command, { children: [
152
+ !hideSearchBox && /* @__PURE__ */ jsxRuntime.jsx(chunkKBAY4F7D_cjs.CommandInput, { placeholder: "Search..." }),
153
+ /* @__PURE__ */ jsxRuntime.jsxs(chunkKBAY4F7D_cjs.CommandList, { children: [
154
+ /* @__PURE__ */ jsxRuntime.jsx(chunkKBAY4F7D_cjs.CommandEmpty, { children: "No results" }),
155
+ /* @__PURE__ */ jsxRuntime.jsx(chunkKBAY4F7D_cjs.CommandGroup, { children: options.map(({ id: id2, disabled, ...option }) => /* @__PURE__ */ jsxRuntime.jsx(
156
+ chunkKBAY4F7D_cjs.CommandItem,
157
157
  {
158
158
  value: option.title,
159
+ disabled,
159
160
  onSelect: () => handleSelect(option.value),
161
+ className: chunkMGWZXPMF_cjs.cn(disabled && "cursor-not-allowed opacity-50"),
160
162
  children: /* @__PURE__ */ jsxRuntime.jsx(
161
163
  chunkXKLOANYB_cjs.ListItem_default,
162
164
  {
@@ -191,7 +193,7 @@ var Combobox = react.forwardRef((props, ref) => {
191
193
  });
192
194
  Combobox.displayName = "Combobox";
193
195
  var triggerVariants = cva.cva(
194
- "group relative cursor-pointer text-green-100 flex flex-row items-center justify-between gap-2 border border-grey-20 focus:outline-green-80 disabled:bg-grey-5",
196
+ "group relative cursor-pointer text-grey-80 flex flex-row items-center justify-between gap-2 border border-grey-20 focus:outline-green-80 disabled:bg-grey-5",
195
197
  {
196
198
  variants: {
197
199
  variant: {
@@ -206,7 +208,8 @@ var triggerVariants = cva.cva(
206
208
  size: {
207
209
  small: ["h-8", "py-1", "px-2", "text-xs"],
208
210
  normal: ["h-9", "py-2", "px-3", "text-sm"],
209
- large: ["h-10", "py-3", "px-4", "text-base"]
211
+ large: ["h-10", "py-2", "px-4", "text-base"],
212
+ xlarge: ["h-11", "py-3", "px-4", "text-base"]
210
213
  }
211
214
  },
212
215
  defaultVariants: {
@@ -217,5 +220,5 @@ var triggerVariants = cva.cva(
217
220
  );
218
221
 
219
222
  exports.Combobox = Combobox;
220
- //# sourceMappingURL=chunk-XC3HIJM3.cjs.map
221
- //# sourceMappingURL=chunk-XC3HIJM3.cjs.map
223
+ //# sourceMappingURL=chunk-4FETL23S.cjs.map
224
+ //# sourceMappingURL=chunk-4FETL23S.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/ui/Combobox.tsx"],"names":["forwardRef","useState","useRef","icons","useEffect","value","cn","jsx","Label_default","jsxs","Popover","PopoverTrigger","Badge","ChevronDownIcon","PopoverContent","Command","CommandInput","CommandList","CommandEmpty","CommandGroup","id","CommandItem","ListItem_default","Separator","CircleX","ErrorMessage_default","cva"],"mappings":"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","file":"chunk-4FETL23S.cjs","sourcesContent":["'use client'\n\nimport { cva, type VariantProps } from 'cva'\nimport { ChevronDownIcon, CircleX, icons } from 'lucide-react'\nimport { type ComponentProps, forwardRef, useEffect, useRef, useState } from 'react'\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from '@/components/primitives/command'\nimport { Popover, PopoverContent, PopoverTrigger } from '@/components/primitives/popover'\nimport { Separator } from '@/components/primitives/separator'\nimport { Badge } from '@/components/ui/Badge'\nimport ErrorMessage from '@/components/ui/ErrorMessage'\nimport Label from '@/components/ui/Label'\nimport ListItem from '@/components/ui/ListItem'\nimport { cn } from '@/lib/utils'\n\ntype Icon = { icon?: keyof typeof icons }\ntype LabelProps = { label?: string; description?: string }\ntype Children = { children?: (props: { close: () => void }) => JSX.Element }\ntype Option = {\n id: string\n value: string\n title: string\n description?: string\n icon?: string\n disabled?: boolean\n}\ntype ClassNames = { label?: string; trigger?: string; items?: string; content?: string }\ntype Shared = { options: Option[]; classNames?: ClassNames; placeholder?: string; error?: string }\ntype MultiSelect = { multiselect: true; value?: string[]; onChange?: (v: string[]) => void }\ntype SingleSelect = { multiselect?: false; value?: string; onChange?: (v: string) => void }\ntype TriggerVariants = VariantProps<typeof triggerVariants>\ntype SelectProps = Omit<ComponentProps<'select'>, 'value' | 'onChange' | 'size' | 'children'>\ntype Props = TriggerVariants & SelectProps & Children & Shared & Icon & LabelProps\ntype MultiSelectProps = Props & MultiSelect\ntype SingleSelectProps = Props & SingleSelect\ntype ComboboxProps = MultiSelectProps | SingleSelectProps\n\nexport const Combobox = forwardRef<HTMLDivElement, ComboboxProps>((props, ref) => {\n const {\n id,\n name,\n value,\n label,\n options,\n required,\n description,\n classNames,\n multiselect,\n placeholder,\n error,\n variant = 'default',\n size,\n icon,\n className,\n onChange: handleChange,\n children: footer,\n } = props\n const [selected, setSelected] = useState<Option[]>([])\n const [open, setOpen] = useState(false)\n const isUserUpdate = useRef(false)\n const IconComponent = icon && icons[icon]\n const hideSearchBox = options?.length <= 5\n const isDefault = variant === 'default'\n const isChip = variant === 'chip'\n const isEmpty = selected.length === 0\n const showChevron = isDefault ? isEmpty : true\n const close = () => setOpen(false)\n\n useEffect(() => {\n if (!isUserUpdate.current) {\n const valueArray = multiselect ? (value ?? []) : value ? [value] : []\n setSelected(\n valueArray.map((v) => options.find((o) => o.value === v)).filter((v) => v !== undefined)\n )\n }\n }, [value, options, multiselect])\n\n useEffect(() => {\n if (isUserUpdate.current) {\n if (multiselect) {\n handleChange?.(selected.map((o) => o.value))\n } else {\n handleChange?.(selected[0]?.value ?? '')\n }\n isUserUpdate.current = false\n }\n }, [selected, multiselect, handleChange])\n\n const updateMultiSelect = (prev: Option[], option: Option) => {\n return prev.some((o) => o.value === option.value)\n ? prev.filter((v) => v !== option)\n : [...prev, option]\n }\n\n const handleSelect = (value: string) => {\n const option = options.find((o) => o.value === value)\n if (!option || option.disabled) return\n\n isUserUpdate.current = true\n if (multiselect) {\n setSelected((prev) => updateMultiSelect(prev, option))\n } else {\n setSelected([option])\n close()\n }\n }\n\n const handleClear = () => {\n isUserUpdate.current = true\n setSelected([])\n }\n\n const handleDisplayValue = () => {\n const defaultLabel = !isEmpty ? selected.map((s) => s.title).join(', ') : placeholder\n return isDefault ? defaultLabel : label\n }\n\n return (\n <div className={cn('flex flex-col gap-1', className)}>\n {isDefault && (\n <Label\n text={label}\n htmlFor={name}\n required={required}\n description={description}\n className={classNames?.label}\n />\n )}\n\n <div className=\"relative flex\">\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger\n asChild\n disabled={options.length === 0}\n data-testid={`${id ?? name}-combobox-trigger`}\n >\n <div\n ref={ref}\n className={cn(\n triggerVariants({ variant, size }),\n isDefault && !isEmpty && 'pr-10',\n classNames?.trigger\n )}\n aria-expanded={open}\n >\n {isDefault && IconComponent && <IconComponent className=\"h-4 w-4 shrink-0\" />}\n {isChip && !isEmpty && <Badge variant=\"purple\">{selected.length}</Badge>}\n\n <span\n className={cn(\n 'w-full truncate leading-normal',\n isDefault && isEmpty && 'text-grey-50'\n )}\n >\n {handleDisplayValue()}\n </span>\n\n {showChevron && (\n <ChevronDownIcon\n className=\"shrink-0 transform group-data-[state=open]:rotate-180\"\n size=\"16\"\n />\n )}\n </div>\n </PopoverTrigger>\n\n <PopoverContent\n className={cn(\n 'flex w-full max-w-xs flex-col overflow-hidden p-0',\n 'max-h-[--radix-popover-content-available-height]',\n classNames?.content\n )}\n collisionPadding={8}\n sideOffset={4}\n align=\"start\"\n >\n <Command>\n {!hideSearchBox && <CommandInput placeholder=\"Search...\" />}\n\n <CommandList>\n <CommandEmpty>No results</CommandEmpty>\n <CommandGroup>\n {options.map(({ id, disabled, ...option }) => (\n <CommandItem\n key={id}\n value={option.title}\n disabled={disabled}\n onSelect={() => handleSelect(option.value)}\n className={cn(disabled && 'cursor-not-allowed opacity-50')}\n >\n <ListItem\n className={cn(classNames?.items, 'truncate py-1')}\n isSelected={selected.some((s) => s.value === option.value)}\n hasCheckbox={multiselect}\n {...option}\n />\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n\n {!!footer && <Separator />}\n {footer && footer({ close })}\n </Command>\n </PopoverContent>\n </Popover>\n\n {isDefault && !isEmpty && (\n <button\n type=\"button\"\n className=\"absolute inset-y-0 right-1 my-auto flex h-8 w-8 cursor-pointer items-center justify-center rounded-full hover:bg-pickle-20\"\n onClick={handleClear}\n >\n <CircleX className=\"h-4 w-4 text-green-100\" />\n </button>\n )}\n </div>\n\n <ErrorMessage message={error} />\n </div>\n )\n})\nCombobox.displayName = 'Combobox'\n\nconst triggerVariants = cva(\n 'group relative cursor-pointer text-grey-80 flex flex-row items-center justify-between gap-2 border border-grey-20 focus:outline-green-80 disabled:bg-grey-5',\n {\n variants: {\n variant: {\n default: ['w-full', 'rounded-lg'],\n chip: [\n 'font-bold',\n 'rounded-3xl',\n 'data-[state=open]:bg-black',\n 'data-[state=open]:text-white',\n ],\n },\n size: {\n small: ['h-8', 'py-1', 'px-2', 'text-xs'],\n normal: ['h-9', 'py-2', 'px-3', 'text-sm'],\n large: ['h-10', 'py-2', 'px-4', 'text-base'],\n xlarge: ['h-11', 'py-3', 'px-4', 'text-base'],\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'normal',\n },\n }\n)\n"]}
@@ -0,0 +1,138 @@
1
+ import { Label_default } from './chunk-CAGLLWPR.js';
2
+ import { ErrorMessage_default } from './chunk-CWTO3NXW.js';
3
+ import { cn } from './chunk-2FGZQI42.js';
4
+ import { cva } from 'cva';
5
+ import { icons, X } from 'lucide-react';
6
+ import { forwardRef } from 'react';
7
+ import { jsxs, jsx } from 'react/jsx-runtime';
8
+
9
+ var Input = forwardRef(
10
+ ({
11
+ label,
12
+ error,
13
+ description,
14
+ theme,
15
+ size,
16
+ icon,
17
+ onClear,
18
+ value,
19
+ onChange,
20
+ classNames,
21
+ className,
22
+ ...props
23
+ }, ref) => {
24
+ const handleClear = () => {
25
+ onChange?.({ target: { value: "" } });
26
+ onClear?.();
27
+ };
28
+ const IconComponent = icon && icons[icon];
29
+ const placeholder = props.placeholder ?? (icon === "Search" ? "Search..." : "");
30
+ const hasIcon = !!icon;
31
+ const iconColor = theme === "dark" ? "text-white" : "text-grey-80";
32
+ return /* @__PURE__ */ jsxs(
33
+ "div",
34
+ {
35
+ className: cn("group flex w-full flex-col gap-1", className),
36
+ "data-testid": `input-wrapper-${props.id}`,
37
+ children: [
38
+ label && /* @__PURE__ */ jsx(
39
+ Label_default,
40
+ {
41
+ text: label,
42
+ htmlFor: props.name,
43
+ required: props.required,
44
+ description,
45
+ className: classNames?.label
46
+ }
47
+ ),
48
+ /* @__PURE__ */ jsxs("div", { className: "relative flex flex-row items-center", children: [
49
+ IconComponent && /* @__PURE__ */ jsx(
50
+ IconComponent,
51
+ {
52
+ className: `absolute left-3 h-4 w-4 ${iconColor} opacity-50 group-hover:opacity-100`
53
+ }
54
+ ),
55
+ /* @__PURE__ */ jsx(
56
+ "input",
57
+ {
58
+ className: cn(inputVariants({ theme, hasIcon, size })),
59
+ ref,
60
+ placeholder,
61
+ value,
62
+ onChange,
63
+ "data-testid": `input-element-${props.id}`,
64
+ ...props
65
+ }
66
+ ),
67
+ hasIcon && value && /* @__PURE__ */ jsx(
68
+ X,
69
+ {
70
+ className: `absolute right-3 h-4 w-4 cursor-pointer ${iconColor}`,
71
+ onClick: handleClear,
72
+ "data-testid": "clear-button"
73
+ }
74
+ )
75
+ ] }),
76
+ /* @__PURE__ */ jsx(ErrorMessage_default, { message: error })
77
+ ]
78
+ }
79
+ );
80
+ }
81
+ );
82
+ Input.displayName = "Input";
83
+ var inputVariants = cva(
84
+ [
85
+ "border",
86
+ "border-grey-20",
87
+ "placeholder:text-grey-50",
88
+ "focus-visible:ring-ring",
89
+ "inline-flex",
90
+ "w-full",
91
+ "items-center",
92
+ "justify-start",
93
+ "gap-3",
94
+ "rounded-lg",
95
+ "bg-transparent",
96
+ "shadow-sm",
97
+ "transition-colors",
98
+ "focus-visible:outline-none",
99
+ "focus-visible:ring-1",
100
+ "disabled:cursor-not-allowed",
101
+ "disabled:opacity-50",
102
+ "appearance-none",
103
+ "[&::-webkit-search-cancel-button]:appearance-none",
104
+ "[&::-webkit-search-decoration]:appearance-none",
105
+ "[&::-webkit-search-results-button]:appearance-none",
106
+ "[&::-webkit-search-results-decoration]:appearance-none",
107
+ "[&::-ms-clear]:display-none",
108
+ "[&::-ms-reveal]:display-none"
109
+ ],
110
+ {
111
+ variants: {
112
+ theme: {
113
+ light: "text-grey-80",
114
+ dark: "text-white"
115
+ },
116
+ size: {
117
+ small: "h-8 pl-4 pr-3 py-1 text-xs",
118
+ normal: "h-9 pl-4 pr-3 py-2 text-sm",
119
+ large: "h-10 pl-4 pr-3 py-2 text-base",
120
+ xlarge: "h-11 pl-4 pr-3 py-3 text-base"
121
+ },
122
+ hasIcon: {
123
+ false: "pl-3",
124
+ true: "pl-8"
125
+ }
126
+ },
127
+ defaultVariants: {
128
+ theme: "light",
129
+ size: "normal",
130
+ hasIcon: false
131
+ }
132
+ }
133
+ );
134
+ var Input_default = Input;
135
+
136
+ export { Input_default };
137
+ //# sourceMappingURL=chunk-5GODYRZA.js.map
138
+ //# sourceMappingURL=chunk-5GODYRZA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/ui/Input.tsx"],"names":[],"mappings":"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","file":"chunk-5GODYRZA.js","sourcesContent":["import { cva, type VariantProps } from 'cva'\nimport { icons, X } from 'lucide-react'\nimport { type ChangeEvent, forwardRef, type InputHTMLAttributes } from 'react'\n\nimport ErrorMessage from '@/components/ui/ErrorMessage'\nimport Label from '@/components/ui/Label'\nimport { cn } from '@/lib/utils'\n\ninterface Props\n extends Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>,\n VariantProps<typeof inputVariants> {\n label?: string\n error?: string\n icon?: keyof typeof icons\n description?: string\n classNames?: { label?: string }\n onClear?: () => void\n}\n\n/**\n * A reusable input component that supports icons, labels, error messages, and clearing functionality.\n *\n * @example\n * // Basic usage\n * <Input\n * id=\"email\"\n * name=\"email\"\n * placeholder=\"Enter your email\"\n * />\n *\n * @example\n * // With label and error\n * <Input\n * id=\"username\"\n * label=\"Username\"\n * error=\"Username is required\"\n * required\n * />\n *\n * @example\n * // Search input with clear functionality\n * <Input\n * icon=\"Search\"\n * value={searchValue}\n * onChange={handleChange}\n * onClear={() => setSearchValue('')}\n * />\n */\nconst Input = forwardRef<HTMLInputElement, Props>(\n (\n {\n label,\n error,\n description,\n theme,\n size,\n icon,\n onClear,\n value,\n onChange,\n classNames,\n className,\n ...props\n },\n ref\n ) => {\n const handleClear = () => {\n onChange?.({ target: { value: '' } } as ChangeEvent<HTMLInputElement>)\n onClear?.()\n }\n\n const IconComponent = icon && icons[icon]\n\n const placeholder = props.placeholder ?? (icon === 'Search' ? 'Search...' : '')\n const hasIcon = !!icon\n\n const iconColor = theme === 'dark' ? 'text-white' : 'text-grey-80'\n\n return (\n <div\n className={cn('group flex w-full flex-col gap-1', className)}\n data-testid={`input-wrapper-${props.id}`}\n >\n {label && (\n <Label\n text={label}\n htmlFor={props.name}\n required={props.required}\n description={description}\n className={classNames?.label}\n />\n )}\n <div className=\"relative flex flex-row items-center\">\n {IconComponent && (\n <IconComponent\n className={`absolute left-3 h-4 w-4 ${iconColor} opacity-50 group-hover:opacity-100`}\n />\n )}\n <input\n className={cn(inputVariants({ theme, hasIcon, size }))}\n ref={ref}\n placeholder={placeholder}\n value={value}\n onChange={onChange}\n data-testid={`input-element-${props.id}`}\n {...props}\n />\n {hasIcon && value && (\n <X\n className={`absolute right-3 h-4 w-4 cursor-pointer ${iconColor}`}\n onClick={handleClear}\n data-testid=\"clear-button\"\n />\n )}\n </div>\n\n <ErrorMessage message={error} />\n </div>\n )\n }\n)\nInput.displayName = 'Input'\n\nconst inputVariants = cva(\n [\n 'border',\n 'border-grey-20',\n 'placeholder:text-grey-50',\n 'focus-visible:ring-ring',\n 'inline-flex',\n 'w-full',\n 'items-center',\n 'justify-start',\n 'gap-3',\n 'rounded-lg',\n 'bg-transparent',\n 'shadow-sm',\n 'transition-colors',\n 'focus-visible:outline-none',\n 'focus-visible:ring-1',\n 'disabled:cursor-not-allowed',\n 'disabled:opacity-50',\n 'appearance-none',\n '[&::-webkit-search-cancel-button]:appearance-none',\n '[&::-webkit-search-decoration]:appearance-none',\n '[&::-webkit-search-results-button]:appearance-none',\n '[&::-webkit-search-results-decoration]:appearance-none',\n '[&::-ms-clear]:display-none',\n '[&::-ms-reveal]:display-none',\n ],\n {\n variants: {\n theme: {\n light: 'text-grey-80',\n dark: 'text-white',\n },\n size: {\n small: 'h-8 pl-4 pr-3 py-1 text-xs',\n normal: 'h-9 pl-4 pr-3 py-2 text-sm',\n large: 'h-10 pl-4 pr-3 py-2 text-base',\n xlarge: 'h-11 pl-4 pr-3 py-3 text-base',\n },\n hasIcon: {\n false: 'pl-3',\n true: 'pl-8',\n },\n },\n defaultVariants: {\n theme: 'light',\n size: 'normal',\n hasIcon: false,\n },\n }\n)\n\nexport default Input\n"]}
@@ -1,5 +1,5 @@
1
- import { jobPostSchema, ShiftEnum, PublishStatusEnum, JobFunctionEnum, EmploymentTypeEnum, EmploymentLevelEnum, ClinicalSpecialtyEnum, ClinicalSettingEnum, ClinicalLicenseEnum, BestFitEnum } from './chunk-47H3M7TP.js';
2
1
  import { sanityReferenceSchema } from './chunk-W6BMYVY5.js';
2
+ import { jobPostSchema, ShiftEnum, PublishStatusEnum, JobFunctionEnum, EmploymentTypeEnum, EmploymentLevelEnum, ClinicalSpecialtyEnum, ClinicalSettingEnum, ClinicalLicenseEnum, BestFitEnum } from './chunk-47H3M7TP.js';
3
3
  import { companySchema } from './chunk-FOJTLQJO.js';
4
4
  import { quantitativeValueSchema, postalAddressSchema, monetaryAmountSchema, UnitTextEnum, DetailLevelEnum, CurrencyEnum } from './chunk-Z33TWZHI.js';
5
5
  import { __export } from './chunk-PZ5AY32C.js';
@@ -83,5 +83,5 @@ var jobPostSchema2 = jobPostSchema.extend({
83
83
  })).transform(({ _type, _id, _rev, _createdAt, _updatedAt, ...rest }) => rest);
84
84
 
85
85
  export { JobPostTypeEnum, MonetaryAmountTypeEnum, jobPostSchema2 as jobPostSchema, job_posting_service_sanity_exports, monetaryAmountSchema2 as monetaryAmountSchema, postalAddressSchema2 as postalAddressSchema, quantitativeValueSchema2 as quantitativeValueSchema };
86
- //# sourceMappingURL=chunk-KJ5X2ZKA.js.map
87
- //# sourceMappingURL=chunk-KJ5X2ZKA.js.map
86
+ //# sourceMappingURL=chunk-5REFGTWO.js.map
87
+ //# sourceMappingURL=chunk-5REFGTWO.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/types/latest/custom/job_posting_service_sanity.ts"],"names":["jobPostSchema","monetaryAmountSchema","postalAddressSchema","quantitativeValueSchema"],"mappings":"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","file":"chunk-KJ5X2ZKA.js","sourcesContent":["import { companySchema } from '../company_service_latest';\nimport {\n jobPostSchema as contractJobPostSchema,\n } from '../job_posting_service_latest';\n\nimport {\n monetaryAmountSchema as contractMonetaryAmountSchema,\n postalAddressSchema as contractPostalAddressSchema,\n quantitativeValueSchema as contractQuantitativeValueSchema\n} from '../shared_pickle_output_latest';\n\nimport { sanityReferenceSchema } from './custom_sanity_models';\n\nimport { z } from 'zod';\n\n// New Enums\nexport const JobPostTypeEnum = z.enum(['jobPost']);\nexport const MonetaryAmountTypeEnum = z.enum(['monetaryAmount']);\n\nexport const postalAddressSchema = contractPostalAddressSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('address')\n}).omit({ type: true })\n.strict()\n.transform(data => ({\n ...data,\n type: data._type,\n}))\n.transform(({ _type, ...rest }) => rest);\n\nexport const quantitativeValueSchema = contractQuantitativeValueSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('quantitativeValue')\n }).omit({ type: true })\n .strict()\n .transform(data => ({\n ...data,\n type: data._type,\n }))\n .transform(({ _type, ...rest }) => rest);\n\n // 4. MonetaryAmount - Extend and override\n export const monetaryAmountSchema = contractMonetaryAmountSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('monetaryAmount'),\n value: quantitativeValueSchema.optional().describe(\"The quantitative_value for a given salary\")\n }).omit({ type: true })\n .strict()\n .transform(data => ({\n ...data,\n type: data._type,\n }))\n .transform(({ _type, ...rest }) => rest);\n\n // 5. JobPost - Extend and override\n export const jobPostSchema = contractJobPostSchema.extend({\n // Override base fields with Sanity-specific fields\n _id: z.string()\n .describe(\"The NDG specific id for a job posting in form of ndg-<company_slug>-<unique-job-id>. Serves as unique identifier. Cannot be changed.\")\n .regex(/^ndg-.*-.*$/),\n _rev: z.string().optional().describe(\"Revision number\"),\n _type: z.string().describe(\"Document type used within sanity\").default('jobPost'),\n _createdAt: z.string().datetime().describe(\"Time document was created. Autoset by Sanity\"),\n _updatedAt: z.string().datetime().describe(\"Time document was created. Autoset by Sanity\"),\n\n // Override fields with new schemas\n estimatedSalary: monetaryAmountSchema.optional()\n .describe(\"Determines the estimated salary for a given job posting\"),\n jobLocation: postalAddressSchema.optional()\n .describe(\"Determines the primary physical location where the job is to be performed. For remote roles, use applicantLocationRequirements\"),\n\n // Add Sanity-specific fields\n ndgMetadata: z.record(z.any()).optional(),\n ndgID: z.string().optional(),\n hiringOrganization: z.optional(z.union([sanityReferenceSchema, companySchema])),\n raw: z.record(z.any()).optional(),\n isLoaded: z.boolean().default(false),\n isVerified: z.boolean().default(false),\n needsReview: z.boolean().default(false),\n schema_version: z.string().optional(),\n origin: z.string().optional(),\n temp: z.record(z.any()).optional(),\n applicationType: z.string().optional(),\n\n // Override clientId to use Sanity naming convention\n clientID: z.string()\n }).omit({type: true, id:true, createdAt: true, updatedAt: true, clientId:true}).transform(data => ({\n ...data,\n type: data._type,\n id: data._id,\n createdAt: data._createdAt,\n updatedAt: data._updatedAt,\n rev: data._rev\n }))\n .transform(({ _type,_id, _rev, _createdAt, _updatedAt, ...rest }) => rest);;\n\n // Exports\n export type SanityReference = z.infer<typeof sanityReferenceSchema>;\n export type PostalAddress = z.infer<typeof postalAddressSchema>;\n export type QuantitativeValue = z.infer<typeof quantitativeValueSchema>;\n export type MonetaryAmount = z.infer<typeof monetaryAmountSchema>;\n export type JobPost = z.infer<typeof jobPostSchema>;\n\n\n export {\n EmploymentTypeEnum,\n EmploymentLevelEnum,\n JobFunctionEnum,\n PublishStatusEnum,\n BestFitEnum,\n ClinicalLicenseEnum,\n ShiftEnum,\n ClinicalSettingEnum,\n ClinicalSpecialtyEnum,\n } from '../job_posting_service_latest';\n\n export {\n DetailLevelEnum,\n UnitTextEnum,\n CurrencyEnum,\n } from '../shared_pickle_output_latest';\n\n export{\n sanityReferenceSchema\n } from './custom_sanity_models';\n"]}
1
+ {"version":3,"sources":["../src/types/latest/custom/job_posting_service_sanity.ts"],"names":["jobPostSchema","monetaryAmountSchema","postalAddressSchema","quantitativeValueSchema"],"mappings":"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","file":"chunk-5REFGTWO.js","sourcesContent":["import { companySchema } from '../company_service_latest';\nimport {\n jobPostSchema as contractJobPostSchema,\n } from '../job_posting_service_latest';\n\nimport {\n monetaryAmountSchema as contractMonetaryAmountSchema,\n postalAddressSchema as contractPostalAddressSchema,\n quantitativeValueSchema as contractQuantitativeValueSchema\n} from '../shared_pickle_output_latest';\n\nimport { sanityReferenceSchema } from './custom_sanity_models';\n\nimport { z } from 'zod';\n\n// New Enums\nexport const JobPostTypeEnum = z.enum(['jobPost']);\nexport const MonetaryAmountTypeEnum = z.enum(['monetaryAmount']);\n\nexport const postalAddressSchema = contractPostalAddressSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('address')\n}).omit({ type: true })\n.strict()\n.transform(data => ({\n ...data,\n type: data._type,\n}))\n.transform(({ _type, ...rest }) => rest);\n\nexport const quantitativeValueSchema = contractQuantitativeValueSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('quantitativeValue')\n }).omit({ type: true })\n .strict()\n .transform(data => ({\n ...data,\n type: data._type,\n }))\n .transform(({ _type, ...rest }) => rest);\n\n // 4. MonetaryAmount - Extend and override\n export const monetaryAmountSchema = contractMonetaryAmountSchema.extend({\n _type: z.string().describe(\"Document type used within sanity\").default('monetaryAmount'),\n value: quantitativeValueSchema.optional().describe(\"The quantitative_value for a given salary\")\n }).omit({ type: true })\n .strict()\n .transform(data => ({\n ...data,\n type: data._type,\n }))\n .transform(({ _type, ...rest }) => rest);\n\n // 5. JobPost - Extend and override\n export const jobPostSchema = contractJobPostSchema.extend({\n // Override base fields with Sanity-specific fields\n _id: z.string()\n .describe(\"The NDG specific id for a job posting in form of ndg-<company_slug>-<unique-job-id>. Serves as unique identifier. Cannot be changed.\")\n .regex(/^ndg-.*-.*$/),\n _rev: z.string().optional().describe(\"Revision number\"),\n _type: z.string().describe(\"Document type used within sanity\").default('jobPost'),\n _createdAt: z.string().datetime().describe(\"Time document was created. Autoset by Sanity\"),\n _updatedAt: z.string().datetime().describe(\"Time document was created. Autoset by Sanity\"),\n\n // Override fields with new schemas\n estimatedSalary: monetaryAmountSchema.optional()\n .describe(\"Determines the estimated salary for a given job posting\"),\n jobLocation: postalAddressSchema.optional()\n .describe(\"Determines the primary physical location where the job is to be performed. For remote roles, use applicantLocationRequirements\"),\n\n // Add Sanity-specific fields\n ndgMetadata: z.record(z.any()).optional(),\n ndgID: z.string().optional(),\n hiringOrganization: z.optional(z.union([sanityReferenceSchema, companySchema])),\n raw: z.record(z.any()).optional(),\n isLoaded: z.boolean().default(false),\n isVerified: z.boolean().default(false),\n needsReview: z.boolean().default(false),\n schema_version: z.string().optional(),\n origin: z.string().optional(),\n temp: z.record(z.any()).optional(),\n applicationType: z.string().optional(),\n\n // Override clientId to use Sanity naming convention\n clientID: z.string()\n }).omit({type: true, id:true, createdAt: true, updatedAt: true, clientId:true}).transform(data => ({\n ...data,\n type: data._type,\n id: data._id,\n createdAt: data._createdAt,\n updatedAt: data._updatedAt,\n rev: data._rev\n }))\n .transform(({ _type,_id, _rev, _createdAt, _updatedAt, ...rest }) => rest);;\n\n // Exports\n export type SanityReference = z.infer<typeof sanityReferenceSchema>;\n export type PostalAddress = z.infer<typeof postalAddressSchema>;\n export type QuantitativeValue = z.infer<typeof quantitativeValueSchema>;\n export type MonetaryAmount = z.infer<typeof monetaryAmountSchema>;\n export type JobPost = z.infer<typeof jobPostSchema>;\n\n\n export {\n EmploymentTypeEnum,\n EmploymentLevelEnum,\n JobFunctionEnum,\n PublishStatusEnum,\n BestFitEnum,\n ClinicalLicenseEnum,\n ShiftEnum,\n ClinicalSettingEnum,\n ClinicalSpecialtyEnum,\n } from '../job_posting_service_latest';\n\n export {\n DetailLevelEnum,\n UnitTextEnum,\n CurrencyEnum,\n } from '../shared_pickle_output_latest';\n\n export{\n sanityReferenceSchema\n } from './custom_sanity_models';\n"]}
@@ -1,15 +1,22 @@
1
- import { Command, CommandInput, CommandList, CommandEmpty, CommandGroup, CommandItem } from './chunk-62OBBM7T.js';
2
- import { autocomplete } from './chunk-U3D4LL6T.js';
1
+ import { Command, CommandInput, CommandList, CommandEmpty, CommandGroup, CommandItem } from './chunk-SNHRG4TY.js';
3
2
  import { cn } from './chunk-2FGZQI42.js';
3
+ import { autocomplete } from './chunk-U3D4LL6T.js';
4
4
  import { LoaderCircle, CircleX } from 'lucide-react';
5
5
  import { useState, useRef, useCallback, useEffect } from 'react';
6
6
  import { jsx, jsxs } from 'react/jsx-runtime';
7
7
 
8
+ var sizeClasses = {
9
+ small: "h-8 text-xs",
10
+ normal: "h-9 text-sm",
11
+ large: "h-10 text-base",
12
+ xlarge: "h-11 text-base"
13
+ };
8
14
  function PlacesQueryInput({
9
15
  apiKey,
10
16
  selected,
11
17
  onSelect,
12
- className
18
+ className,
19
+ size = "normal"
13
20
  }) {
14
21
  const [predictions, setPredictions] = useState(null);
15
22
  const [input, setInput] = useState(selected?.description ?? "");
@@ -73,7 +80,7 @@ function PlacesQueryInput({
73
80
  placeholder: "Type an address to search...",
74
81
  value: input,
75
82
  onValueChange: handleInputChange,
76
- className: "truncate pr-8"
83
+ className: cn("truncate pr-8", sizeClasses[size])
77
84
  }
78
85
  ),
79
86
  isLoadingPredictions && /* @__PURE__ */ jsx(LoaderCircle, { className: "absolute inset-y-0 right-2 my-auto flex h-8 w-8 animate-spin items-center justify-center rounded-full text-green-100" }),
@@ -113,5 +120,5 @@ function PlacesQueryInput({
113
120
  var PlacesQueryInput_default = PlacesQueryInput;
114
121
 
115
122
  export { PlacesQueryInput_default };
116
- //# sourceMappingURL=chunk-CEA4U6AR.js.map
117
- //# sourceMappingURL=chunk-CEA4U6AR.js.map
123
+ //# sourceMappingURL=chunk-62HL22CD.js.map
124
+ //# sourceMappingURL=chunk-62HL22CD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/ui/PlacesQueryInput.tsx"],"names":[],"mappings":"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","file":"chunk-62HL22CD.js","sourcesContent":["'use client'\n\nimport { type PlaceAutocompleteResult } from '@googlemaps/google-maps-services-js'\nimport { CircleX, LoaderCircle } from 'lucide-react'\nimport { useCallback, useEffect, useRef, useState } from 'react'\n\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from '@/components/primitives/command'\nimport { autocomplete } from '@/lib/google'\nimport { cn } from '@/lib/utils'\n\n/**\n * The idea is of this type is to have a more specific type for the Place object,\n * without the repos that use it having to import the PlaceAutocompleteResult type.\n * 'place_id' can be used to query the Google Places API directly for more information about the place.\n */\nexport type Place = Pick<PlaceAutocompleteResult, 'description' | 'place_id'>\n\ntype Size = 'small' | 'normal' | 'large' | 'xlarge'\n\ninterface PlacesQueryInputProps {\n apiKey: string\n selected?: Place\n onSelect: (place?: Place) => void\n className?: string\n size?: Size\n}\n\nconst sizeClasses: Record<Size, string> = {\n small: 'h-8 text-xs',\n normal: 'h-9 text-sm',\n large: 'h-10 text-base',\n xlarge: 'h-11 text-base',\n}\n\nfunction PlacesQueryInput({\n apiKey,\n selected,\n onSelect,\n className,\n size = 'normal',\n}: Readonly<PlacesQueryInputProps>) {\n const [predictions, setPredictions] = useState<PlaceAutocompleteResult[] | null>(null)\n const [input, setInput] = useState(selected?.description ?? '')\n const [isLoadingPredictions, setIsLoadingPredictions] = useState(false)\n const [shouldOpenUpward, setShouldOpenUpward] = useState(false)\n const timeoutRef = useRef<NodeJS.Timeout | null>(null)\n const inputRef = useRef<HTMLDivElement | null>(null)\n\n const debouncedAutocomplete = useCallback((value: string) => {\n if (timeoutRef.current) {\n clearTimeout(timeoutRef.current)\n }\n timeoutRef.current = setTimeout(async () => {\n try {\n if (value.length > 2) {\n setIsLoadingPredictions(true)\n const fetchedPredictions = await autocomplete(value, apiKey)\n setIsLoadingPredictions(false)\n setPredictions(fetchedPredictions ?? [])\n } else {\n setPredictions(null)\n }\n } catch (error) {\n setIsLoadingPredictions(false)\n setPredictions([])\n console.error('Autocomplete error:', error)\n }\n }, 300)\n }, [])\n\n const handleInputChange = (value: string) => {\n setInput(value)\n debouncedAutocomplete(value)\n }\n\n const handleSelect = (prediction: PlaceAutocompleteResult) => {\n onSelect(prediction)\n setPredictions(null)\n setInput(prediction.description)\n }\n\n const handleClear = () => {\n onSelect()\n setPredictions(null)\n setInput('')\n }\n\n /** Close the dropdown when the input loses focus, with the timeout to allow the user to click on a prediction.\n * */\n const handleBlur = () => setTimeout(() => setPredictions(null), 200)\n\n useEffect(() => {\n const checkDropdownPosition = () => {\n if (inputRef.current) {\n const rect = inputRef.current.getBoundingClientRect()\n const windowHeight = window.innerHeight\n setShouldOpenUpward(rect.bottom + 200 > windowHeight)\n }\n }\n\n checkDropdownPosition()\n window.addEventListener('resize', checkDropdownPosition)\n return () => window.removeEventListener('resize', checkDropdownPosition)\n }, [])\n\n return (\n <div className={cn('relative w-full', className)} ref={inputRef} onBlur={handleBlur}>\n <Command>\n <div className=\"relative w-full\">\n <CommandInput\n placeholder=\"Type an address to search...\"\n value={input}\n onValueChange={handleInputChange}\n className={cn('truncate pr-8', sizeClasses[size])}\n />\n {isLoadingPredictions && (\n <LoaderCircle className=\"absolute inset-y-0 right-2 my-auto flex h-8 w-8 animate-spin items-center justify-center rounded-full text-green-100\" />\n )}\n {input && (\n <button\n type=\"button\"\n className=\"absolute inset-y-0 right-2 my-auto flex h-8 w-8 cursor-pointer items-center justify-center rounded-full hover:bg-pickle-20\"\n onClick={handleClear}\n >\n <CircleX className=\"h-4 w-4 text-green-100\" />\n </button>\n )}\n </div>\n {predictions && (\n <CommandList\n className={cn(\n 'absolute z-50 w-full rounded-md border bg-white shadow-lg',\n shouldOpenUpward ? 'bottom-full' : 'top-full'\n )}\n >\n <CommandEmpty>No results</CommandEmpty>\n <CommandGroup>\n {predictions.map((prediction) => (\n <CommandItem\n key={prediction.place_id}\n onSelect={() => handleSelect(prediction)}\n className=\"truncate\"\n >\n {prediction.description}\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n )}\n </Command>\n </div>\n )\n}\n\nexport default PlacesQueryInput\n"]}
@@ -0,0 +1,140 @@
1
+ 'use strict';
2
+
3
+ var chunkXWQI5MC3_cjs = require('./chunk-XWQI5MC3.cjs');
4
+ var chunkLTJXX7NG_cjs = require('./chunk-LTJXX7NG.cjs');
5
+ var chunkMGWZXPMF_cjs = require('./chunk-MGWZXPMF.cjs');
6
+ var cva = require('cva');
7
+ var lucideReact = require('lucide-react');
8
+ var react = require('react');
9
+ var jsxRuntime = require('react/jsx-runtime');
10
+
11
+ var Input = react.forwardRef(
12
+ ({
13
+ label,
14
+ error,
15
+ description,
16
+ theme,
17
+ size,
18
+ icon,
19
+ onClear,
20
+ value,
21
+ onChange,
22
+ classNames,
23
+ className,
24
+ ...props
25
+ }, ref) => {
26
+ const handleClear = () => {
27
+ onChange?.({ target: { value: "" } });
28
+ onClear?.();
29
+ };
30
+ const IconComponent = icon && lucideReact.icons[icon];
31
+ const placeholder = props.placeholder ?? (icon === "Search" ? "Search..." : "");
32
+ const hasIcon = !!icon;
33
+ const iconColor = theme === "dark" ? "text-white" : "text-grey-80";
34
+ return /* @__PURE__ */ jsxRuntime.jsxs(
35
+ "div",
36
+ {
37
+ className: chunkMGWZXPMF_cjs.cn("group flex w-full flex-col gap-1", className),
38
+ "data-testid": `input-wrapper-${props.id}`,
39
+ children: [
40
+ label && /* @__PURE__ */ jsxRuntime.jsx(
41
+ chunkXWQI5MC3_cjs.Label_default,
42
+ {
43
+ text: label,
44
+ htmlFor: props.name,
45
+ required: props.required,
46
+ description,
47
+ className: classNames?.label
48
+ }
49
+ ),
50
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "relative flex flex-row items-center", children: [
51
+ IconComponent && /* @__PURE__ */ jsxRuntime.jsx(
52
+ IconComponent,
53
+ {
54
+ className: `absolute left-3 h-4 w-4 ${iconColor} opacity-50 group-hover:opacity-100`
55
+ }
56
+ ),
57
+ /* @__PURE__ */ jsxRuntime.jsx(
58
+ "input",
59
+ {
60
+ className: chunkMGWZXPMF_cjs.cn(inputVariants({ theme, hasIcon, size })),
61
+ ref,
62
+ placeholder,
63
+ value,
64
+ onChange,
65
+ "data-testid": `input-element-${props.id}`,
66
+ ...props
67
+ }
68
+ ),
69
+ hasIcon && value && /* @__PURE__ */ jsxRuntime.jsx(
70
+ lucideReact.X,
71
+ {
72
+ className: `absolute right-3 h-4 w-4 cursor-pointer ${iconColor}`,
73
+ onClick: handleClear,
74
+ "data-testid": "clear-button"
75
+ }
76
+ )
77
+ ] }),
78
+ /* @__PURE__ */ jsxRuntime.jsx(chunkLTJXX7NG_cjs.ErrorMessage_default, { message: error })
79
+ ]
80
+ }
81
+ );
82
+ }
83
+ );
84
+ Input.displayName = "Input";
85
+ var inputVariants = cva.cva(
86
+ [
87
+ "border",
88
+ "border-grey-20",
89
+ "placeholder:text-grey-50",
90
+ "focus-visible:ring-ring",
91
+ "inline-flex",
92
+ "w-full",
93
+ "items-center",
94
+ "justify-start",
95
+ "gap-3",
96
+ "rounded-lg",
97
+ "bg-transparent",
98
+ "shadow-sm",
99
+ "transition-colors",
100
+ "focus-visible:outline-none",
101
+ "focus-visible:ring-1",
102
+ "disabled:cursor-not-allowed",
103
+ "disabled:opacity-50",
104
+ "appearance-none",
105
+ "[&::-webkit-search-cancel-button]:appearance-none",
106
+ "[&::-webkit-search-decoration]:appearance-none",
107
+ "[&::-webkit-search-results-button]:appearance-none",
108
+ "[&::-webkit-search-results-decoration]:appearance-none",
109
+ "[&::-ms-clear]:display-none",
110
+ "[&::-ms-reveal]:display-none"
111
+ ],
112
+ {
113
+ variants: {
114
+ theme: {
115
+ light: "text-grey-80",
116
+ dark: "text-white"
117
+ },
118
+ size: {
119
+ small: "h-8 pl-4 pr-3 py-1 text-xs",
120
+ normal: "h-9 pl-4 pr-3 py-2 text-sm",
121
+ large: "h-10 pl-4 pr-3 py-2 text-base",
122
+ xlarge: "h-11 pl-4 pr-3 py-3 text-base"
123
+ },
124
+ hasIcon: {
125
+ false: "pl-3",
126
+ true: "pl-8"
127
+ }
128
+ },
129
+ defaultVariants: {
130
+ theme: "light",
131
+ size: "normal",
132
+ hasIcon: false
133
+ }
134
+ }
135
+ );
136
+ var Input_default = Input;
137
+
138
+ exports.Input_default = Input_default;
139
+ //# sourceMappingURL=chunk-6KGXXX6X.cjs.map
140
+ //# sourceMappingURL=chunk-6KGXXX6X.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/ui/Input.tsx"],"names":["forwardRef","icons","jsxs","cn","jsx","Label_default","X","ErrorMessage_default","cva"],"mappings":"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","file":"chunk-6KGXXX6X.cjs","sourcesContent":["import { cva, type VariantProps } from 'cva'\nimport { icons, X } from 'lucide-react'\nimport { type ChangeEvent, forwardRef, type InputHTMLAttributes } from 'react'\n\nimport ErrorMessage from '@/components/ui/ErrorMessage'\nimport Label from '@/components/ui/Label'\nimport { cn } from '@/lib/utils'\n\ninterface Props\n extends Omit<InputHTMLAttributes<HTMLInputElement>, 'size'>,\n VariantProps<typeof inputVariants> {\n label?: string\n error?: string\n icon?: keyof typeof icons\n description?: string\n classNames?: { label?: string }\n onClear?: () => void\n}\n\n/**\n * A reusable input component that supports icons, labels, error messages, and clearing functionality.\n *\n * @example\n * // Basic usage\n * <Input\n * id=\"email\"\n * name=\"email\"\n * placeholder=\"Enter your email\"\n * />\n *\n * @example\n * // With label and error\n * <Input\n * id=\"username\"\n * label=\"Username\"\n * error=\"Username is required\"\n * required\n * />\n *\n * @example\n * // Search input with clear functionality\n * <Input\n * icon=\"Search\"\n * value={searchValue}\n * onChange={handleChange}\n * onClear={() => setSearchValue('')}\n * />\n */\nconst Input = forwardRef<HTMLInputElement, Props>(\n (\n {\n label,\n error,\n description,\n theme,\n size,\n icon,\n onClear,\n value,\n onChange,\n classNames,\n className,\n ...props\n },\n ref\n ) => {\n const handleClear = () => {\n onChange?.({ target: { value: '' } } as ChangeEvent<HTMLInputElement>)\n onClear?.()\n }\n\n const IconComponent = icon && icons[icon]\n\n const placeholder = props.placeholder ?? (icon === 'Search' ? 'Search...' : '')\n const hasIcon = !!icon\n\n const iconColor = theme === 'dark' ? 'text-white' : 'text-grey-80'\n\n return (\n <div\n className={cn('group flex w-full flex-col gap-1', className)}\n data-testid={`input-wrapper-${props.id}`}\n >\n {label && (\n <Label\n text={label}\n htmlFor={props.name}\n required={props.required}\n description={description}\n className={classNames?.label}\n />\n )}\n <div className=\"relative flex flex-row items-center\">\n {IconComponent && (\n <IconComponent\n className={`absolute left-3 h-4 w-4 ${iconColor} opacity-50 group-hover:opacity-100`}\n />\n )}\n <input\n className={cn(inputVariants({ theme, hasIcon, size }))}\n ref={ref}\n placeholder={placeholder}\n value={value}\n onChange={onChange}\n data-testid={`input-element-${props.id}`}\n {...props}\n />\n {hasIcon && value && (\n <X\n className={`absolute right-3 h-4 w-4 cursor-pointer ${iconColor}`}\n onClick={handleClear}\n data-testid=\"clear-button\"\n />\n )}\n </div>\n\n <ErrorMessage message={error} />\n </div>\n )\n }\n)\nInput.displayName = 'Input'\n\nconst inputVariants = cva(\n [\n 'border',\n 'border-grey-20',\n 'placeholder:text-grey-50',\n 'focus-visible:ring-ring',\n 'inline-flex',\n 'w-full',\n 'items-center',\n 'justify-start',\n 'gap-3',\n 'rounded-lg',\n 'bg-transparent',\n 'shadow-sm',\n 'transition-colors',\n 'focus-visible:outline-none',\n 'focus-visible:ring-1',\n 'disabled:cursor-not-allowed',\n 'disabled:opacity-50',\n 'appearance-none',\n '[&::-webkit-search-cancel-button]:appearance-none',\n '[&::-webkit-search-decoration]:appearance-none',\n '[&::-webkit-search-results-button]:appearance-none',\n '[&::-webkit-search-results-decoration]:appearance-none',\n '[&::-ms-clear]:display-none',\n '[&::-ms-reveal]:display-none',\n ],\n {\n variants: {\n theme: {\n light: 'text-grey-80',\n dark: 'text-white',\n },\n size: {\n small: 'h-8 pl-4 pr-3 py-1 text-xs',\n normal: 'h-9 pl-4 pr-3 py-2 text-sm',\n large: 'h-10 pl-4 pr-3 py-2 text-base',\n xlarge: 'h-11 pl-4 pr-3 py-3 text-base',\n },\n hasIcon: {\n false: 'pl-3',\n true: 'pl-8',\n },\n },\n defaultVariants: {\n theme: 'light',\n size: 'normal',\n hasIcon: false,\n },\n }\n)\n\nexport default Input\n"]}
@@ -1,8 +1,8 @@
1
+ import { Avatar } from './chunk-2TEFWPFS.js';
1
2
  import { Chip_default } from './chunk-LQ4DG6ST.js';
2
3
  import { BackButton } from './chunk-IJQTUD3D.js';
3
- import { Avatar } from './chunk-2TEFWPFS.js';
4
- import { iconMap } from './chunk-PONUWUJ7.js';
5
4
  import { cn } from './chunk-2FGZQI42.js';
5
+ import { iconMap } from './chunk-PONUWUJ7.js';
6
6
  import { Dot } from 'lucide-react';
7
7
  import Image from 'next/image';
8
8
  import { jsxs, jsx } from 'react/jsx-runtime';
@@ -150,5 +150,5 @@ function JobHeader({
150
150
  }
151
151
 
152
152
  export { JobHeader };
153
- //# sourceMappingURL=chunk-WOD47B4V.js.map
154
- //# sourceMappingURL=chunk-WOD47B4V.js.map
153
+ //# sourceMappingURL=chunk-6Z6T5WWS.js.map
154
+ //# sourceMappingURL=chunk-6Z6T5WWS.js.map