@duffel/components 3.11.0-canary.3 → 3.12.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 (247) hide show
  1. package/README.md +6 -3
  2. package/package.json +6 -3
  3. package/components/DuffelAncillaries/Card.d.ts +0 -14
  4. package/components/DuffelAncillaries/Counter.d.ts +0 -10
  5. package/components/DuffelAncillaries/DuffelAncillaries.d.ts +0 -3
  6. package/components/DuffelAncillaries/DuffelAncillariesCustomElement.d.ts +0 -12
  7. package/components/DuffelAncillaries/bags/BaggageSelectionCard.d.ts +0 -12
  8. package/components/DuffelAncillaries/bags/BaggageSelectionController.d.ts +0 -14
  9. package/components/DuffelAncillaries/bags/BaggageSelectionModal.d.ts +0 -12
  10. package/components/DuffelAncillaries/bags/BaggageSelectionModalBody.d.ts +0 -12
  11. package/components/DuffelAncillaries/bags/BaggageSelectionModalBodyPassenger.d.ts +0 -14
  12. package/components/DuffelAncillaries/bags/BaggageSelectionModalFooter.d.ts +0 -15
  13. package/components/DuffelAncillaries/bags/BaggageSelectionModalHeader.d.ts +0 -10
  14. package/components/DuffelAncillaries/bags/IncludedBaggageBanner.d.ts +0 -8
  15. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionCard.d.ts +0 -11
  16. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModal.d.ts +0 -12
  17. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalBody.d.ts +0 -8
  18. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalBodyListItem.d.ts +0 -4
  19. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalFooter.d.ts +0 -12
  20. package/components/DuffelAncillaries/cancel_for_any_reason/CfarSelectionModalHeader.d.ts +0 -2
  21. package/components/DuffelAncillaries/seats/Amenity.d.ts +0 -7
  22. package/components/DuffelAncillaries/seats/DeckSelect.d.ts +0 -15
  23. package/components/DuffelAncillaries/seats/Element.d.ts +0 -16
  24. package/components/DuffelAncillaries/seats/EmptyElement.d.ts +0 -2
  25. package/components/DuffelAncillaries/seats/ExitElement.d.ts +0 -6
  26. package/components/DuffelAncillaries/seats/Legend.d.ts +0 -13
  27. package/components/DuffelAncillaries/seats/Row.d.ts +0 -14
  28. package/components/DuffelAncillaries/seats/RowSection.d.ts +0 -18
  29. package/components/DuffelAncillaries/seats/SeatElement.d.ts +0 -14
  30. package/components/DuffelAncillaries/seats/SeatInfo.d.ts +0 -8
  31. package/components/DuffelAncillaries/seats/SeatMap.d.ts +0 -13
  32. package/components/DuffelAncillaries/seats/SeatMapUnavailable.d.ts +0 -2
  33. package/components/DuffelAncillaries/seats/SeatSelectionCard.d.ts +0 -13
  34. package/components/DuffelAncillaries/seats/SeatSelectionModal.d.ts +0 -15
  35. package/components/DuffelAncillaries/seats/SeatSelectionModalBody.d.ts +0 -4
  36. package/components/DuffelAncillaries/seats/SeatSelectionModalFooter.d.ts +0 -16
  37. package/components/DuffelAncillaries/seats/SeatSelectionModalHeader.d.ts +0 -11
  38. package/components/DuffelAncillaries/seats/SeatUnavailable.d.ts +0 -6
  39. package/components/DuffelCardForm/DuffelCardForm.d.ts +0 -4
  40. package/components/DuffelCardForm/DuffelCardFormCustomElement.d.ts +0 -34
  41. package/components/DuffelCardForm/lib/getIFrameEventListener.d.ts +0 -7
  42. package/components/DuffelCardForm/lib/getIFrameOriginForEnvironment.d.ts +0 -2
  43. package/components/DuffelCardForm/lib/getIframeURL.d.ts +0 -2
  44. package/components/DuffelCardForm/lib/getPathnameForIntent.d.ts +0 -2
  45. package/components/DuffelCardForm/lib/getTokenFromClientKey.d.ts +0 -1
  46. package/components/DuffelCardForm/lib/postMessageToCreateCardForTemporaryUse.d.ts +0 -1
  47. package/components/DuffelCardForm/lib/postMessageToSaveCard.d.ts +0 -1
  48. package/components/DuffelCardForm/lib/postMessageWithStyles.d.ts +0 -2
  49. package/components/DuffelCardForm/lib/types.d.ts +0 -154
  50. package/components/DuffelCardForm/lib/useDuffelCardFormActions.d.ts +0 -24
  51. package/components/DuffelNGSView/AirlineSelector.d.ts +0 -10
  52. package/components/DuffelNGSView/DuffelNGSView.d.ts +0 -14
  53. package/components/DuffelNGSView/FilterControl.d.ts +0 -20
  54. package/components/DuffelNGSView/FilterControls.d.ts +0 -13
  55. package/components/DuffelNGSView/NGSShelfInfoCard.d.ts +0 -7
  56. package/components/DuffelNGSView/NGSSliceFareCard.d.ts +0 -10
  57. package/components/DuffelNGSView/NGSTable.d.ts +0 -15
  58. package/components/DuffelNGSView/SliceSummary.d.ts +0 -7
  59. package/components/DuffelNGSView/SortingControl.d.ts +0 -23
  60. package/components/DuffelNGSView/StopsSelector.d.ts +0 -8
  61. package/components/DuffelNGSView/TimeRangeSelector.d.ts +0 -8
  62. package/components/DuffelNGSView/lib/deduplicate-mapped-offers-by-fare-brand.d.ts +0 -7
  63. package/components/DuffelNGSView/lib/does-slice-have-mixed-cabins.d.ts +0 -4
  64. package/components/DuffelNGSView/lib/filter-results.d.ts +0 -14
  65. package/components/DuffelNGSView/lib/get-initial-filter-values.d.ts +0 -4
  66. package/components/DuffelNGSView/lib/get-max-baggages-for-offer-slice.d.ts +0 -8
  67. package/components/DuffelNGSView/lib/getAirlines.d.ts +0 -4
  68. package/components/DuffelNGSView/lib/group-offers-for-ngs-view.d.ts +0 -6
  69. package/components/DuffelNGSView/lib/index.d.ts +0 -14
  70. package/components/DuffelNGSView/lib/sort-ngs-rows-by-duration.d.ts +0 -5
  71. package/components/DuffelNGSView/lib/sort-ngs-rows-by-recommended.d.ts +0 -2
  72. package/components/DuffelNGSView/lib/sort-ngs-rows-by-shelf-price.d.ts +0 -6
  73. package/components/DuffelNGSView/lib/useFilters.d.ts +0 -28
  74. package/components/DuffelPayments/DuffelPayments.d.ts +0 -11
  75. package/components/DuffelPayments/DuffelPaymentsCustomElement.d.ts +0 -13
  76. package/components/MapboxPlacesLookup/MapboxPlacesLookup.d.ts +0 -12
  77. package/components/MapboxPlacesLookup/MapboxPlacesLookupCustomElement.d.ts +0 -13
  78. package/components/MapboxPlacesLookup/lib/getPlacesFromMapboxClient.d.ts +0 -7
  79. package/components/OfferSlice/OfferSlice.d.ts +0 -7
  80. package/components/OfferSlice/OfferSliceConditions.d.ts +0 -7
  81. package/components/OfferSlice/OfferSliceDetailItem.d.ts +0 -7
  82. package/components/OfferSlice/OfferSliceDetailLayoverItem.d.ts +0 -8
  83. package/components/OfferSlice/OfferSliceDetailTravelItem.d.ts +0 -9
  84. package/components/OfferSlice/lib/getHighlightStyles.d.ts +0 -7
  85. package/components/OfferSliceModal/OfferSliceModal.d.ts +0 -7
  86. package/components/PlacesLookup/PlacesLookup.d.ts +0 -20
  87. package/components/Stays/StaysAmenities.d.ts +0 -9
  88. package/components/Stays/StaysAmenitiesCustomElement.d.ts +0 -12
  89. package/components/Stays/StaysRating.d.ts +0 -6
  90. package/components/Stays/StaysRatingCustomElement.d.ts +0 -14
  91. package/components/Stays/StaysRoomRateCard.d.ts +0 -13
  92. package/components/Stays/StaysRoomRateCardCustomElement.d.ts +0 -14
  93. package/components/Stays/StaysSummary.d.ts +0 -12
  94. package/components/Stays/StaysSummaryCustomElement.d.ts +0 -12
  95. package/components/Stays/lib/getRateLabel.d.ts +0 -2
  96. package/components/Stays/lib/types.d.ts +0 -29
  97. package/components/shared/AirlineLogo.d.ts +0 -8
  98. package/components/shared/AnimatedLoaderEllipsis.d.ts +0 -2
  99. package/components/shared/Button.d.ts +0 -23
  100. package/components/shared/ErrorBoundary.d.ts +0 -13
  101. package/components/shared/FetchOfferErrorState.d.ts +0 -5
  102. package/components/shared/HSpace.d.ts +0 -28
  103. package/components/shared/Icon.d.ts +0 -97
  104. package/components/shared/IconButton.d.ts +0 -16
  105. package/components/shared/Modal.d.ts +0 -14
  106. package/components/shared/NonIdealState.d.ts +0 -4
  107. package/components/shared/RadioButton.d.ts +0 -7
  108. package/components/shared/SliceCarriersTitle.d.ts +0 -8
  109. package/components/shared/Stamp.d.ts +0 -7
  110. package/components/shared/Tabs.d.ts +0 -16
  111. package/components/shared/VSpace.d.ts +0 -14
  112. package/components/shared/WithComponentStyles.d.ts +0 -7
  113. package/custom-elements.d.ts +0 -12
  114. package/custom-elements.js +0 -70
  115. package/custom-elements.js.map +0 -7
  116. package/fixtures/offer-requests/orq_duplicates.d.ts +0 -2
  117. package/fixtures/passengers/mock_passengers.d.ts +0 -4
  118. package/functions/createThreeDSecureSession/client.d.ts +0 -43
  119. package/functions/createThreeDSecureSession/createThreeDSecureSession.d.ts +0 -25
  120. package/functions/createThreeDSecureSession/initEvervault.d.ts +0 -1
  121. package/functions/createThreeDSecureSession/loadEvervaultScript.d.ts +0 -1
  122. package/functions/hasService.d.ts +0 -3
  123. package/functions.d.ts +0 -10
  124. package/index.d.ts +0 -18
  125. package/index.js +0 -55
  126. package/index.js.map +0 -7
  127. package/lib/captureErrorInSentry.d.ts +0 -1
  128. package/lib/colors.d.ts +0 -28
  129. package/lib/compileCreateOrderPayload.d.ts +0 -13
  130. package/lib/convertDurationToString.d.ts +0 -1
  131. package/lib/createPriceFormatters.d.ts +0 -12
  132. package/lib/fetchFromDuffelAPI.d.ts +0 -8
  133. package/lib/fetchFromFixtures.d.ts +0 -3
  134. package/lib/formatAvailableServices.d.ts +0 -12
  135. package/lib/formatDate.d.ts +0 -2
  136. package/lib/formatSeatMaps.d.ts +0 -4
  137. package/lib/getAirlinesText.d.ts +0 -2
  138. package/lib/getBaggageServiceDescription.d.ts +0 -2
  139. package/lib/getCabinsForSegmentAndDeck.d.ts +0 -3
  140. package/lib/getCarriers.d.ts +0 -6
  141. package/lib/getCurrencyForSeatMaps.d.ts +0 -10
  142. package/lib/getCurrencyForServices.d.ts +0 -11
  143. package/lib/getDateObject.d.ts +0 -10
  144. package/lib/getDateString.d.ts +0 -73
  145. package/lib/getDayDiff.d.ts +0 -5
  146. package/lib/getDurationString.d.ts +0 -1
  147. package/lib/getFareBrandName.d.ts +0 -2
  148. package/lib/getFirstSeatElementMatchingCriteria.d.ts +0 -4
  149. package/lib/getLayoverOriginDestinationKey.d.ts +0 -1
  150. package/lib/getPassengerBySegmentList.d.ts +0 -7
  151. package/lib/getPassengerInitials.d.ts +0 -1
  152. package/lib/getPassengerMapById.d.ts +0 -4
  153. package/lib/getPassengerName.d.ts +0 -2
  154. package/lib/getRowNumber.d.ts +0 -2
  155. package/lib/getSegmentDates.d.ts +0 -5
  156. package/lib/getSegmentFlightNumber.d.ts +0 -2
  157. package/lib/getSegmentList.d.ts +0 -3
  158. package/lib/getServicePriceMapById.d.ts +0 -4
  159. package/lib/getSliceDetails.d.ts +0 -3
  160. package/lib/getSymbols.d.ts +0 -2
  161. package/lib/getTimeString.d.ts +0 -1
  162. package/lib/getTotalAmountForServices.d.ts +0 -4
  163. package/lib/getTotalQuantity.d.ts +0 -2
  164. package/lib/getTravelItem.d.ts +0 -3
  165. package/lib/hasAvailableSeatService.d.ts +0 -3
  166. package/lib/hasBaggageServiceOfSameMetadataTypeAlreadyBeenSelected.d.ts +0 -4
  167. package/lib/hasHighLuminance.d.ts +0 -1
  168. package/lib/hasService.d.ts +0 -2
  169. package/lib/hasWings.d.ts +0 -2
  170. package/lib/isAmenityElement.d.ts +0 -3
  171. package/lib/isBaggageService.d.ts +0 -3
  172. package/lib/isCancelForAnyReasonService.d.ts +0 -3
  173. package/lib/isFixtureOfferId.d.ts +0 -2
  174. package/lib/isISO8601Duration.d.ts +0 -2
  175. package/lib/isPayloadComplete.d.ts +0 -3
  176. package/lib/isSeatElement.d.ts +0 -3
  177. package/lib/isValidDateString.d.ts +0 -6
  178. package/lib/logging.d.ts +0 -46
  179. package/lib/moneyStringFormatter.d.ts +0 -8
  180. package/lib/offerIsExpired.d.ts +0 -2
  181. package/lib/retrieveOffer.d.ts +0 -3
  182. package/lib/retrieveOfferFromDuffelAPI.d.ts +0 -1
  183. package/lib/retrieveSeatMaps.d.ts +0 -3
  184. package/lib/retrieveSeatMapsFromDuffelAPI.d.ts +0 -1
  185. package/lib/setBodyScrollability.d.ts +0 -1
  186. package/lib/toUTCDate.d.ts +0 -1
  187. package/lib/validateProps.d.ts +0 -7
  188. package/lib/withPlural.d.ts +0 -1
  189. package/stories/AirlineLogo.stories.d.ts +0 -3
  190. package/stories/AirlineSelector.stories.d.ts +0 -3
  191. package/stories/BaggageSelectionModalHeader.stories.d.ts +0 -6
  192. package/stories/Button.stories.d.ts +0 -15
  193. package/stories/DuffelAncillaries.stories.d.ts +0 -24
  194. package/stories/DuffelCardForm.stories.d.ts +0 -7
  195. package/stories/DuffelNGSView.stories.d.ts +0 -7
  196. package/stories/DuffelPayments.stories.d.ts +0 -7
  197. package/stories/Icon.stories.d.ts +0 -3
  198. package/stories/IconButton.stories.d.ts +0 -8
  199. package/stories/MapboxPlacesLookup.stories.d.ts +0 -5
  200. package/stories/NGSShelfInfoCard.stories.d.ts +0 -3
  201. package/stories/NGSSliceFareCard.stories.d.ts +0 -3
  202. package/stories/OfferSlice.stories.d.ts +0 -5
  203. package/stories/OfferSliceModal.stories.d.ts +0 -6
  204. package/stories/PlacesLookup.stories.d.ts +0 -3
  205. package/stories/SeatMap.stories.d.ts +0 -4
  206. package/stories/SliceCarriersTitle.stories.d.ts +0 -10
  207. package/stories/SliceSummary.stories.d.ts +0 -5
  208. package/stories/StaysAmenities.stories.d.ts +0 -10
  209. package/stories/StaysRating.stories.d.ts +0 -16
  210. package/stories/StaysRoomRateCard.stories.d.ts +0 -141
  211. package/stories/StaysSummary.stories.d.ts +0 -47
  212. package/tests/components/DuffelAncillaries.test.d.ts +0 -1
  213. package/tests/functions/createThreeDSecureSession.test.d.ts +0 -1
  214. package/tests/lib/convertDurationToString.test.d.ts +0 -1
  215. package/tests/lib/createPriceFormatters.test.d.ts +0 -1
  216. package/tests/lib/formatAvailableServices.test.d.ts +0 -1
  217. package/tests/lib/formatSeatMaps.test.d.ts +0 -1
  218. package/tests/lib/getAirlines.test.d.ts +0 -1
  219. package/tests/lib/getAirlinesText.test.d.ts +0 -1
  220. package/tests/lib/getCarriers.test.d.ts +0 -1
  221. package/tests/lib/getCurrencyForServices.test.d.ts +0 -1
  222. package/tests/lib/getDateObject.test.d.ts +0 -1
  223. package/tests/lib/getDateString.spec.d.ts +0 -1
  224. package/tests/lib/getDayDiff.test.d.ts +0 -1
  225. package/tests/lib/getDurationString.test.d.ts +0 -1
  226. package/tests/lib/getFareBrandName.test.d.ts +0 -1
  227. package/tests/lib/getLayoverOriginDestinationKey.test.d.ts +0 -1
  228. package/tests/lib/getRateLabel.spec.d.ts +0 -1
  229. package/tests/lib/getSegmentDates.d.ts +0 -1
  230. package/tests/lib/getSegmentDates.test.d.ts +0 -1
  231. package/tests/lib/getSegmentFlightNumber.test.d.ts +0 -1
  232. package/tests/lib/getSliceDetails.test.d.ts +0 -1
  233. package/tests/lib/getTimeString.test.d.ts +0 -1
  234. package/tests/lib/getTravelItem.test.d.ts +0 -1
  235. package/tests/lib/groupOffersForNGSView.test.d.ts +0 -1
  236. package/tests/lib/hasAvailableSeatService.test.d.ts +0 -1
  237. package/tests/lib/hasBaggageServiceOfSameMetadataTypeAlreadyBeenSelected.test.d.ts +0 -1
  238. package/tests/lib/isValidDateString.test.d.ts +0 -1
  239. package/tests/lib/logging.test.d.ts +0 -1
  240. package/tests/lib/moneyStringFormatter.test.d.ts +0 -1
  241. package/tests/lib/toUTCDate.test.d.ts +0 -1
  242. package/tests/lib/validateProps.test.d.ts +0 -5
  243. package/tsconfig.tsbuildinfo +0 -1
  244. package/types/CurrencyConversion.d.ts +0 -10
  245. package/types/DuffelAncillariesProps.d.ts +0 -115
  246. package/types/TravelDetails.d.ts +0 -77
  247. package/types/index.d.ts +0 -4
package/README.md CHANGED
@@ -26,7 +26,8 @@ There are 3 different ways to integrate the components into your website. This w
26
26
 
27
27
  ```jsx
28
28
  <DuffelAncillaries
29
- offer_id="fixture_off_1"
29
+ offer={offerFromYourBackend} // The offer object from your backend
30
+ seat_maps={seatMapsFromYourBackend}
30
31
  services={["bags", "seats"]}
31
32
  passengers={[...]}
32
33
  onPayloadReady={console.log}
@@ -64,7 +65,8 @@ If you are not using React but still in a node environment, you can:
64
65
 
65
66
  ```javascript
66
67
  renderDuffelAncillariesCustomElement({
67
- offer_id: "fixture_off_1",
68
+ offer: offerFromYourBackend,
69
+ seat_maps: seatMapsFromYourBackend,
68
70
  services: ["bags", "seats"],
69
71
  passengers: [...],
70
72
  });
@@ -112,7 +114,8 @@ If you are not in a node environment and can't rely on npm to install the packag
112
114
  const duffelAncillariesElement = document.querySelector("duffel-ancillaries");
113
115
 
114
116
  duffelAncillariesElement.render({
115
- offer_id: "fixture_off_1",
117
+ offer: offerFromYourBackend,
118
+ seat_maps: seatMapsFromYourBackend,
116
119
  services: ["bags", "seats"],
117
120
  passengers: [...],
118
121
  });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@duffel/components",
3
- "version": "3.11.0-canary.3",
3
+ "version": "3.12.0",
4
4
  "description": "Component library to build your travel product with Duffel.",
5
5
  "keywords": [
6
6
  "Duffel",
@@ -56,7 +56,10 @@
56
56
  "@stripe/react-stripe-js": "2.1.0",
57
57
  "@stripe/stripe-js": "1.54.2",
58
58
  "classnames": "2.3.2",
59
+ "date-fns": "^4.1.0",
60
+ "date-fns-tz": "^3.2.0",
59
61
  "duration-fns": "3.0.2",
62
+ "form-data": "4.0.4",
60
63
  "fuse.js": "6.6.2",
61
64
  "lodash": "4.17.21",
62
65
  "rc-slider": "10.6.2",
@@ -84,7 +87,7 @@
84
87
  "@testing-library/react": "14.3.1",
85
88
  "@types/jest": "29.5.14",
86
89
  "@types/lodash": "4.17.20",
87
- "@types/node": "18.19.115",
90
+ "@types/node": "18.19.130",
88
91
  "@types/prompts": "2.4.9",
89
92
  "@types/react": "18.2.33",
90
93
  "@types/react-dom": "18.2.14",
@@ -93,7 +96,7 @@
93
96
  "babel-jest": "29.7.0",
94
97
  "concurrently": "8.2.2",
95
98
  "dotenv": "16.4.5",
96
- "esbuild": "0.25.3",
99
+ "esbuild": "0.25.12",
97
100
  "esbuild-copy-static-files": "0.1.0",
98
101
  "eslint": "8.52.0",
99
102
  "eslint-config-prettier": "9.0.0",
@@ -1,14 +0,0 @@
1
- import { IconName } from "@components/shared/Icon";
2
- import * as React from "react";
3
- export interface CardProps {
4
- buttonTitle: string;
5
- title: string;
6
- icon: IconName;
7
- onClick?: (() => void) | null;
8
- children: React.ReactNode;
9
- copy: string;
10
- isLoading?: boolean;
11
- disabled?: boolean;
12
- isSelected?: boolean;
13
- }
14
- export declare const Card: React.FC<CardProps>;
@@ -1,10 +0,0 @@
1
- import * as React from "react";
2
- interface CounterProps {
3
- id: string;
4
- min: number;
5
- max: number;
6
- value: number;
7
- onChange: (value: number) => void;
8
- }
9
- export declare const Counter: React.FC<CounterProps>;
10
- export {};
@@ -1,3 +0,0 @@
1
- import * as React from "react";
2
- import { DuffelAncillariesProps } from "../../types/DuffelAncillariesProps";
3
- export declare const DuffelAncillaries: React.FC<DuffelAncillariesProps>;
@@ -1,12 +0,0 @@
1
- import { DuffelAncillariesPropsWithClientKeyAndOfferId, DuffelAncillariesPropsWithOfferIdForFixture, DuffelAncillariesPropsWithOffersAndSeatMaps, DuffelAncillariesPropWithOfferAndClientKey, OnPayloadReady } from "../../types/DuffelAncillariesProps";
2
- declare global {
3
- namespace JSX {
4
- interface IntrinsicElements {
5
- "duffel-ancillaries": React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
6
- }
7
- }
8
- }
9
- type DuffelAncillariesCustomElementRenderArguments = Omit<DuffelAncillariesPropsWithOfferIdForFixture, "onPayloadReady"> | Omit<DuffelAncillariesPropsWithClientKeyAndOfferId, "onPayloadReady"> | Omit<DuffelAncillariesPropWithOfferAndClientKey, "onPayloadReady"> | Omit<DuffelAncillariesPropsWithOffersAndSeatMaps, "onPayloadReady">;
10
- export declare function renderDuffelAncillariesCustomElement(props: DuffelAncillariesCustomElementRenderArguments): void;
11
- export declare function onDuffelAncillariesPayloadReady(onPayloadReady: OnPayloadReady): void;
12
- export {};
@@ -1,12 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrder, CreateOrderService, Offer } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithBaggageServiceInformation } from "src/types";
5
- export interface BaggageSelectionCardProps {
6
- isLoading: boolean;
7
- offer?: Offer;
8
- passengers: CreateOrder["passengers"];
9
- selectedServices: WithBaggageServiceInformation<CreateOrderService>[];
10
- setSelectedServices: (selectedServices: WithBaggageServiceInformation<CreateOrderService>[]) => void;
11
- }
12
- export declare const BaggageSelectionCard: React.FC<BaggageSelectionCardProps>;
@@ -1,14 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, OfferAvailableServiceBaggage } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithBaggageServiceInformation } from "src/types";
5
- interface BaggageSelectionControllerProps {
6
- segmentId: string;
7
- passengerId: string;
8
- availableService: OfferAvailableServiceBaggage;
9
- selectedServices: WithBaggageServiceInformation<CreateOrderService>[];
10
- quantity: number;
11
- onQuantityChanged: (quantity: number) => void;
12
- }
13
- export declare const BaggageSelectionController: React.FC<BaggageSelectionControllerProps>;
14
- export {};
@@ -1,12 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrder, CreateOrderService, Offer } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithBaggageServiceInformation } from "src/types";
5
- export interface BaggageSelectionModalProps {
6
- isOpen: boolean;
7
- offer?: Offer;
8
- passengers: CreateOrder["passengers"];
9
- selectedServices: WithBaggageServiceInformation<CreateOrderService>[];
10
- onClose: (selectedServices: WithBaggageServiceInformation<CreateOrderService>[]) => void;
11
- }
12
- export declare const BaggageSelectionModal: React.FC<BaggageSelectionModalProps>;
@@ -1,12 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import React from "react";
3
- import { CreateOrderPassenger, CreateOrderService, Offer, OfferSliceSegment } from "@duffel/api/types";
4
- import { WithBaggageServiceInformation } from "src/types";
5
- export interface BaggageSelectionModalBodyProps {
6
- offer: Offer;
7
- segment: OfferSliceSegment;
8
- passengersById: Record<CreateOrderPassenger["id"], CreateOrderPassenger>;
9
- selectedServices: WithBaggageServiceInformation<CreateOrderService>[];
10
- setSelectedServices: (selectedServices: WithBaggageServiceInformation<CreateOrderService>[]) => void;
11
- }
12
- export declare const BaggageSelectionModalBody: React.FC<BaggageSelectionModalBodyProps>;
@@ -1,14 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, OfferAvailableServiceBaggage, OfferSliceSegmentPassengerBaggage } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithBaggageServiceInformation } from "src/types";
5
- export interface BaggageSelectionModalBodyPassengerProps {
6
- segmentId: string;
7
- passengerId: string;
8
- passengerName: string;
9
- includedBaggage: OfferSliceSegmentPassengerBaggage[];
10
- passengerServicesForSegment: OfferAvailableServiceBaggage[];
11
- selectedServices: WithBaggageServiceInformation<CreateOrderService>[];
12
- setSelectedServices: (selectedServices: WithBaggageServiceInformation<CreateOrderService>[]) => void;
13
- }
14
- export declare const BaggageSelectionModalBodyPassenger: React.FC<BaggageSelectionModalBodyPassengerProps>;
@@ -1,15 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrder } from "@duffel/api/types";
3
- import { ServicePriceMapById } from "@lib/getServicePriceMapById";
4
- import React from "react";
5
- export interface BaggageSelectionModalFooterProps {
6
- currency: string;
7
- selectedServices: CreateOrder["services"];
8
- servicePrices: ServicePriceMapById;
9
- isFirstSegment: boolean;
10
- isLastSegment: boolean;
11
- onNextSegmentButtonClicked: () => void;
12
- onPreviousSegmentButtonClicked: () => void;
13
- onClose: () => void;
14
- }
15
- export declare const BaggageSelectionModalFooter: React.FC<BaggageSelectionModalFooterProps>;
@@ -1,10 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { OfferSliceSegment } from "@duffel/api/types";
3
- import React from "react";
4
- export interface BaggageSelectionModalHeaderProps {
5
- segmentCount: number;
6
- currentSegmentIndex: number;
7
- currentSegment: OfferSliceSegment;
8
- setCurrentSegmentIndex: (index: number) => void;
9
- }
10
- export declare const BaggageSelectionModalHeader: React.FC<BaggageSelectionModalHeaderProps>;
@@ -1,8 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { OfferSliceSegmentPassengerBaggage } from "@duffel/api/types";
3
- import React from "react";
4
- interface IncludedBaggageBannerProps {
5
- includedBaggage: OfferSliceSegmentPassengerBaggage[];
6
- }
7
- export declare const IncludedBaggageBanner: React.FC<IncludedBaggageBannerProps>;
8
- export {};
@@ -1,11 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, Offer } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithServiceInformation } from "src/types";
5
- export interface CfarSelectionCardProps {
6
- isLoading: boolean;
7
- offer?: Offer;
8
- selectedServices: WithServiceInformation<CreateOrderService>[];
9
- setSelectedServices: (selectedServices: WithServiceInformation<CreateOrderService>[]) => void;
10
- }
11
- export declare const CfarSelectionCard: React.FC<CfarSelectionCardProps>;
@@ -1,12 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, Offer, OfferAvailableServiceCFAR } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithServiceInformation } from "src/types";
5
- export interface CfarSelectionModalProps {
6
- isOpen: boolean;
7
- offerCurrency?: Offer["base_currency"];
8
- service?: OfferAvailableServiceCFAR;
9
- selectedServices: WithServiceInformation<CreateOrderService>[];
10
- onClose: (selectedServices: WithServiceInformation<CreateOrderService>[]) => void;
11
- }
12
- export declare const CfarSelectionModal: React.FC<CfarSelectionModalProps>;
@@ -1,8 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import React from "react";
3
- import { Offer, OfferAvailableServiceCFAR } from "@duffel/api/types";
4
- export interface CfarSelectionModalBodyProps {
5
- offerCurrency: Offer["base_currency"];
6
- service: OfferAvailableServiceCFAR;
7
- }
8
- export declare const CfarSelectionModalBody: React.FC<CfarSelectionModalBodyProps>;
@@ -1,4 +0,0 @@
1
- import React, { ReactNode } from "react";
2
- export declare const CfarSelectionModalBodyListItem: React.FC<{
3
- children: ReactNode;
4
- }>;
@@ -1,12 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, OfferAvailableServiceCFAR } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithServiceInformation } from "src/types";
5
- export interface CfarSelectionModalFooterProps {
6
- service: OfferAvailableServiceCFAR;
7
- selectedServices: WithServiceInformation<CreateOrderService>[];
8
- onAddCfarService: () => void;
9
- onRemoveCfarService: () => void;
10
- onClose: () => void;
11
- }
12
- export declare const CfarSelectionModalFooter: React.FC<CfarSelectionModalFooterProps>;
@@ -1,2 +0,0 @@
1
- import React from "react";
2
- export declare const CfarSelectionModalHeader: React.FC;
@@ -1,7 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { SeatMapCabinRowSectionElementAmenity } from "@duffel/api/types";
3
- import * as React from "react";
4
- export interface AmenityProps {
5
- type: SeatMapCabinRowSectionElementAmenity;
6
- }
7
- export declare const Amenity: React.FC<AmenityProps>;
@@ -1,15 +0,0 @@
1
- import * as React from "react";
2
- export interface DeckSelectProps {
3
- /**
4
- * The currently selected deck number
5
- */
6
- value: number;
7
- /**
8
- * What to do when the user selects a deck
9
- */
10
- setValue: (value: number) => void;
11
- }
12
- /**
13
- * The deck selection component for the seat map.
14
- */
15
- export declare const DeckSelect: React.FC<DeckSelectProps>;
@@ -1,16 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, SeatMapCabinRowSectionElement } from "@duffel/api/types";
3
- import * as React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- interface ElementProps {
6
- sectionIndex: number;
7
- elementIndex: number;
8
- element: SeatMapCabinRowSectionElement;
9
- selectedServicesMap: Record<string, WithSeatServiceInformation<CreateOrderService>>;
10
- onSeatToggled: (seatService: WithSeatServiceInformation<CreateOrderService>) => void;
11
- currentPassengerId: string;
12
- currentSegmentId: string;
13
- currentPassengerName: string;
14
- }
15
- export declare const Element: React.FC<ElementProps>;
16
- export {};
@@ -1,2 +0,0 @@
1
- import * as React from "react";
2
- export declare const EmptyElement: React.FC;
@@ -1,6 +0,0 @@
1
- import * as React from "react";
2
- interface ExitElementProps {
3
- isRight: boolean;
4
- }
5
- export declare const ExitElement: React.FC<ExitElementProps>;
6
- export {};
@@ -1,13 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { SeatMapCabinRowSectionElementAmenity } from "@duffel/api/types";
3
- import * as React from "react";
4
- export interface LegendProps {
5
- /**
6
- * The set of additional symbols to display
7
- */
8
- symbols: Set<SeatMapCabinRowSectionElementAmenity>;
9
- }
10
- /**
11
- * The legend for the seat map.
12
- */
13
- export declare const Legend: React.FC<LegendProps>;
@@ -1,14 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, SeatMapCabinRow } from "@duffel/api/types";
3
- import * as React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- export interface RowProps {
6
- row: SeatMapCabinRow;
7
- hasWings: boolean;
8
- selectedServicesMap: Record<string, WithSeatServiceInformation<CreateOrderService>>;
9
- onSeatToggled: (seatService: WithSeatServiceInformation<CreateOrderService>) => void;
10
- currentPassengerId: string;
11
- currentPassengerName: string;
12
- currentSegmentId: string;
13
- }
14
- export declare const Row: React.FC<RowProps>;
@@ -1,18 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, SeatMapCabinRow, SeatMapCabinRowSection } from "@duffel/api/types";
3
- import * as React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- interface RowSectionProps {
6
- row: SeatMapCabinRow;
7
- rowNumber: string | null;
8
- hasWings: boolean;
9
- section: SeatMapCabinRowSection;
10
- sectionIndex: number;
11
- selectedServicesMap: Record<string, WithSeatServiceInformation<CreateOrderService>>;
12
- onSeatToggled: (seatService: WithSeatServiceInformation<CreateOrderService>) => void;
13
- currentPassengerId: string;
14
- currentPassengerName: string;
15
- currentSegmentId: string;
16
- }
17
- export declare const RowSection: React.FC<RowSectionProps>;
18
- export {};
@@ -1,14 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, SeatMapCabinRowSectionElementSeat } from "@duffel/api/types";
3
- import * as React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- interface SeatElementProps {
6
- element: SeatMapCabinRowSectionElementSeat;
7
- currentSegmentId: string;
8
- currentPassengerId: string;
9
- currentPassengerName: string;
10
- onSeatToggled: (seatService: WithSeatServiceInformation<CreateOrderService>) => void;
11
- selectedServicesMap: Record<string, WithSeatServiceInformation<CreateOrderService>>;
12
- }
13
- export declare const SeatElement: React.FC<SeatElementProps>;
14
- export {};
@@ -1,8 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { SeatMapCabinRowSectionAvailableService, SeatMapCabinRowSectionElementSeat } from "@duffel/api/types";
3
- import * as React from "react";
4
- export interface SeatInfoProps {
5
- seat: SeatMapCabinRowSectionElementSeat | null;
6
- service: SeatMapCabinRowSectionAvailableService | undefined;
7
- }
8
- export declare const SeatInfo: React.FC<SeatInfoProps>;
@@ -1,13 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrderService, SeatMap as SeatMapType } from "@duffel/api/types";
3
- import * as React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- export interface SeatMapProps {
6
- seatMap: SeatMapType;
7
- selectedServicesMap: Record<string, WithSeatServiceInformation<CreateOrderService>>;
8
- onSeatToggled: (seatService: WithSeatServiceInformation<CreateOrderService>) => void;
9
- currentPassengerId: string;
10
- currentPassengerName: string;
11
- currentSegmentId: string;
12
- }
13
- export declare const SeatMap: React.FC<SeatMapProps>;
@@ -1,2 +0,0 @@
1
- import * as React from "react";
2
- export declare const SeatMapUnavailable: React.FC;
@@ -1,13 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrder, CreateOrderService, Offer, SeatMap } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- export interface SeatSelectionCardProps {
6
- isLoading: boolean;
7
- offer?: Offer;
8
- seatMaps?: SeatMap[];
9
- passengers: CreateOrder["passengers"];
10
- selectedServices: WithSeatServiceInformation<CreateOrderService>[];
11
- setSelectedServices: (selectedServices: WithSeatServiceInformation<CreateOrderService>[]) => void;
12
- }
13
- export declare const SeatSelectionCard: React.FC<SeatSelectionCardProps>;
@@ -1,15 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { CreateOrder, CreateOrderService, Offer, SeatMap } from "@duffel/api/types";
3
- import React from "react";
4
- import { WithSeatServiceInformation } from "src/types";
5
- type CreateOrderServiceWithInformation = WithSeatServiceInformation<CreateOrderService>;
6
- export interface SeatSelectionModalProps {
7
- isOpen: boolean;
8
- offer?: Offer;
9
- seatMaps?: SeatMap[];
10
- selectedServices: CreateOrderServiceWithInformation[];
11
- passengers: CreateOrder["passengers"];
12
- onClose: (selectedServices: CreateOrderServiceWithInformation[]) => void;
13
- }
14
- export declare const SeatSelectionModal: React.FC<SeatSelectionModalProps>;
15
- export {};
@@ -1,4 +0,0 @@
1
- import React from "react";
2
- import { SeatMapProps } from "./SeatMap";
3
- export type SeatSelectionModalBodyProps = SeatMapProps;
4
- export declare const SeatSelectionModalBody: React.FC<SeatSelectionModalBodyProps>;
@@ -1,16 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { ServicePriceMapById } from "@lib/getServicePriceMapById";
3
- import React from "react";
4
- import { CreateOrder, SeatMap } from "@duffel/api/types";
5
- export interface SeatSelectionModalFooterProps {
6
- currency: string;
7
- selectedServices: CreateOrder["services"];
8
- servicePrices: ServicePriceMapById;
9
- isFirstSegment: boolean;
10
- isLastSegment: boolean;
11
- onNextSegmentButtonClicked: () => void;
12
- onPreviousSegmentButtonClicked: () => void;
13
- onClose: () => void;
14
- seatMaps: SeatMap[];
15
- }
16
- export declare const SeatSelectionModalFooter: React.FC<SeatSelectionModalFooterProps>;
@@ -1,11 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { OfferSliceSegment } from "@duffel/api/types";
3
- import React from "react";
4
- export interface SeatSelectionModalHeaderProps {
5
- segmentAndPassengerPermutationsCount: number;
6
- currentSegment: OfferSliceSegment;
7
- currentPassengerName: string;
8
- currentSegmentAndPassengerPermutationsIndex: number;
9
- setCurrentSegmentAndPassengerPermutationsIndex: (index: number) => void;
10
- }
11
- export declare const SeatSelectionModalHeader: React.FC<SeatSelectionModalHeaderProps>;
@@ -1,6 +0,0 @@
1
- /// <reference types="@duffel/api" />
2
- import { SeatMapCabinRowSectionElementSeat } from "@duffel/api/types";
3
- import * as React from "react";
4
- export declare const SeatUnavailable: React.FC<{
5
- seat: SeatMapCabinRowSectionElementSeat;
6
- }>;
@@ -1,4 +0,0 @@
1
- import * as React from "react";
2
- import { DuffelCardFormProps } from "./lib/types";
3
- import { DuffelCardFormActions } from "./lib/useDuffelCardFormActions";
4
- export declare const DuffelCardForm: React.ForwardRefExoticComponent<DuffelCardFormProps & React.RefAttributes<DuffelCardFormActions>>;
@@ -1,34 +0,0 @@
1
- import * as React from "react";
2
- import { DuffelCardFormProps } from "./lib/types";
3
- declare const CUSTOM_ELEMENT_TAG = "duffel-card-form";
4
- type DuffelCardFormCustomElementRenderArguments = Pick<DuffelCardFormProps, "clientKey" | "intent" | "savedCardData" | "styles" | "tokenProxyEnvironment">;
5
- declare global {
6
- namespace JSX {
7
- interface IntrinsicElements {
8
- [CUSTOM_ELEMENT_TAG]: React.DetailedHTMLProps<React.HTMLAttributes<HTMLElement>, HTMLElement>;
9
- }
10
- }
11
- interface Window {
12
- renderDuffelCardFormCustomElement: typeof renderDuffelCardFormCustomElement;
13
- saveCard: typeof saveCard;
14
- createCardForTemporaryUse: typeof createCardForTemporaryUse;
15
- onValidateSuccess: typeof onValidateSuccess;
16
- onValidateFailure: typeof onValidateFailure;
17
- onSaveCardSuccess: typeof onSaveCardSuccess;
18
- onSaveCardFailure: typeof onSaveCardFailure;
19
- onCreateCardForTemporaryUseSuccess: typeof onCreateCardForTemporaryUseSuccess;
20
- onCreateCardForTemporaryUseFailure: typeof onCreateCardForTemporaryUseFailure;
21
- onSecurityPolicyViolation: typeof onSecurityPolicyViolation;
22
- }
23
- }
24
- export declare function renderDuffelCardFormCustomElement(props: DuffelCardFormCustomElementRenderArguments): void;
25
- export declare function saveCard(): void;
26
- export declare function createCardForTemporaryUse(): void;
27
- export declare const onValidateSuccess: (callback: () => void) => void;
28
- export declare const onValidateFailure: (callback: () => void) => void;
29
- export declare const onSaveCardSuccess: (callback: (data: import("./lib/types").SaveCardData) => void) => void;
30
- export declare const onSaveCardFailure: (callback: (error: import("./lib/types").SaveCardError) => void) => void;
31
- export declare const onCreateCardForTemporaryUseSuccess: (callback: (data: import("./lib/types").CreateCardForTemporaryUseData) => void) => void;
32
- export declare const onCreateCardForTemporaryUseFailure: (callback: (error: import("./lib/types").CreateCardForTemporaryUseError) => void) => void;
33
- export declare const onSecurityPolicyViolation: (callback: (data: import("./lib/types").SecurityPolicyViolationData) => void) => void;
34
- export {};
@@ -1,7 +0,0 @@
1
- import { DuffelCardFormProps } from "./types";
2
- type Inputs = {
3
- setIFrameHeight: (height: string) => void;
4
- postMessageWithStyles: () => void;
5
- } & Pick<DuffelCardFormProps, "onValidateSuccess" | "onValidateFailure" | "onCreateCardForTemporaryUseSuccess" | "onCreateCardForTemporaryUseFailure" | "onSaveCardSuccess" | "onSaveCardFailure" | "onSecurityPolicyViolation">;
6
- export declare function getIFrameEventListener(iFrameURL: URL, { postMessageWithStyles, setIFrameHeight, onValidateSuccess, onValidateFailure, onCreateCardForTemporaryUseSuccess, onCreateCardForTemporaryUseFailure, onSaveCardSuccess, onSaveCardFailure, onSecurityPolicyViolation, }: Inputs): (event: MessageEvent) => void;
7
- export {};
@@ -1,2 +0,0 @@
1
- import { DuffelCardFormProps } from "./types";
2
- export declare function getIFrameOriginForEnvironment(tokenProxyEnvironment: DuffelCardFormProps["tokenProxyEnvironment"]): string;
@@ -1,2 +0,0 @@
1
- import { DuffelCardFormProps } from "./types";
2
- export declare function getIframeURL(tokenProxyEnvironment: DuffelCardFormProps["tokenProxyEnvironment"], intent: DuffelCardFormProps["intent"], clientKey: DuffelCardFormProps["clientKey"], savedCardData: DuffelCardFormProps["savedCardData"]): URL;
@@ -1,2 +0,0 @@
1
- import { DuffelCardFormIntent } from "./types";
2
- export declare function getPathnameForIntent(intent: DuffelCardFormIntent): string;
@@ -1 +0,0 @@
1
- export declare function getTokenFromClientKey(clientKey: string): string;
@@ -1 +0,0 @@
1
- export declare function postMessageToCreateCardForTemporaryUse(iFrameReference: React.RefObject<HTMLIFrameElement>, baseUrl: URL): void;
@@ -1 +0,0 @@
1
- export declare function postMessageToSaveCard(iFrameReference: React.RefObject<HTMLIFrameElement>, baseUrl: URL): void;
@@ -1,2 +0,0 @@
1
- import { DuffelCardFormStyles } from "./types";
2
- export declare function postMessageWithStyles(iFrameReference: React.RefObject<HTMLIFrameElement>, baseUrl: URL, styles: DuffelCardFormStyles | undefined): void;