@saasquatch/mint-components 1.3.2-18 → 1.3.2-19

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 (207) hide show
  1. package/dist/cjs/{ShadowViewAddon-d6a442a9.js → ShadowViewAddon-a85b8c8d.js} +1 -1
  2. package/dist/cjs/{global-b957dd98.js → global-6223fe8f.js} +1 -1
  3. package/dist/cjs/{index.module-85eb6b4d.js → index.module-7dd4b981.js} +1 -1
  4. package/dist/cjs/loader.cjs.js +2 -2
  5. package/dist/cjs/mint-components.cjs.js +2 -2
  6. package/dist/cjs/{re-render-59955561.js → re-render-6111d4bd.js} +1 -1
  7. package/dist/cjs/sqm-asset-card.cjs.entry.js +1 -1
  8. package/dist/cjs/sqm-big-stat.cjs.entry.js +2 -2
  9. package/dist/cjs/sqm-divided-layout_30.cjs.entry.js +3735 -314
  10. package/dist/cjs/sqm-graphql-client-provider.cjs.entry.js +1 -1
  11. package/dist/cjs/{sqm-leaderboard-rank-view-9114d9ad.js → sqm-leaderboard-rank-view-7dd44d62.js} +2 -2
  12. package/dist/cjs/sqm-leaderboard-rank.cjs.entry.js +3 -3
  13. package/dist/cjs/sqm-leaderboard.cjs.entry.js +2 -2
  14. package/dist/cjs/sqm-name-fields.cjs.entry.js +1 -1
  15. package/dist/cjs/{sqm-navigation-sidebar-item-view-b565a10a.js → sqm-navigation-sidebar-item-view-6c7f78e6.js} +1 -1
  16. package/dist/cjs/sqm-navigation-sidebar-item.cjs.entry.js +2 -2
  17. package/dist/cjs/sqm-popup-container.cjs.entry.js +1 -1
  18. package/dist/cjs/{sqm-portal-email-verification-view-bd40f7eb.js → sqm-portal-email-verification-view-08d1848c.js} +1 -1
  19. package/dist/cjs/sqm-portal-email-verification.cjs.entry.js +3 -3
  20. package/dist/cjs/{sqm-portal-footer-view-b60e17c8.js → sqm-portal-footer-view-69c73802.js} +1 -1
  21. package/dist/cjs/sqm-portal-footer.cjs.entry.js +3 -3
  22. package/dist/cjs/sqm-portal-forgot-password.cjs.entry.js +1 -1
  23. package/dist/cjs/sqm-portal-logout.cjs.entry.js +1 -1
  24. package/dist/cjs/{sqm-portal-profile-view-c3b889d4.js → sqm-portal-profile-view-14b41436.js} +1 -1
  25. package/dist/cjs/sqm-portal-profile.cjs.entry.js +3 -3
  26. package/dist/cjs/sqm-portal-protected-route.cjs.entry.js +1 -1
  27. package/dist/cjs/sqm-portal-reset-password.cjs.entry.js +1 -1
  28. package/dist/cjs/sqm-portal-verify-email.cjs.entry.js +1 -1
  29. package/dist/cjs/sqm-referral-table-column.cjs.entry.js +2 -2
  30. package/dist/cjs/sqm-referral-table-date-column.cjs.entry.js +2 -2
  31. package/dist/cjs/sqm-referral-table-rewards-column.cjs.entry.js +2 -2
  32. package/dist/cjs/sqm-referral-table-status-column.cjs.entry.js +2 -2
  33. package/dist/cjs/sqm-referral-table-user-column.cjs.entry.js +2 -2
  34. package/dist/cjs/sqm-share-code.cjs.entry.js +1 -1
  35. package/dist/cjs/{useDemoBigStat-9193e8c5.js → useDemoBigStat-2786227e.js} +1 -1
  36. package/dist/collection/components/sqm-reward-exchange-list/RewardExchangeList.stories.js +26 -18
  37. package/dist/collection/components/sqm-reward-exchange-list/RewardExchangeListData.js +106 -119
  38. package/dist/collection/components/sqm-reward-exchange-list/SVGs.js +21 -5
  39. package/dist/collection/components/sqm-reward-exchange-list/assets/placeholder.png +0 -0
  40. package/dist/collection/components/sqm-reward-exchange-list/progressBar.js +32 -29
  41. package/dist/collection/components/sqm-reward-exchange-list/sqm-reward-exchange-list-view.js +199 -89
  42. package/dist/collection/components/sqm-stencilbook/AutoColor.js +26 -0
  43. package/dist/collection/components/sqm-stencilbook/Themes.js +38 -0
  44. package/dist/collection/components/sqm-stencilbook/sqm-stencilbook.js +11 -2
  45. package/dist/collection/components/sqm-task-card/sqm-task-card-view.js +42 -34
  46. package/dist/esm/{ShadowViewAddon-2338f393.js → ShadowViewAddon-a3f510db.js} +1 -1
  47. package/dist/esm/{global-0e81c5e6.js → global-90da933f.js} +1 -1
  48. package/dist/esm/{index.module-9b5bb6a2.js → index.module-90d2c3ad.js} +1 -1
  49. package/dist/esm/loader.js +2 -2
  50. package/dist/esm/mint-components.js +2 -2
  51. package/dist/esm/{re-render-57ac6584.js → re-render-e06f2f7f.js} +1 -1
  52. package/dist/esm/sqm-asset-card.entry.js +1 -1
  53. package/dist/esm/sqm-big-stat.entry.js +2 -2
  54. package/dist/esm/sqm-divided-layout_30.entry.js +3735 -314
  55. package/dist/esm/sqm-graphql-client-provider.entry.js +1 -1
  56. package/dist/esm/{sqm-leaderboard-rank-view-3f0dc20e.js → sqm-leaderboard-rank-view-47844836.js} +2 -2
  57. package/dist/esm/sqm-leaderboard-rank.entry.js +3 -3
  58. package/dist/esm/sqm-leaderboard.entry.js +2 -2
  59. package/dist/esm/sqm-name-fields.entry.js +1 -1
  60. package/dist/esm/{sqm-navigation-sidebar-item-view-79b0748c.js → sqm-navigation-sidebar-item-view-f2304ad9.js} +1 -1
  61. package/dist/esm/sqm-navigation-sidebar-item.entry.js +2 -2
  62. package/dist/esm/sqm-popup-container.entry.js +1 -1
  63. package/dist/esm/{sqm-portal-email-verification-view-8f253fb7.js → sqm-portal-email-verification-view-8cefe480.js} +1 -1
  64. package/dist/esm/sqm-portal-email-verification.entry.js +3 -3
  65. package/dist/esm/{sqm-portal-footer-view-b8a2f15e.js → sqm-portal-footer-view-d9fe0bf8.js} +1 -1
  66. package/dist/esm/sqm-portal-footer.entry.js +3 -3
  67. package/dist/esm/sqm-portal-forgot-password.entry.js +1 -1
  68. package/dist/esm/sqm-portal-logout.entry.js +1 -1
  69. package/dist/esm/{sqm-portal-profile-view-831dea85.js → sqm-portal-profile-view-b67467b4.js} +1 -1
  70. package/dist/esm/sqm-portal-profile.entry.js +3 -3
  71. package/dist/esm/sqm-portal-protected-route.entry.js +1 -1
  72. package/dist/esm/sqm-portal-reset-password.entry.js +1 -1
  73. package/dist/esm/sqm-portal-verify-email.entry.js +1 -1
  74. package/dist/esm/sqm-referral-table-column.entry.js +2 -2
  75. package/dist/esm/sqm-referral-table-date-column.entry.js +2 -2
  76. package/dist/esm/sqm-referral-table-rewards-column.entry.js +2 -2
  77. package/dist/esm/sqm-referral-table-status-column.entry.js +2 -2
  78. package/dist/esm/sqm-referral-table-user-column.entry.js +2 -2
  79. package/dist/esm/sqm-share-code.entry.js +1 -1
  80. package/dist/esm/{useDemoBigStat-660c8672.js → useDemoBigStat-c3b955b7.js} +1 -1
  81. package/dist/esm-es5/{ShadowViewAddon-2338f393.js → ShadowViewAddon-a3f510db.js} +1 -1
  82. package/dist/esm-es5/{global-0e81c5e6.js → global-90da933f.js} +1 -1
  83. package/dist/esm-es5/{index.module-9b5bb6a2.js → index.module-90d2c3ad.js} +1 -1
  84. package/dist/esm-es5/loader.js +1 -1
  85. package/dist/esm-es5/mint-components.js +1 -1
  86. package/dist/esm-es5/{re-render-57ac6584.js → re-render-e06f2f7f.js} +1 -1
  87. package/dist/esm-es5/sqm-asset-card.entry.js +1 -1
  88. package/dist/esm-es5/sqm-big-stat.entry.js +1 -1
  89. package/dist/esm-es5/sqm-divided-layout_30.entry.js +58 -1
  90. package/dist/esm-es5/sqm-graphql-client-provider.entry.js +1 -1
  91. package/dist/esm-es5/{sqm-leaderboard-rank-view-3f0dc20e.js → sqm-leaderboard-rank-view-47844836.js} +1 -1
  92. package/dist/esm-es5/sqm-leaderboard-rank.entry.js +1 -1
  93. package/dist/esm-es5/sqm-leaderboard.entry.js +1 -1
  94. package/dist/esm-es5/sqm-name-fields.entry.js +1 -1
  95. package/dist/esm-es5/{sqm-navigation-sidebar-item-view-79b0748c.js → sqm-navigation-sidebar-item-view-f2304ad9.js} +1 -1
  96. package/dist/esm-es5/sqm-navigation-sidebar-item.entry.js +1 -1
  97. package/dist/esm-es5/sqm-popup-container.entry.js +1 -1
  98. package/dist/esm-es5/{sqm-portal-email-verification-view-8f253fb7.js → sqm-portal-email-verification-view-8cefe480.js} +1 -1
  99. package/dist/esm-es5/sqm-portal-email-verification.entry.js +1 -1
  100. package/dist/esm-es5/{sqm-portal-footer-view-b8a2f15e.js → sqm-portal-footer-view-d9fe0bf8.js} +1 -1
  101. package/dist/esm-es5/sqm-portal-footer.entry.js +1 -1
  102. package/dist/esm-es5/sqm-portal-forgot-password.entry.js +1 -1
  103. package/dist/esm-es5/sqm-portal-logout.entry.js +1 -1
  104. package/dist/esm-es5/{sqm-portal-profile-view-831dea85.js → sqm-portal-profile-view-b67467b4.js} +1 -1
  105. package/dist/esm-es5/sqm-portal-profile.entry.js +1 -1
  106. package/dist/esm-es5/sqm-portal-protected-route.entry.js +1 -1
  107. package/dist/esm-es5/sqm-portal-reset-password.entry.js +1 -1
  108. package/dist/esm-es5/sqm-portal-verify-email.entry.js +1 -1
  109. package/dist/esm-es5/sqm-referral-table-column.entry.js +1 -1
  110. package/dist/esm-es5/sqm-referral-table-date-column.entry.js +1 -1
  111. package/dist/esm-es5/sqm-referral-table-rewards-column.entry.js +1 -1
  112. package/dist/esm-es5/sqm-referral-table-status-column.entry.js +1 -1
  113. package/dist/esm-es5/sqm-referral-table-user-column.entry.js +1 -1
  114. package/dist/esm-es5/sqm-share-code.entry.js +1 -1
  115. package/dist/esm-es5/{useDemoBigStat-660c8672.js → useDemoBigStat-c3b955b7.js} +1 -1
  116. package/dist/mint-components/assets/placeholder.png +0 -0
  117. package/dist/mint-components/mint-components.esm.js +1 -1
  118. package/dist/mint-components/mint-components.js +1 -1
  119. package/dist/mint-components/{p-be615f03.system.js → p-07c924fa.system.js} +1 -1
  120. package/dist/mint-components/{p-295b306a.js → p-0eb3e89c.js} +1 -1
  121. package/dist/mint-components/p-160bd62f.entry.js +1 -0
  122. package/dist/mint-components/{p-58bf2a30.system.js → p-16f5a7cb.system.js} +1 -1
  123. package/dist/mint-components/{p-55f029cd.system.entry.js → p-1a09e4e1.system.entry.js} +1 -1
  124. package/dist/mint-components/p-1c8b0290.entry.js +1 -0
  125. package/dist/mint-components/{p-b893904c.system.entry.js → p-1dcdca58.system.entry.js} +1 -1
  126. package/dist/mint-components/p-20d41ab1.entry.js +1 -0
  127. package/dist/mint-components/{p-a93149f4.entry.js → p-221a4097.entry.js} +1 -1
  128. package/dist/mint-components/{p-0a882bab.system.entry.js → p-223b42bd.system.entry.js} +1 -1
  129. package/dist/mint-components/{p-27bb0aa9.js → p-224504ad.js} +1 -1
  130. package/dist/mint-components/{p-7062ab8e.system.entry.js → p-24b3c6f0.system.entry.js} +1 -1
  131. package/dist/mint-components/{p-3404b8d2.system.entry.js → p-24c9a599.system.entry.js} +1 -1
  132. package/dist/mint-components/{p-aee2a2b9.entry.js → p-29fab29b.entry.js} +1 -1
  133. package/dist/mint-components/{p-ad1c6eb8.system.entry.js → p-304e6c82.system.entry.js} +1 -1
  134. package/dist/mint-components/{p-8f5b80f2.entry.js → p-3397167c.entry.js} +1 -1
  135. package/dist/mint-components/{p-62102076.entry.js → p-33c5ffb7.entry.js} +1 -1
  136. package/dist/mint-components/p-3551df7f.system.entry.js +58 -0
  137. package/dist/mint-components/{p-98e29140.system.entry.js → p-396bf448.system.entry.js} +1 -1
  138. package/dist/mint-components/{p-69902f7c.system.js → p-3b97aed8.system.js} +1 -1
  139. package/dist/mint-components/{p-1ec1dcb3.system.js → p-3ce2fb83.system.js} +1 -1
  140. package/dist/mint-components/p-3d856985.entry.js +1 -0
  141. package/dist/mint-components/{p-1dc2793a.system.entry.js → p-4052b948.system.entry.js} +1 -1
  142. package/dist/mint-components/{p-46cb29e2.system.entry.js → p-412a9226.system.entry.js} +1 -1
  143. package/dist/mint-components/{p-75b143ac.system.entry.js → p-44d0fc80.system.entry.js} +1 -1
  144. package/dist/mint-components/p-45c752a0.entry.js +1 -0
  145. package/dist/mint-components/{p-b6107771.js → p-46a4269a.js} +1 -1
  146. package/dist/mint-components/{p-16b0b00b.entry.js → p-52802c88.entry.js} +2 -2
  147. package/dist/mint-components/p-5480e4ee.entry.js +1 -0
  148. package/dist/mint-components/p-55508395.system.entry.js +1 -0
  149. package/dist/mint-components/{p-a59e65f2.js → p-563253e8.js} +1 -1
  150. package/dist/mint-components/{p-58fb3d02.system.js → p-60855d33.system.js} +1 -1
  151. package/dist/mint-components/{p-0e49a93f.system.entry.js → p-67ae18d1.system.entry.js} +1 -1
  152. package/dist/mint-components/{p-8bfe1f7d.js → p-6882070c.js} +1 -1
  153. package/dist/mint-components/{p-cafc22bf.system.entry.js → p-69bcf4fa.system.entry.js} +1 -1
  154. package/dist/mint-components/{p-1dc2e37a.system.entry.js → p-6bf0a4d9.system.entry.js} +1 -1
  155. package/dist/mint-components/{p-b9edc48d.system.entry.js → p-6e245fa3.system.entry.js} +1 -1
  156. package/dist/mint-components/{p-77f9b4af.entry.js → p-723ebe45.entry.js} +1 -1
  157. package/dist/mint-components/{p-e53399e5.system.entry.js → p-73148868.system.entry.js} +1 -1
  158. package/dist/mint-components/p-8435a22d.entry.js +1 -0
  159. package/dist/mint-components/p-883a32e7.entry.js +1 -0
  160. package/dist/mint-components/{p-7ee8a7ed.system.js → p-9c554ca0.system.js} +1 -1
  161. package/dist/mint-components/{p-75ae6fc0.entry.js → p-9d6dbb2d.entry.js} +1 -1
  162. package/dist/mint-components/p-9e4fee30.system.entry.js +1 -0
  163. package/dist/mint-components/{p-101fafa3.js → p-a2c3cff3.js} +1 -1
  164. package/dist/mint-components/{p-6acfe4a0.entry.js → p-a4c2c7ed.entry.js} +1 -1
  165. package/dist/mint-components/{p-f3ea7918.system.js → p-a6094ff9.system.js} +1 -1
  166. package/dist/mint-components/{p-25021e09.entry.js → p-ade44a4e.entry.js} +1 -1
  167. package/dist/mint-components/{p-be62004c.entry.js → p-b1bb07db.entry.js} +1 -1
  168. package/dist/mint-components/{p-d4fe6a69.system.js → p-b608f7a4.system.js} +1 -1
  169. package/dist/mint-components/{p-623e7f8c.entry.js → p-b8a77904.entry.js} +69 -12
  170. package/dist/mint-components/{p-503192e9.entry.js → p-b8bd2607.entry.js} +1 -1
  171. package/dist/mint-components/{p-17e6fc02.system.entry.js → p-be2738b0.system.entry.js} +1 -1
  172. package/dist/mint-components/{p-b2cb66f5.system.js → p-c6114bfe.system.js} +1 -1
  173. package/dist/mint-components/{p-d5a00e40.system.entry.js → p-c79c608d.system.entry.js} +1 -1
  174. package/dist/mint-components/{p-1dd1105d.system.entry.js → p-cca9026f.system.entry.js} +1 -1
  175. package/dist/mint-components/p-cd410a05.entry.js +9 -0
  176. package/dist/mint-components/p-cdeae699.system.js +1 -0
  177. package/dist/mint-components/{p-232dddcc.system.entry.js → p-d174d0bc.system.entry.js} +1 -1
  178. package/dist/mint-components/{p-bafc60df.js → p-d21e0dbd.js} +1 -1
  179. package/dist/mint-components/{p-d5b84d6b.js → p-d35b0366.js} +1 -1
  180. package/dist/mint-components/{p-24d13567.js → p-db2e4c42.js} +1 -1
  181. package/dist/mint-components/{p-35103a1b.system.entry.js → p-dc603d08.system.entry.js} +1 -1
  182. package/dist/mint-components/{p-8a9966fc.system.js → p-e7f633b9.system.js} +1 -1
  183. package/dist/mint-components/p-f17050de.entry.js +1 -0
  184. package/dist/mint-components/{p-441119ee.js → p-f90486ca.js} +15 -15
  185. package/dist/mint-components/p-fce1dbf6.entry.js +1 -0
  186. package/dist/types/components/sqm-reward-exchange-list/RewardExchangeList.stories.d.ts +9 -3
  187. package/dist/types/components/sqm-reward-exchange-list/RewardExchangeListData.d.ts +158 -36
  188. package/dist/types/components/sqm-reward-exchange-list/SVGs.d.ts +1 -0
  189. package/dist/types/components/sqm-reward-exchange-list/useRewardExchangeList.d.ts +0 -1
  190. package/dist/types/components/sqm-stencilbook/AutoColor.d.ts +1 -0
  191. package/dist/types/components/sqm-stencilbook/Themes.d.ts +16 -0
  192. package/package.json +3 -1
  193. package/dist/mint-components/p-024cc1be.system.entry.js +0 -1
  194. package/dist/mint-components/p-22d56623.entry.js +0 -9
  195. package/dist/mint-components/p-3098bb1b.system.entry.js +0 -1
  196. package/dist/mint-components/p-35ba4a8b.entry.js +0 -1
  197. package/dist/mint-components/p-51277d8e.system.entry.js +0 -1
  198. package/dist/mint-components/p-6410316b.entry.js +0 -1
  199. package/dist/mint-components/p-6cbb3a00.entry.js +0 -1
  200. package/dist/mint-components/p-853bd4bd.entry.js +0 -1
  201. package/dist/mint-components/p-85728f98.entry.js +0 -1
  202. package/dist/mint-components/p-8ec40f9a.entry.js +0 -1
  203. package/dist/mint-components/p-aa39d9c0.entry.js +0 -1
  204. package/dist/mint-components/p-dea06c92.entry.js +0 -1
  205. package/dist/mint-components/p-eb5aae94.entry.js +0 -1
  206. package/dist/mint-components/p-f7b80ac0.entry.js +0 -1
  207. package/dist/mint-components/p-f7d7e44d.system.js +0 -1
@@ -1,8 +1,8 @@
1
1
  import { h, r as registerInstance, c as Host, d as getAssetPath } from './index-17b4da69.js';
2
2
  import { m as h$1, j as useState, e as useEffect, f as useRef, n as d$2, y as y$1, b as browser, u as useReducer, c as createCommonjsModule, a as commonjsGlobal, k as useMemo } from './extends-3a3f9fe2.js';
3
- import { i as intl, a as insertCSS } from './global-0e81c5e6.js';
3
+ import { i as intl, a as insertCSS } from './global-90da933f.js';
4
4
  import { u as useCallback } from './use-callback-b38a1523.js';
5
- import { d as dist, T as T$1, e as en, b as be, j as j$1, Z as Ze, r as rn, D as De, q as qe, P as P$1, E as Ee, M as M$1, a as sn, c as an, x as x$1, f as D$1, L as L$1, N as Ne, A as A$1 } from './index.module-9b5bb6a2.js';
5
+ import { d as dist, T as T$1, e as en, b as be, j as j$1, Z as Ze, r as rn, D as De, q as qe, P as P$1, E as Ee, M as M$1, a as sn, c as an, x as x$1, f as D$1, L as L$1, N as Ne, A as A$1 } from './index.module-90d2c3ad.js';
6
6
  import { j as jsonpointer } from './jsonpointer-388a7082.js';
7
7
  import { j as jss, c as create } from './jss-preset-default.esm-71fae192.js';
8
8
  import { g as getProps, a as getMissingProps } from './utils-454405f5.js';
@@ -11,21 +11,21 @@ import { E as ErrorStyles, H as HostBlock, A as AuthWrapper, a as AuthColumn, b
11
11
  import { P as PortalContainerView } from './sqm-portal-container-view-73757ca5.js';
12
12
  import { P as PortalSectionView } from './sqm-portal-section-view-f0876545.js';
13
13
  import { T as TextSpanView } from './sqm-text-span-view-1781df94.js';
14
- import { g as gql, L as LeaderboardRankView } from './sqm-leaderboard-rank-view-3f0dc20e.js';
15
- import { u as useRerenderListener, a as useRequestRerender } from './re-render-57ac6584.js';
16
- import { p as pathToRegexp, B as BigStatView, u as useBigStat, a as useDemoBigStat } from './useDemoBigStat-660c8672.js';
14
+ import { g as gql, L as LeaderboardRankView } from './sqm-leaderboard-rank-view-47844836.js';
15
+ import { u as useRerenderListener, a as useRequestRerender } from './re-render-e06f2f7f.js';
16
+ import { p as pathToRegexp, B as BigStatView, u as useBigStat, a as useDemoBigStat } from './useDemoBigStat-c3b955b7.js';
17
17
  import { S as ShareLinkView } from './sqm-share-link-view-9282b8e8.js';
18
- import { L as LeaderboardView, u as useLeaderboard, S as ShadowViewAddon } from './ShadowViewAddon-2338f393.js';
18
+ import { L as LeaderboardView, u as useLeaderboard, S as ShadowViewAddon } from './ShadowViewAddon-a3f510db.js';
19
19
  import { N as NavigationSidebarView } from './sqm-navigation-sidebar-view-2242502c.js';
20
- import { N as NavigationSidebarItemView } from './sqm-navigation-sidebar-item-view-79b0748c.js';
20
+ import { N as NavigationSidebarItemView } from './sqm-navigation-sidebar-item-view-f2304ad9.js';
21
21
  import { S as StatContainerView } from './sqm-stat-container-view-4133feb6.js';
22
- import { P as PortalProfileView } from './sqm-portal-profile-view-831dea85.js';
22
+ import { P as PortalProfileView } from './sqm-portal-profile-view-b67467b4.js';
23
23
  import { P as PortalForgotPasswordView } from './sqm-portal-forgot-password-view-e3a6a716.js';
24
- import { P as PortalEmailVerificationView } from './sqm-portal-email-verification-view-8f253fb7.js';
24
+ import { P as PortalEmailVerificationView } from './sqm-portal-email-verification-view-8cefe480.js';
25
25
  import { P as PortalResetPasswordView$1 } from './sqm-portal-reset-password-view-a4e50da2.js';
26
26
  import { P as PortalVerifyEmailView } from './sqm-portal-verify-email-view-6f18bac2.js';
27
27
  import { A as AssetCardView } from './sqm-asset-card-view-6f360937.js';
28
- import { P as PoweredByImg$1, a as PortalFooterView } from './sqm-portal-footer-view-b8a2f15e.js';
28
+ import { P as PoweredByImg$1, a as PortalFooterView } from './sqm-portal-footer-view-d9fe0bf8.js';
29
29
  import { H as HeroView } from './sqm-hero-view-bfd8abd1.js';
30
30
  import { N as NameFieldsView } from './sqm-name-fields-view-4162fb7b.js';
31
31
 
@@ -14917,51 +14917,69 @@ function useRewardExchangeList(props) {
14917
14917
  };
14918
14918
  }
14919
14919
 
14920
- const ExchangeArrows = () => (h("svg", { width: "30", height: "30", viewBox: "0 0 30 30", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14921
- h("circle", { cx: "15", cy: "15", r: "15", fill: "white" }),
14922
- h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M10.6255 21.783C10.5129 21.8963 10.3597 21.96 10.2 21.96C10.0402 21.96 9.88705 21.8963 9.77442 21.783L5.87442 17.8597C5.64081 17.6247 5.64194 17.2448 5.87695 17.0112C6.11197 16.7775 6.49186 16.7787 6.72548 17.0137L9.59995 19.9054V8.52001C9.59995 8.18864 9.86858 7.92001 10.2 7.92001C10.5313 7.92001 10.8 8.18864 10.8 8.52001V19.9054L13.6744 17.0137C13.908 16.7787 14.2879 16.7775 14.5229 17.0112C14.758 17.2448 14.7591 17.6247 14.5255 17.8597L10.6255 21.783ZM20.2255 8.09707C20.1129 7.98378 19.9597 7.92007 19.8 7.92007C19.6402 7.92007 19.487 7.98378 19.3744 8.09707L15.4744 12.0204C15.2408 12.2554 15.2419 12.6353 15.477 12.8689C15.712 13.1025 16.0919 13.1014 16.3255 12.8664L19.2 9.97473V21.3601C19.2 21.6914 19.4686 21.9601 19.8 21.9601C20.1313 21.9601 20.4 21.6914 20.4 21.3601V9.97473L23.2744 12.8664C23.508 13.1014 23.8879 13.1025 24.1229 12.8689C24.358 12.6353 24.3591 12.2554 24.1255 12.0204L20.2255 8.09707Z", fill: "#333333" })));
14923
- const CheckMark = () => (h("svg", { xmlns: "http://www.w3.org/2000/svg", width: "10", height: "7", viewBox: "0 0 10 7", fill: "none" },
14924
- h("path", { d: "M2.12828 2.71485C1.72536 2.33712 1.09253 2.35754 0.714799 2.76045C0.337068 3.16336 0.357483 3.7962 0.760395 4.17393L2.12828 2.71485ZM3.81471 5.66661L3.13076 6.39615C3.51542 6.75677 4.11399 6.75677 4.49865 6.39615L3.81471 5.66661ZM9.23939 1.95171C9.6423 1.57397 9.66271 0.941139 9.28498 0.538227C8.90725 0.135315 8.27442 0.114901 7.87151 0.492631L9.23939 1.95171ZM0.760395 4.17393L3.13076 6.39615L4.49865 4.93708L2.12828 2.71485L0.760395 4.17393ZM4.49865 6.39615L9.23939 1.95171L7.87151 0.492631L3.13076 4.93708L4.49865 6.39615Z", fill: "white" })));
14925
-
14926
- function Dot({ active, completed, incomplete, }) {
14920
+ const ExchangeArrows = () => (h("svg", { width: 19, height: 15, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14921
+ h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M5.125 14.783a.6.6 0 0 1-.851 0l-3.9-3.923a.6.6 0 1 1 .85-.846L4.1 12.905V1.52a.6.6 0 0 1 1.2 0v11.385l2.875-2.891a.6.6 0 1 1 .85.846l-3.9 3.923Zm9.6-13.686a.6.6 0 0 0-.851 0l-3.9 3.923a.6.6 0 0 0 .85.846L13.7 2.975V14.36a.6.6 0 1 0 1.2 0V2.975l2.875 2.891a.6.6 0 1 0 .85-.846l-3.9-3.923Z", fill: "#333" })));
14922
+ const CheckMark = () => (h("svg", { width: 12, height: 10, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14923
+ h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M11.58.23c.475.371.56 1.057.19 1.532L5.69 9.554a1.091 1.091 0 0 1-1.631.1L.32 5.915a1.09 1.09 0 1 1 1.542-1.542L4.73 7.239 10.049.42A1.09 1.09 0 0 1 11.58.23Z", fill: "#fff" })));
14924
+ const Gift = () => (h("svg", { width: 156, height: 157, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14925
+ h("path", { d: "M40.18 126h83.663a3 3 0 0 0 3-3V73.966a3 3 0 0 0-3-3H40.18a3 3 0 0 0-3 3V123a3 3 0 0 0 3 3Z", fill: "#FFD34F" }),
14926
+ h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M37.18 73.862v7.966h89.663v-7.966H37.18Z", fill: "#E9BB30" }),
14927
+ h("path", { d: "M133.039 74.224a2.18 2.18 0 0 0 2.187-2.172v-19.19c0-1.2-.98-2.172-2.187-2.172H31.347a2.18 2.18 0 0 0-2.187 2.172v19.19c0 1.2.98 2.172 2.187 2.172H133.04Z", fill: "#FFC000" }),
14928
+ h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M123.287 35.172c0 6.056-9.155 15.226-13.76 15.654H88.888V126H75.141V50.826H58.534c-9.462-2.038-17.803-9.258-17.803-16.944 0-7.49 3.274-13.422 9.23-15.983 5.693-2.446 12.265-1.105 17.46 2.479 6.378 4.398 9.956 12.654 13.202 20.144.284.657.567 1.308.848 1.95.274-.608.55-1.228.83-1.856 3.216-7.22 6.887-15.464 13.057-19.89 5.454-3.913 12.387-5.39 18.38-2.711 6.197 2.77 9.549 9.127 9.549 17.157Zm-23.306-8.266c3.305-2.37 7.262-2.8 10.645 0 2.946 2.44 3.103 3.588 3.482 6.351l.067.483c0 4.09-3.549 10.252-7.097 10.252-2.515 0-4.489-.022-6.34-.041-3.375-.036-6.337-.068-11.403.04.966-1.86 1.737-3.644 2.473-5.346 1.967-4.553 3.678-8.515 8.173-11.739Zm-39.034 0c-1.6-1.103-5.268-.61-6.79.043-1.257.54-3.134 2.19-3.134 6.933 0 4.61 7.511 8.59 7.511 8.59s5.962 1.52 16.607 1.52c-3.624-8.922-8.757-13.336-14.194-17.086Z", fill: "#EB5757" }),
14929
+ h("path", { d: "M75.086 74.224h13.85v7.604h-13.85v-7.604Z", fill: "#DD4747" }),
14930
+ h("g", { filter: "url(#a)" },
14931
+ h("ellipse", { cx: 82.008, cy: 141.207, rx: 36.813, ry: 5.793, fill: "#E0DDDD", "fill-opacity": 0.8 })),
14932
+ h("path", { d: "M150.446 79.134a.5.5 0 0 1 .9 0l1.133 2.336c.05.102.132.184.234.233l2.344 1.122a.5.5 0 0 1 0 .902l-2.344 1.122a.503.503 0 0 0-.234.233l-1.133 2.336a.5.5 0 0 1-.9 0l-1.134-2.336a.499.499 0 0 0-.234-.233l-2.343-1.122a.5.5 0 0 1 0-.902l2.343-1.122a.499.499 0 0 0 .234-.233l1.134-2.336Z", fill: "#FAB6B6" }),
14933
+ h("path", { d: "M14.86 29.168a.5.5 0 0 1 .9 0l1.133 2.336a.5.5 0 0 0 .234.233l2.344 1.122a.5.5 0 0 1 0 .902l-2.344 1.122a.5.5 0 0 0-.234.233l-1.133 2.336a.5.5 0 0 1-.9 0l-1.134-2.336a.5.5 0 0 0-.234-.233l-2.343-1.122a.5.5 0 0 1 0-.902l2.344-1.122a.5.5 0 0 0 .233-.233l1.134-2.336Z", fill: "#F4EFBC" }),
14934
+ h("path", { d: "m125.382 0 .712 1.466 1.475.706-1.475.707-.712 1.466-.711-1.466-1.476-.707 1.476-.706.711-1.466Z", fill: "#FDA802" }),
14935
+ h("path", { d: "m2.187 103.552.711 1.466 1.476.706-1.476.707-.711 1.466-.711-1.466L0 105.724l1.476-.706.71-1.466Z", fill: "#E4599C" }),
14936
+ h("defs", null,
14937
+ h("filter", { id: "a", x: 35.195, y: 125.414, width: 93.625, height: 31.586, filterUnits: "userSpaceOnUse", "color-interpolation-filters": "s-rGB" },
14938
+ h("feFlood", { "flood-opacity": 0, result: "BackgroundImageFix" }),
14939
+ h("feBlend", { in: "SourceGraphic", in2: "BackgroundImageFix", result: "shape" }),
14940
+ h("feGaussianBlur", { stdDeviation: 5, result: "effect1_foregroundBlur_653_17907" })))));
14941
+
14942
+ function Dot({ active, completed, incomplete, stage, }) {
14927
14943
  return (h("div", { style: {
14928
- flex: "0 0 0",
14929
- content: "''",
14930
- height: "4px",
14931
- borderRadius: "4px",
14932
- background: incomplete ? "#E5E5E5" : "#9E9E9E",
14933
- position: "relative",
14934
- bottom: "0",
14935
- left: "0",
14936
14944
  display: "flex",
14937
- justifyContent: "center",
14938
- columnGap: "50px",
14939
- marginRight: "-2px",
14940
- boxSizing: "content-box",
14941
14945
  } },
14942
14946
  h("div", { style: {
14943
- backgroundColor: completed ? "#9E9E9E" : "#FFF",
14947
+ backgroundColor: completed
14948
+ ? "var(--sl-color-success-500)"
14949
+ : incomplete
14950
+ ? "var(--sl-color-neutral-200)"
14951
+ : "var(--sl-color-neutral-0)",
14944
14952
  border: active
14945
- ? "3px solid #9E9E9E"
14953
+ ? "1px solid var(--sl-color-success-500)"
14946
14954
  : incomplete
14947
- ? "3px solid #E5E5E5"
14948
- : "3px solid #9E9E9E",
14955
+ ? "1px solid var(--sl-color-neutral-200)"
14956
+ : "1px solid var(--sl-color-success-500)",
14949
14957
  borderRadius: "50%",
14950
- width: "10px",
14951
- height: "10px",
14952
- margin: "-6px auto 0px",
14958
+ width: "23px",
14959
+ height: "23px",
14960
+ margin: "-11px",
14953
14961
  zIndex: "1",
14954
14962
  boxSizing: "content-box",
14955
- } }, completed && (h("div", { style: { top: "-6px", position: "relative" } },
14956
- h(CheckMark, null))))));
14963
+ } }, completed ? (h("div", { style: { top: "-10.5%", left: "23.5%", position: "relative" } },
14964
+ h(CheckMark, null))) : (h("div", { style: {
14965
+ color: active
14966
+ ? "var(--sl-color-success-500)"
14967
+ : "var(--sl-color-neutral-50)",
14968
+ width: "23px",
14969
+ lineHeight: "24px",
14970
+ textAlign: "center",
14971
+ position: "relative",
14972
+ } }, stage + 1)))));
14957
14973
  }
14958
- function ProgressLine({ incomplete = false, active = false }) {
14974
+ function ProgressLine({ incomplete = false, active = false, invisible = false, }) {
14959
14975
  return (h("div", { style: {
14960
14976
  content: "''",
14961
14977
  flex: "0.5 0.5 0",
14962
14978
  height: "4px",
14963
14979
  borderRadius: "4px",
14964
- background: incomplete || active ? "#E5E5E5" : "#9E9E9E",
14980
+ background: incomplete || active
14981
+ ? "var(--sl-color-neutral-200)"
14982
+ : "var(--sl-color-success-500)",
14965
14983
  position: "relative",
14966
14984
  bottom: "0",
14967
14985
  left: "0",
@@ -14970,17 +14988,18 @@ function ProgressLine({ incomplete = false, active = false }) {
14970
14988
  columnGap: "50px",
14971
14989
  marginRight: "-2px",
14972
14990
  boxSizing: "content-box",
14991
+ opacity: invisible ? "0" : "1",
14973
14992
  } }));
14974
14993
  }
14975
- function Progress({ active, completed, incomplete }) {
14994
+ function Progress({ active, completed, incomplete, stage }) {
14976
14995
  return [
14977
- h(ProgressLine, { incomplete: incomplete }),
14978
- h(Dot, { active: active, completed: completed, incomplete: incomplete }),
14979
- h(ProgressLine, { incomplete: incomplete, active: active }),
14996
+ h(ProgressLine, { incomplete: incomplete, invisible: stage === 0 }),
14997
+ h(Dot, { active: active, completed: completed, incomplete: incomplete, stage: stage }),
14998
+ h(ProgressLine, { incomplete: incomplete, active: active, invisible: stage === 2 }),
14980
14999
  ];
14981
15000
  }
14982
15001
  function ProgressBar({ stageCount, currentStage, }) {
14983
- return (h("div", { style: { display: "flex", columnGap: "-2px" } }, Array.from(Array(stageCount).keys()).map((stage) => (h(Progress, { active: currentStage === stage, completed: currentStage > stage, incomplete: currentStage < stage })))));
15002
+ return (h("div", { style: { display: "flex", columnGap: "-2px" } }, Array.from(Array(stageCount).keys()).map((stage) => (h(Progress, { active: currentStage === stage, completed: currentStage > stage, incomplete: currentStage < stage, stage: stage })))));
14984
15003
  }
14985
15004
 
14986
15005
  const stageList = ["chooseReward", "chooseAmount", "confirmation", "success"];
@@ -15010,7 +15029,6 @@ function RewardExchangeView(props) {
15010
15029
  "&::part(base)": {
15011
15030
  boxShadow: "none",
15012
15031
  width: "100%",
15013
- // maxWidth: "350px",
15014
15032
  display: "flex",
15015
15033
  margin: "0 auto",
15016
15034
  },
@@ -15019,35 +15037,6 @@ function RewardExchangeView(props) {
15019
15037
  display: "flex",
15020
15038
  width: "100%",
15021
15039
  },
15022
- "& .text-area": {
15023
- textAlign: "left",
15024
- padding: "8px",
15025
- },
15026
- "& .title": {
15027
- fontSize: "var(--sl-font-size-medium)",
15028
- fontWeight: "var(--sl-font-weight-semibold)",
15029
- },
15030
- "& .amount": {
15031
- fontSize: "var(--sl-font-size-small)",
15032
- },
15033
- "& .error": {
15034
- fontSize: "var(--sl-font-size-small)",
15035
- color: "var(--sl-color-warning-500)",
15036
- },
15037
- "& .selected-outline": {
15038
- width: "18px",
15039
- height: "18px",
15040
- minWidth: "18px",
15041
- borderRadius: "50%",
15042
- background: "var(--sl-color-primary-500)",
15043
- position: "relative",
15044
- margin: "-9px",
15045
- left: "100%",
15046
- },
15047
- "& .selected-checkmark": {
15048
- position: "relative",
15049
- top: "-6px",
15050
- },
15051
15040
  },
15052
15041
  Drawer: {
15053
15042
  "&::part(base)": {
@@ -15065,14 +15054,14 @@ function RewardExchangeView(props) {
15065
15054
  FullImage: {
15066
15055
  objectFit: "contain",
15067
15056
  maxWidth: "100%",
15068
- height: "150px",
15057
+ height: "250px",
15069
15058
  display: "flex",
15070
15059
  margin: "0 auto",
15071
15060
  },
15072
15061
  PreviewImage: {
15073
15062
  objectFit: "contain",
15074
15063
  width: "120px",
15075
- height: "120px",
15064
+ height: "118px",
15076
15065
  flex: 0.33,
15077
15066
  },
15078
15067
  InputBox: {
@@ -15099,8 +15088,10 @@ function RewardExchangeView(props) {
15099
15088
  cursor: "pointer",
15100
15089
  },
15101
15090
  ProgressBar: {
15102
- fontSize: "80%",
15103
- marginBottom: "20px",
15091
+ maxWidth: "350px",
15092
+ width: "100%",
15093
+ margin: "auto",
15094
+ marginBottom: "var(--sl-spacing-xxx-large)",
15104
15095
  "& .text-area": {
15105
15096
  marginTop: "5px",
15106
15097
  display: "flex",
@@ -15109,16 +15100,133 @@ function RewardExchangeView(props) {
15109
15100
  whiteSpace: "nowrap",
15110
15101
  marginBottom: "6px",
15111
15102
  "& .text": {
15103
+ marginBottom: "var(--sl-spacing-x-small)",
15112
15104
  flex: "1 1 0",
15113
15105
  },
15114
15106
  "& .text.subdued": {
15115
- color: "#BDBDBD",
15107
+ color: "var(--sl-color-neutral-200)",
15116
15108
  },
15117
15109
  },
15118
15110
  },
15119
15111
  KutayCard: {
15112
+ display: "flex",
15113
+ userSelect: "none",
15114
+ height: "120px",
15120
15115
  "&::part(base)": {
15121
15116
  boxShadow: "none",
15117
+ width: "100%",
15118
+ },
15119
+ "&::part(body)": {
15120
+ display: "flex",
15121
+ padding: 0,
15122
+ },
15123
+ "& .selected-outline": {
15124
+ width: "18px",
15125
+ height: "18px",
15126
+ minWidth: "18px",
15127
+ borderRadius: "50%",
15128
+ background: "var(--sl-color-primary-500)",
15129
+ position: "relative",
15130
+ margin: "-9px",
15131
+ left: "100%",
15132
+ },
15133
+ "& .selected-checkmark": {
15134
+ position: "relative",
15135
+ left: "12%",
15136
+ top: "-29%",
15137
+ transform: "scale(0.8)",
15138
+ },
15139
+ },
15140
+ Square: {
15141
+ width: "120px",
15142
+ height: "118px",
15143
+ borderRadius: "3px 0 0 3px",
15144
+ "& .image": {
15145
+ width: "100%",
15146
+ height: "100%",
15147
+ objectFit: "contain",
15148
+ borderRadius: "inherit",
15149
+ },
15150
+ "& .image.subdued": {
15151
+ filter: "brightness(0.95)",
15152
+ opacity: "0.5",
15153
+ },
15154
+ },
15155
+ Image: {
15156
+ "& .image": {
15157
+ objectFit: "contain",
15158
+ width: "120px",
15159
+ height: "118px",
15160
+ flex: 0.33,
15161
+ },
15162
+ "& .image.black": {
15163
+ filter: "brightness(20%)",
15164
+ },
15165
+ },
15166
+ TextArea: {
15167
+ textAlign: "left",
15168
+ padding: "12px",
15169
+ "& .title": {
15170
+ fontSize: "16px",
15171
+ lineHeight: "20px",
15172
+ fontWeight: "600",
15173
+ color: "var(--sl-color-neutral-1000)",
15174
+ },
15175
+ "& .amount": {
15176
+ fontSize: "14px",
15177
+ lineHeight: "18px",
15178
+ marginTop: "8px",
15179
+ color: "var(--sl-color-neutral-500)",
15180
+ },
15181
+ "& .error": {
15182
+ fontSize: "14px",
15183
+ lineHeight: "18px",
15184
+ marginTop: "8px",
15185
+ fontWeight: "600",
15186
+ color: "var(--sl-color-warning-500)",
15187
+ },
15188
+ },
15189
+ ChooseAmount: {
15190
+ margin: "var(--sl-spacing-medium) 0",
15191
+ "& .title": {
15192
+ //fontSize: "var(--sl-font-size-large)",
15193
+ fontSize: "113%",
15194
+ fontWeight: "var(--sl-font-weight-semibold)",
15195
+ color: "var(--sl-color-neutral-1000)",
15196
+ },
15197
+ "& .points": {
15198
+ //fontSize: "var(--sl-font-size-large)",
15199
+ fontSize: "113%",
15200
+ fontWeight: "var(--sl-font-weight-semibold)",
15201
+ color: "var(--sl-color-sky-500)",
15202
+ },
15203
+ "& .description": {
15204
+ fontSize: "var(--sl-font-size-medium)",
15205
+ fontWeight: "var(--sl-font-weight-normal)",
15206
+ color: "var(--sl-color-neutral-500)",
15207
+ margin: "var(--sl-spacing-medium) 0",
15208
+ lineHeight: "var(--sl-line-height-dense)",
15209
+ marginTop: "var(--sl-spacing-xx-small)",
15210
+ },
15211
+ "& .space": {
15212
+ marginBottom: "var(--sl-spacing-xxx-large)",
15213
+ },
15214
+ },
15215
+ Success: {
15216
+ textAlign: "center",
15217
+ "& .title": {
15218
+ fontSize: "var(--sl-font-size-large)",
15219
+ fontWeight: "var(--sl-font-weight-semibold)",
15220
+ color: "var(--sl-color-neutral-1000)",
15221
+ },
15222
+ "& .description": {
15223
+ color: "var(--sl-color-neutral-400)",
15224
+ width: "100%",
15225
+ maxWidth: "350px",
15226
+ margin: "0 auto",
15227
+ lineHeight: "var(--sl-line-height-dense)",
15228
+ marginBottom: "var(--sl-spacing-xxx-large)",
15229
+ marginTop: "var(--sl-spacing-xx-small)",
15122
15230
  },
15123
15231
  },
15124
15232
  KutayButton: {
@@ -15151,6 +15259,9 @@ function RewardExchangeView(props) {
15151
15259
  "& .continue.right": {
15152
15260
  marginLeft: "auto",
15153
15261
  },
15262
+ "& .continue.center": {
15263
+ margin: "0 auto",
15264
+ },
15154
15265
  },
15155
15266
  };
15156
15267
  // JSS config
@@ -15186,7 +15297,7 @@ function RewardExchangeView(props) {
15186
15297
  id: "unavailableCode",
15187
15298
  defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15188
15299
  }, {
15189
- unavailableReason: step.unavailableReason || step.unavailableReasonCode,
15300
+ unavailableReason: step.unavailableReasonCode,
15190
15301
  }))))));
15191
15302
  })));
15192
15303
  }
@@ -15214,51 +15325,70 @@ function RewardExchangeView(props) {
15214
15325
  ? item.prettySourceValue
15215
15326
  : `${item.sourceMinValue} to ${item.prettySourceMaxValue}`;
15216
15327
  return (h("div", { key: item.key, class: item.available ? sheet.classes.CardContainer : "", style: style },
15217
- h("sl-card", { class: sheet.classes.Base, onClick: () => item.available &&
15328
+ h("sl-card", { class: sheet.classes.KutayCard, style: {
15329
+ cursor: item.unavailableReasonCode
15330
+ ? "not-allowed"
15331
+ : "pointer",
15332
+ }, onClick: () => item.available &&
15218
15333
  callbacks.setExchangeState({ selectedItem: item }) },
15219
15334
  item.key === (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.key) && (h("div", { class: "selected-outline" },
15220
15335
  h("div", { class: "selected-checkmark" },
15221
15336
  h(CheckMark, null)))),
15222
- // item?.imageUrl &&
15223
- h("img", { class: sheet.classes.PreviewImage, src: (item === null || item === void 0 ? void 0 : item.imageUrl) || getAssetPath("./assets/Reward-icon.png") }),
15224
- h("div", { class: "text-area" },
15225
- h("div", { class: "title" }, item.description),
15226
- h("div", { class: "amount" }, amount),
15227
- item.unavailableReasonCode && (h("div", { class: "error" }, intl.formatMessage({
15228
- id: "unavailableCode",
15229
- defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15230
- }, {
15231
- unavailableReason: item.unavailableReason ||
15232
- item.unavailableReasonCode,
15233
- })))))));
15337
+ h("div", { style: {
15338
+ display: "flex",
15339
+ width: "100%",
15340
+ borderRadius: "3px",
15341
+ background: item.unavailableReasonCode
15342
+ ? "rgba(0, 0, 0, 0.05)"
15343
+ : "rgba(0, 0, 0, 0)",
15344
+ } },
15345
+ h("div", { class: sheet.classes.Square },
15346
+ h("img", { class: item.unavailableReasonCode ? "image subdued" : "image", src: (item === null || item === void 0 ? void 0 : item.imageUrl) ||
15347
+ getAssetPath("./assets/placeholder.png") })),
15348
+ h("div", { class: sheet.classes.TextArea, style: {
15349
+ opacity: item.unavailableReasonCode ? "0.5" : "1",
15350
+ } },
15351
+ h("div", { class: "title" }, item.name),
15352
+ h("div", { class: "amount" }, amount),
15353
+ item.unavailableReasonCode && (h("div", { class: "error" }, intl.formatMessage({
15354
+ id: "unavailableCode",
15355
+ defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15356
+ }, {
15357
+ unavailableReason: item.unavailableReason ||
15358
+ item.unavailableReasonCode,
15359
+ }))))))));
15234
15360
  })),
15235
15361
  h("div", { class: sheet.classes.KutayButton },
15236
15362
  h("sl-button", { class: "continue right", size: "large", onClick: () => callbacks.setStage("chooseAmount"), disabled: !states.selectedItem }, "Continue")),
15237
15363
  ];
15238
15364
  }
15239
15365
  function chooseAmount() {
15240
- var _a;
15366
+ var _a, _b, _c;
15241
15367
  const input = getInput();
15242
15368
  const isDisabled = ((_a = states.selectedItem) === null || _a === void 0 ? void 0 : _a.ruleType) === "FIXED_GLOBAL_REWARD"
15243
15369
  ? false
15244
15370
  : input && !states.amount;
15245
15371
  return (h("div", null,
15246
- h("div", null,
15247
- //selectedItem?.imageUrl &&
15248
- h("img", { class: sheet.classes.FullImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15249
- getAssetPath("./assets/Reward-icon.png") })),
15250
- h("b", null, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description),
15251
- h("div", { class: sheet.classes.InputBox }, input),
15372
+ h("div", null, h("img", { class: sheet.classes.FullImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15373
+ getAssetPath("./assets/placeholder.png") })),
15374
+ h("div", { class: sheet.classes.ChooseAmount },
15375
+ h("div", { class: "title" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name),
15376
+ ((_b = states.selectedItem) === null || _b === void 0 ? void 0 : _b.ruleType) === "FIXED_GLOBAL_REWARD" ? (h("div", { class: "points" }, input)) : (h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description)),
15377
+ ((_c = states.selectedItem) === null || _c === void 0 ? void 0 : _c.ruleType) === "FIXED_GLOBAL_REWARD" ? (h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description)) : (h("div", { class: "points" }, input)),
15378
+ h("div", { class: "space" })),
15252
15379
  h("div", { class: sheet.classes.KutayButton },
15253
15380
  h("sl-button", { class: "cancel", size: "large", type: "text", onClick: () => callbacks.resetState() }, "Cancel"),
15254
15381
  h("sl-button", { class: "continue", size: "large", onClick: () => callbacks.setStage("confirmation"), disabled: isDisabled }, "Continue to confirmation"))));
15255
15382
  }
15256
15383
  function confirmation() {
15257
15384
  return (h("div", null,
15258
- h("h2", null, "Confirm and redeem"),
15259
- h("div", { style: { textAlign: "center" } },
15385
+ h("h2", { style: { margin: "20px 0" } }, "Confirm and redeem"),
15386
+ h("div", { style: {
15387
+ textAlign: "center",
15388
+ marginBottom: "var(--sl-spacing-xxx-large)",
15389
+ } },
15260
15390
  h("p", null,
15261
- h("b", null, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettySourceValue) || (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.prettySourceValue))),
15391
+ h("span", { style: { fontSize: "18px" } }, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettySourceValue) || (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.prettySourceValue))),
15262
15392
  h("p", null,
15263
15393
  h(ExchangeArrows, null)),
15264
15394
  h("div", { class: sheet.classes.CardContainer, style: {
@@ -15267,20 +15397,27 @@ function RewardExchangeView(props) {
15267
15397
  flex: "1",
15268
15398
  minWidth: "100%",
15269
15399
  } },
15270
- h("sl-card", { class: sheet.classes.Base },
15271
- h("img", { class: sheet.classes.PreviewImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15272
- getAssetPath("./assets/Reward-icon.png") }),
15273
- h("p", { style: { marginBottom: "0", flex: "1" } }, selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue)))),
15400
+ h("sl-card", { style: { width: "auto", maxWidth: "350px", margin: "auto" }, class: sheet.classes.KutayCard },
15401
+ h("div", { class: sheet.classes.Square },
15402
+ h("img", { class: "image", src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15403
+ getAssetPath("./assets/placeholder.png") })),
15404
+ h("div", { class: sheet.classes.TextArea, style: {
15405
+ lineHeight: "18px",
15406
+ alignSelf: "center",
15407
+ } }, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue) ? (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue) +
15408
+ " " + (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name)
15409
+ : selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name)))),
15274
15410
  h("div", { class: sheet.classes.KutayButton },
15275
15411
  h("sl-button", { class: "cancel", type: "text", size: "large", onClick: () => callbacks.setStage("chooseAmount") }, "Back"),
15276
15412
  h("sl-button", { class: "continue", size: "large", onClick: callbacks.exchangeReward }, "Redeem"))));
15277
15413
  }
15278
15414
  function success() {
15279
- return (h("div", { style: { textAlign: "center" } },
15280
- h("img", { class: sheet.classes.FullImage, src: getAssetPath("./assets/Reward-icon.png") }),
15281
- h("p", { style: { color: "forestgreen" } }, "Reward Redeemed"),
15282
- (data === null || data === void 0 ? void 0 : data.fuelTankCode) && h("pre", null, data === null || data === void 0 ? void 0 : data.fuelTankCode),
15283
- h("sl-button", { class: "continue", type: "primary", size: "large", onClick: () => callbacks.resetState(true) }, "Done")));
15415
+ return (h("div", { class: sheet.classes.Success },
15416
+ h(Gift, null),
15417
+ h("div", { class: "title" }, "Reward Redeemed"),
15418
+ h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description),
15419
+ h("div", { class: sheet.classes.KutayButton },
15420
+ h("sl-button", { class: "continue center", type: "primary", size: "large", onClick: () => callbacks.resetState(true) }, "Done"))));
15284
15421
  }
15285
15422
  const stages = {
15286
15423
  chooseReward: () => chooseReward(),
@@ -15293,7 +15430,7 @@ function RewardExchangeView(props) {
15293
15430
  const stageNumber = stageList.indexOf(states.redeemStage);
15294
15431
  return (h("div", { class: sheet.classes.ProgressBar },
15295
15432
  h("div", { class: "text-area" }, Object.keys(stageProgressList).map((stage) => {
15296
- if (stage === states.redeemStage) {
15433
+ if (stageList.indexOf(stage) <= stageNumber) {
15297
15434
  return h("span", { class: "text" }, stageProgressList[stage]);
15298
15435
  }
15299
15436
  else {
@@ -15302,25 +15439,16 @@ function RewardExchangeView(props) {
15302
15439
  })),
15303
15440
  h(ProgressBar, { stageCount: 3, currentStage: stageNumber })));
15304
15441
  }
15305
- // const BackButton = () => {
15306
- // if (states.redeemStage === "success") return "";
15307
- // let previousStage: Stages = "";
15308
- // if (states.redeemStage === "confirmation") {
15309
- // previousStage = "chooseAmount";
15310
- // } else if (states.redeemStage === "chooseAmount") {
15311
- // previousStage = "chooseReward";
15312
- // }
15313
- // return (
15314
- // <div slot="label">
15315
- // <a
15316
- // style={{ cursor: "pointer", fontSize: "80%", color: "#858585" }}
15317
- // onClick={() => callbacks.setStage(previousStage)}
15318
- // >
15319
- // <LeftArrow /> Back
15320
- // </a>
15321
- // </div>
15322
- // );
15323
- // };
15442
+ function loading() {
15443
+ return (h("div", { style: {
15444
+ display: "flex",
15445
+ height: "400px",
15446
+ alignItems: "center",
15447
+ justifyContent: "center",
15448
+ } },
15449
+ h("div", { style: { transform: "scale(5)" } },
15450
+ h("sl-spinner", null))));
15451
+ }
15324
15452
  function errorMessage() {
15325
15453
  return (h("sl-alert", { type: "danger", open: true },
15326
15454
  h("sl-icon", { slot: "icon", name: "exclamation-octagon" }),
@@ -15330,6 +15458,7 @@ function RewardExchangeView(props) {
15330
15458
  h("style", { type: "text/css" }, styleString),
15331
15459
  h("div", null,
15332
15460
  stageMap(),
15461
+ states.loading && loading(),
15333
15462
  states.exchangeError && errorMessage(),
15334
15463
  currentStage && currentStage())));
15335
15464
  }
@@ -21468,23 +21597,20 @@ function TaskCardView(props) {
21468
21597
  const style = {
21469
21598
  HostBlock: HostBlock,
21470
21599
  TaskCard: {
21471
- "& .main > div": {
21472
- margin: "var(--sl-spacing-medium)",
21473
- },
21474
21600
  "& .main": {
21475
21601
  position: "relative",
21476
21602
  boxSizing: "border-box",
21477
21603
  minWidth: "347px",
21478
21604
  background: "var(--sl-color-neutral-0)",
21479
- border: "1px solid var(--sl-color-neutral-300)",
21605
+ border: "1px solid var(--sl-color-neutral-200)",
21480
21606
  borderRadius: "var(--sl-border-radius-medium)",
21481
21607
  fontSize: "var(--sl-font-size-small)",
21482
21608
  lineHeight: "var(--sl-line-height-dense)",
21483
21609
  color: "var(--sl-color-neutral-600)",
21484
21610
  },
21485
21611
  "& .main.complete": {
21486
- background: "var(--sl-color-success-50)",
21487
- borderColor: "var(--sl-color-success-700)",
21612
+ background: "var(--sl-color-primary-50)",
21613
+ borderColor: "var(--sl-color-primary-500)",
21488
21614
  },
21489
21615
  "& .main.expired": {
21490
21616
  color: "var(--sl-color-neutral-400)",
@@ -21497,6 +21623,12 @@ function TaskCardView(props) {
21497
21623
  "& .black": {
21498
21624
  color: "var(--sl-color-neutral-1000)",
21499
21625
  },
21626
+ "& .container": {
21627
+ margin: "var(--sl-spacing-medium)",
21628
+ },
21629
+ "& .container > div": {
21630
+ margin: "var(--sl-spacing-medium) 0",
21631
+ },
21500
21632
  },
21501
21633
  Header: {
21502
21634
  display: "flex",
@@ -21584,34 +21716,39 @@ function TaskCardView(props) {
21584
21716
  ? "main complete"
21585
21717
  : "main" },
21586
21718
  h("style", { type: "text/css" }, styleString),
21587
- h("div", { class: sheet.classes.Header }, props.loading ? (h("sl-skeleton", { style: { width: "22%", margin: "0", height: "12px" } })) : (h("div", null,
21588
- taskUnavailable && (h("div", { class: "end" }, "Available " +
21589
- dateStart.toLocaleString(luxon.DateTime.DATE_MED).split(",")[0] +
21590
- " - " +
21591
- dateEnd.toLocaleString(luxon.DateTime.DATE_MED).split(",")[0])),
21592
- showComplete && (h("span", { class: taskUnavailable ? "icon neutral" : "icon" }, checkmark_circle$1)),
21593
- h("span", { class: taskUnavailable ? "value" : "value black" }, props.rewardAmount),
21594
- h("span", { class: "text" }, props.rewardUnit)))),
21595
- props.loading ? (h("sl-skeleton", { style: { width: "42%", margin: "0 16px", height: "12px" } })) : (h("div", { class: taskUnavailable ? "title" : "title black" }, props.cardTitle)),
21596
- props.loading ? (h("sl-skeleton", { style: { margin: "12px 16px", height: "12px" } })) : (h(Details, Object.assign({}, props))),
21597
- props.showProgressBar && props.loading ? (h("sl-skeleton", { style: { margin: "0 16px", height: "12px" } })) : (props.showProgressBar && (h(ProgressBarView, Object.assign({}, props, { complete: taskComplete, expired: taskUnavailable })))),
21598
- h("div", { class: sheet.classes.Footer }, props.loading ? (h("sl-skeleton", { style: { width: "25%", marginLeft: "auto", height: "12px" } })) : (h("div", { style: { display: "contents" } },
21599
- h("span", { class: "text" },
21600
- props.repeatable && (h("div", null,
21601
- h("span", { class: repetitions > 0
21602
- ? taskUnavailable
21603
- ? "icon neutral"
21604
- : "icon success"
21605
- : "icon" }, arrow_left_right$1),
21606
- h("span", { class: repetitions > 0
21607
- ? taskUnavailable
21608
- ? "neutral"
21609
- : "success"
21610
- : "" }, "Completed " + repetitions + " times"))),
21611
- props.showExpiry && !taskUnavailable && (h("span", null, "Ends " + dateEnd.toLocaleString(luxon.DateTime.DATE_FULL)))),
21612
- h("sl-button", { class: taskComplete || taskUnavailable ? "action disabled" : "action", type: "primary", size: "small", onClick: () => props.openNewTab
21613
- ? window.open(props.buttonLink)
21614
- : window.open(props.buttonLink, "_self"), disabled: taskComplete || taskUnavailable }, props.buttonText)))))));
21719
+ h("div", { class: "container", style: { opacity: "1" } },
21720
+ h("div", { class: sheet.classes.Header }, props.loading ? (h("sl-skeleton", { style: { width: "22%", margin: "0" } })) : (h("div", null,
21721
+ taskUnavailable && (h("div", { class: "end" }, "Available " +
21722
+ dateStart
21723
+ .toLocaleString(luxon.DateTime.DATE_MED)
21724
+ .split(",")[0] +
21725
+ " - " +
21726
+ dateEnd.toLocaleString(luxon.DateTime.DATE_MED).split(",")[0])),
21727
+ showComplete && (h("span", { class: taskUnavailable ? "icon neutral" : "icon" }, checkmark_circle$1)),
21728
+ h("span", { class: taskUnavailable ? "value" : "value black" }, props.rewardAmount),
21729
+ h("span", { class: "text" }, props.rewardUnit)))),
21730
+ props.loading ? (h("sl-skeleton", { style: { width: "42%", margin: "0 var(--sl-spacing-medium)" } })) : (h("div", { class: taskUnavailable ? "title" : "title black" }, props.cardTitle)),
21731
+ props.loading ? (h("sl-skeleton", { style: { margin: "var(--sl-spacing-medium)" } })) : (h(Details, Object.assign({}, props))),
21732
+ props.showProgressBar && props.loading ? (h("sl-skeleton", { style: { margin: "0 var(--sl-spacing-medium)" } })) : (props.showProgressBar && (h(ProgressBarView, Object.assign({}, props, { complete: taskComplete, expired: taskUnavailable })))),
21733
+ h("div", { class: sheet.classes.Footer }, props.loading ? (h("sl-skeleton", { style: { width: "25%", marginLeft: "auto" } })) : (h("div", { style: { display: "contents" } },
21734
+ h("span", { class: "text" },
21735
+ props.repeatable && (h("div", null,
21736
+ h("span", { class: repetitions > 0
21737
+ ? taskUnavailable
21738
+ ? "icon neutral"
21739
+ : "icon success"
21740
+ : "icon" }, arrow_left_right$1),
21741
+ h("span", { class: repetitions > 0
21742
+ ? taskUnavailable
21743
+ ? "neutral"
21744
+ : "success"
21745
+ : "" }, "Completed " + repetitions + " times"))),
21746
+ props.showExpiry && !taskUnavailable && (h("span", null, "Ends " + dateEnd.toLocaleString(luxon.DateTime.DATE_FULL)))),
21747
+ h("sl-button", { class: taskComplete || taskUnavailable
21748
+ ? "action disabled"
21749
+ : "action", type: "primary", size: "small", onClick: () => props.openNewTab
21750
+ ? window.open(props.buttonLink)
21751
+ : window.open(props.buttonLink, "_parent"), disabled: taskComplete || taskUnavailable }, props.buttonText))))))));
21615
21752
  }
21616
21753
  function Details(props) {
21617
21754
  const style = {
@@ -25488,19 +25625,19 @@ const NameFields$1 = /*#__PURE__*/Object.freeze({
25488
25625
  NameFieldsWithErrors: NameFieldsWithErrors
25489
25626
  });
25490
25627
 
25491
- const baseResponse = (data, selected = null) => ({
25628
+ const baseResponse = (data, stage = "chooseReward", selectedItem = null, selectedStep = null, error = false, loading = false) => ({
25492
25629
  states: {
25493
25630
  content: {
25494
25631
  text: {
25495
25632
  notAvailableError: "{unavailableReason, select, US_TAX {US Tax limit} INSUFFICIENT_REDEEMABLE_CREDIT {Not enough points} other {Not available} }",
25496
25633
  },
25497
25634
  },
25498
- redeemStage: "chooseReward",
25635
+ redeemStage: stage,
25499
25636
  amount: 0,
25500
- exchangeError: false,
25501
- loading: false,
25502
- selectedItem: selected,
25503
- selectedStep: null,
25637
+ exchangeError: error,
25638
+ loading: loading,
25639
+ selectedItem: selectedItem,
25640
+ selectedStep: selectedStep,
25504
25641
  },
25505
25642
  data: {
25506
25643
  exchangeList: data,
@@ -25517,7 +25654,7 @@ const baseResponse = (data, selected = null) => ({
25517
25654
  const baseReward$2 = {
25518
25655
  key: "",
25519
25656
  name: "",
25520
- description: "",
25657
+ description: "Description of reward. Lorem ipsum dolor sit amet, consectetur adipiscing. Id nec semper sapien dignissim rhoncus nunc.",
25521
25658
  imageUrl: "",
25522
25659
  available: true,
25523
25660
  unavailableReason: null,
@@ -25552,8 +25689,8 @@ const selected = {
25552
25689
  const imageUrl = (props) => ({
25553
25690
  imageUrl: props,
25554
25691
  });
25555
- const description = (props) => ({
25556
- description: props,
25692
+ const name = (props) => ({
25693
+ name: props,
25557
25694
  });
25558
25695
  const fixedValue = (props) => ({
25559
25696
  prettySourceValue: props,
@@ -25568,54 +25705,54 @@ const variableValue = (min, max, text) => ({
25568
25705
  const data = [
25569
25706
  {
25570
25707
  ...baseReward$2,
25571
- ...description("Free swag with a promo code"),
25572
- ...imageUrl("https://i.imgur.com/Ds7M19I.png"),
25708
+ ...name("Free swag with a promo code"),
25709
+ ...imageUrl("https://i.imgur.com/n7vC4BR.png"),
25573
25710
  ...fixedValue("40 SaaSquatch Points"),
25574
25711
  },
25575
25712
  {
25576
25713
  ...baseReward$2,
25577
25714
  ...selected,
25578
- ...description("Visa® Prepaid Card USD"),
25579
- ...imageUrl("https://i.imgur.com/4s3q2zz.png"),
25715
+ ...name("Visa® Prepaid Card USD"),
25716
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25580
25717
  ...variableValue(20, 80, "SaaSquatch Points"),
25581
25718
  },
25582
25719
  {
25583
25720
  ...baseReward$2,
25584
- ...description("A very exclusive gift box"),
25585
- ...imageUrl("https://i.imgur.com/XuiJi4l.png"),
25721
+ ...name("A very exclusive gift box"),
25722
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
25586
25723
  ...fixedValue("30 SaaSquatch Points"),
25587
25724
  },
25588
25725
  {
25589
25726
  ...baseReward$2,
25590
- ...description("$50 Store credit"),
25727
+ ...name("$50 Store credit"),
25591
25728
  ...imageUrl("https://i.imgur.com/WkCMVSE.png"),
25592
25729
  ...fixedValue("100 SaaSquatch Points"),
25593
25730
  },
25594
25731
  {
25595
25732
  ...baseReward$2,
25596
- ...description("Variable amount of store credit"),
25733
+ ...name("Variable amount of store credit"),
25597
25734
  ...imageUrl("https://i.imgur.com/Jn2fE0s.png"),
25598
25735
  ...variableValue(20, 100, "SaaSquatch Points"),
25599
25736
  },
25600
25737
  {
25601
25738
  ...baseReward$2,
25602
25739
  ...notEnoughPoints,
25603
- ...description("A very rare cactus"),
25604
- ...imageUrl("https://i.imgur.com/CvCdpXc.png"),
25740
+ ...name("A very rare cactus"),
25741
+ ...imageUrl("https://i.imgur.com/hhlF2Ey.png"),
25605
25742
  ...fixedValue("2000 SaaSquatch Points"),
25606
25743
  },
25607
25744
  {
25608
25745
  ...baseReward$2,
25609
25746
  ...usTax,
25610
- ...description("$1000 Store credit"),
25611
- ...imageUrl("https://i.imgur.com/I9FCh9Z.png"),
25747
+ ...name("$1000 Store credit"),
25748
+ ...imageUrl("https://i.imgur.com/y9HSls1.png"),
25612
25749
  ...fixedValue("2000 SaaSquatch Points"),
25613
25750
  },
25614
25751
  {
25615
25752
  ...baseReward$2,
25616
25753
  ...notEnoughPoints,
25617
- ...description("A holiday gift box"),
25618
- ...imageUrl("https://i.imgur.com/HBJS1WH.png"),
25754
+ ...name("A holiday gift box"),
25755
+ ...imageUrl("https://i.imgur.com/dWEdB3p.png"),
25619
25756
  ...fixedValue("100 SaaSquatch Points"),
25620
25757
  },
25621
25758
  ];
@@ -25623,142 +25760,3423 @@ const rewardExchange = {
25623
25760
  ...baseResponse(data),
25624
25761
  };
25625
25762
  const rewardExchangeSelected = {
25626
- ...baseResponse(data, {
25763
+ ...baseResponse(data, "chooseReward", {
25627
25764
  ...baseReward$2,
25628
25765
  ...selected,
25629
- ...description("Visa® Prepaid Card USD"),
25630
- ...imageUrl("https://i.imgur.com/4s3q2zz.png"),
25766
+ ...name("Visa® Prepaid Card USD"),
25767
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25631
25768
  ...variableValue(20, 80, "SaaSquatch Points"),
25632
25769
  }),
25633
25770
  };
25634
- const test2 = {
25635
- states: {
25636
- content: {
25637
- text: {
25638
- buttonText: "Exchange Rewards",
25639
- ignored: true,
25640
- },
25641
- },
25642
- redeemStage: "chooseAmount",
25643
- amount: 0,
25644
- exchangeError: false,
25645
- loading: false,
25646
- selectedItem: {
25647
- key: "r4",
25648
- name: "Salmon Coins",
25649
- description: "Points for Salmon Coins",
25650
- imageUrl: "data:image/jpeg;base64,/9j/4AAQSkZJRgABAQAAAQABAAD/2wCEAAoHCBUWFRgWFRYYGRgZGh4cHBocHR4aHxwdGRwZHBwfHh4cIS4lHB4rHxoYJjgnKy8xNTU1GiQ7QD00Py40NTEBDAwMEA8QHhISHzQrJCs0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NDQ0NP/AABEIAIABiQMBIgACEQEDEQH/xAAcAAEAAQUBAQAAAAAAAAAAAAAABAECAwUGBwj/xAA+EAABAwICBgYHBwQCAwAAAAABAAIRAyEEMQUSQVFhcQYTgZGhsQciMkJScvAUYoKSwdHhorLC8SMzFUNj/8QAGAEBAQEBAQAAAAAAAAAAAAAAAAECAwT/xAAfEQEBAQEBAQEAAwEBAAAAAAAAARECEiExE0FRYQP/2gAMAwEAAhEDEQA/APZkREBERAREQEREBERAREQEREBERAREQERY6jw0EkgACSTYADMk7AgvVjHgzBBixgzBXmfSjpqapNLDuLaeTqgs58Zhl/Vbx28BnA0Lj3UXNcx0G0tmxHwkW1tvLhks3qRZHryqtdonSjK7dZtnCzmzJaf1HFbFWXUERFQREQEREBERAREQEREBERAREQEREBERAREQEREBERAREQEREBERAREQEREBERAREQEREBFSVqdNafoYVoNaoAT7LBdzvlaLxxyG0oNlUqBoLnEAASSTAAFySTkF5H0z6WHEuNKiSKANx7JqkXl20MFoHfsAidKemVTFeo31KPwAgl0ZF7hY7IaLA39aBHNsIO0cv34eaCVSeBlcnblb/FqnYatxz3WLhw+FnHMrVMfx7/MjyCkMI5znx+Y7flCx1NajqNGaUdTIex2qRYRkRuj3h+y9D0Lp2nXETq1APWb5xv5ZjxXj9Ovt8dsdmXIHmVKw+OIg62rGWqQIINvWs1vZJWeZeVuV7gi5Xoj0j+0g03kGowSSMnNkCTYAOkjK17cOqXSXWBERUEREBERAREQEREBERAREQEREBERBRFjq1WtaXOcGtAkuJAAG8k2C5LS/TukyW0GGq74j6jO83PcAd6DslQFeI6Y6VYmvOvWcG/BS9RvIwZcODiV1vomonq69QWa57Wht82N1i6+ZIe0diD0JERAREQEREBERARFgxOJZTaX1HtY0ZucQAOZNkGdFxmkvSJg2SGa9Y5eo2G/mdEji2VzmO9JWIdalTp0xvcS93+IHcUHqyiYvH0qQmpUYwb3ua3+4rxTG9IsbV9vEVI3NPVjuZC1XUyST7RvfM85zQezYrptgGW68OO5jXP8AFojxWoxHpMw49ilVfxOowH+onwXmzcKdqudhrG0oOyr+k+qfYwzG/M9zvANatfX9ImOd7Ios5NJI/M4+S55lCQREFXvoaosJU0ScV0u0g+ZxL28GtYzxa2fFaKs173F73ue45uc4uceZcSStuyiI8+zmqfZNvDJNGlGGVww5W21BFh2eCubSMAxCmrjUCkruqK2v2dUNAxZTVazUdlJU7A6Rq0rs1J3vp06jvzPYXeKyCiQL5jzhUZhrXAngg2+H6c41lmmnx/42j+2FLZ6RcbtFA/gd+j1z4o8Fa2lJNoTTHV0/SVifeo0Ty1m+bipdL0nO9/DDm2p+hZ+q4p9A7B3rG7D7ldR6NR9JlA+1Qqj5Sx3m4KfR9IOCd7RqM+ZhP9msvKjQVr6B2Jo9oodLcC/LEsHzSz+8BbLDaRo1P+urTf8AK9rvIrwQUSrTSDtxummPohF4Dh8VXZ/11qrAPhe9o7gYUmp0kxzmln2mrB3EB35wNYd6uo9oxukqNETWqspg5a7mtnlJute3pbgSYGJp9pgd5svC6mHc5xcXFzjmXEknmTcqVo3Btc8Nq1RSZHt6jn8hqtuVLf8AFkfQVGs17Q5rg5pyIIIPIjNZFxnQgYXDsdTZjadUvdrBtqcWizC4mTtPALswVZUVREVBEWr0tpujh2k1HXiQwXc7k3ntMBBs1y+nOmFKjLaUVXjODDW/M7aeA3XIXHae6XVq8tE06RkBjbufwc7ad7R6oyOstA8SBrmBsYMvC7nclm0TdJ6Zq4l01Hl8GzR6rGn7rbxzu6+ajOpW9cwPhH6/RVGHdYcBJ7hYfVlewxlnvzPfkPBc63GsxNODkQBsi8cBGXYAvbui+jxQwtFgEHUDncXP9Z09pK8r6N4QV8XSY4Swv1nWMEMBeQTx1YjivbF1n4wIiKgiIgIoOkdJUaDdatUaxuzWMExsAzceAuuG016RjduFpz/9KgMfhYDPeRyQeh1KgaC5xAAuSTAA4k5LldJ9PsHSkNc6s7dTEt/OYaRyleZY/FVq/rYis525rnta0cmWaOwBR6VJvZs4q4mur0j6Q8U+RRYykN//AGO4GXANH5SuWxlWrWdr13ve7e8zHyjJo4CFIpU5dnEe7CzMpgkGO02gBTYIlHCNOWaq7CxnCmsLGky4H9O7MqSXMd7Jnz7Vf0a84Y7M1e3DAGTErOQcoVGAgXud6xeo1jC+iDsmLgHfCyNZa43LIAeCrqu4f6UvS4w06bRIBvtG76/VXhuYiwyWRtMzO+yv1Dv3qejEcuEScuSqy4BG0LK6mdpsVXqSs+lxHfRsdWATwVWstfwUjqztOfJWll4m5k5d6noxH1A4R5KoZsj+Fnbh4yt2BVFMzF8s7J6XGBzIyEo1ucgjmpXUcSqvpwJv5p6MRXU4KPZAsCeA4qUKMDWEmc8haMzKvFDinpMQxTtzWGphSQIMR4rZ9TxKtFDVMTmdt8k9JiA6lA9bZmVa2nrXGV4Wy6kn/SCieCejGt+z7xmqNw42dotmtmKBz3oaJ2Af7V0xrRQWB2GcTIIjzW2dhycx9cVUUjuWtRqeom8Kx1K4EEzt3dq2tXCuIgerfNXtoHIieJj9E1WndhQsuHxFWkJp1XsH3HOb4A3WxNI5kW7FjfhpvfMfUKWkS8J0xxzBPWB42B7GnxbB8Vs6HpHrCzsOxzvuuczwId5rROpDYIUX7MdbIRGe8/tmp7MbLSXS/F1zGv1TDbVpktJ5vnW7iBwWrNSZtebn6vzOfFVdRGcXG/gsRBDshzlX2YvNM5iBPvHyaNg4eG1YjTGwEnaTf67SFKaRffynyusVWmTcz2sJ7tdat2J/axur7zm8p1u5rLDvV9erAsCecADs/hVYHDIv7NRo8FHxTnfAT+L9LrEm1b+Oz9GGj9Z9XEOAloFNsTm71nk615jU/MV6UuX9HmC6vBMMQajnVD+Iw3+lrV1C7MiIiAuO9IHSKthWU20GEvqlw19XWDA3VyGRcS4RNrGxXYrnOk2lMTRNPqKTHtdOs5xIAgthoIyLpME2tkUHj+OOIc7rq7aznEj13tI5Aa1o3NFuCuwrdbWE6riLS3IjxFoyBXqjelDXtLK+FqesIcwalQXzBDi0kfhXKaVwNBjvUa4U3e44arqZ+66TLfEdsiejHLvwuIBa6wMga4aHsc0DIyQGk2sYNjvKtpawqOLWwwxbjAkwbiTPet7UoPp2JljvZeNvBw913gdig1KV5XK3LrUmzGLDTrtaTMmOU2/lS37ABbb/AAsOFoE1GQPeb5hSXsHblO1T18Xz9Ryxu5VwLTDzuj/L9JVXtUmizOMnF3c0GPM9y1OrSxjartiFiqAufVakUoP1hJEZrK6mSRBi97Z71cwZdir9d4WNXFdVXNEqx0ERvVW2Fgp6XyuLFY5h1gda0XEZ9queyYuREG31krnH+fruU9LimomoMz2LIFR0C5OXYI4p6MYxTOtMjVjLirnTcNF4tOXarmNMkmI2b+9Zm7Pr6/hPRjBTa7Ii+/YVke0xbPYs4CAJ6MYg3KyvaxXGYnM7BvVackXEHd2/68U9GMb6YIIOX6K3qwIHYJ+tyyUmOvr6udonLjO1XagsSMtvZCejGCjh2tsNu03klZQxYsSx9tRwF7yFlkNgE3yE7SrOk8mp9fXasLcOQ4nXJnJuwfWaz6xmIsRnbPkriP3VnR5Y9S/P/StbB+uav2fXFY2MDRAgBb1PK5zARBEqxrCTIJABiIF/4V7XAHNXdYO1X6mLKtEOBaQSCLqw4Yauq31Rsjv2rKao+vFKeHcSS1r3TsDSc+Q4KWUYxTsNvNW1mgA2mPFTv/H4g5Uan5CPNYq2isRBmg8j5Z8FPPRsatzgXECLfV9ywOpif45fXapr6DwdUtLTuIIPcVb1WrcxuG4fynMpsQyyPLb+gPkotRzQbhp5kDwICmVXjeQOYjucIBUWq8jcR94FvcW2K758xz36xlrfgj8MjwJUSs1v3B4f3BSw5o90s4tgjvb+yxYydWQ6RxA8wYWZ+rXqfo9x/WYNjSQTSJpmDsEFv9JA7CuqXlPotx5biKlLJr6etH3mERH4XOmNwXqy6siIiArHNBEG4KvRBp8XoNjrsJpncAHM7WnIfKWrVVKGKpWcwPZvpme9jr90rrEQcBUbQMyzVM3nWaAeAB1QeS1dbRjM2vjg6/iP2XpOJwTH+00ExEizo5i8cFrH9Gqcy2AeLWu8gFiytS44puHYy4cHOi0ZDZKgVMPORlegO0PUbZmpHzOb4AR4qK/RNfiB90yfF58li87+rOscTTwT5HqnmRAHG+alDDRyFu/+JK6N2BLTdpHF0yVKo4VgF4KvM35C2OKqtDZLnBvMxMhRnYpnuBzvlB8yt5pvo/TZrVWAu2lusZ7Jz5LRMqUzsaOcHzlZ65y/VnSprH4I+ZzR5lOsd8LOx7VIAaBIcR2D9WfqrqYJMes7dZpn8oXOyNzWClUJIBaR4/QUkMU+ngY4k5/sPFX/AGXZ9bFm81djWOaRECZsrw1T/syDDeaxjSG1nmq9XkpzMMq9QfBXE1DDFka3fkpXUHcqmgdmcJhqKykGiGgDkq6ql9QqUsKAIE773vxKmLqMGqrWKaMOrm4fbClVE1FaaUrYjDqvUKfVa80bz3KvUeS2LcNfKyzNw4GasqfGpOFJtcRe23f2LL9iO7gtoQR7LHu+Vrj5BafFaRfJaPVjOxkcxs7V2541z66g/CATrEfsoVUMBzJ2WvdYMRUnN2tO0u1e45FYX1CPasD8Q1f62+qe0Ld5iemdzm7bc7HslZcO9jXAlrXfdfrDuDSCe2QorfxAb7Fve2W94UzDwLWjgBHhY9wUsw/XUaG0i1zmsZh2NnMtgQNp9n9V1C0fR3AajNciC4WERDc9m+3gt4u/O59crm/FURFpEfE4Zjxqva1w3ET3blz2keh9N96bi0/C712nhJ9bvJ5LqUQeTaX6P1qMl7SGj32+s3tOwcHRwXPPBbmNXc5t2nmNy95IXM6W6H0Ksup/8Tz8Ilp5sy7oWbB5WwbQPxM/Vv8AEJUo6wkAO4tMH9j2Qttpbo5Xw51ns9Uf+xhJb2mJbycAOK1vWA3zO8eq79ncslj7rSnRrGNw+Mo1HEta18O1rQ14LHE2yAdO3Je7r54xFyYMjcQAe79oXsvQfSn2jCUy6demOrfOZLAIPa3VPMncuusujREQEREBERAREQEREFpaCIN1FqaPpu92OVvJTEQaitoVpye4c4P7LWV+i0/A7iRB7wupRZvMqy2OHf0OvIZB3tcP8lJo6EcwWYRvPtE9sldeiniL6rlRgnDNju4qx2F4fWxdakJeIeq5A0An2ZdaWDcO5WdQz4W9wWP4v+r7rlxhQs1LBt2roDhGfC3uT7Iz4fNanGJ6rmK1WgDAlxytsO6+SjPxLB7rwOQPkV02J0PRqTrNgxGsLOHbt5GQua0hoavSksHWM+7JcObMxzaT8oTrn5+Lz1/qjcVSPvgfN6v91ipjKQNxF1znXcOBvEcJH6iVJ0bpHq3TAc33mOEC+4gEA5XcvPLNyt38+N6KKuZQnIE8gt9hyxzQ5oaQdwH1KkQuv8Mv9se655mCecmHtt5rMNFvPwt8fJbtFqf+PKe61bNED3nk8gB5ypFLR7GmYk/eMxyGSmItTjmfkS21VRcXgqdQRUY10ZEi45HMHkpSLaOS0l0Qa6TRcWnc4m/4oJI+YOXLYvRVagfWa5g+JsBp5gkscTwIPBeqqhErN5laleTUmkH2Rzb/AMZ7Wmx71v8AQOB6yqJ9lvrOnbGw75MeK6itoOg6/VgH7stHcLHuUjBYFlIEMETcnMlSc1fXxMREW2BERAREQEREBc3pbodha8nV6t596nDZ5tjVPOJ4rpEQeU6U9H+Ibem5lYbB7Du5xj+rsW89HuiMThzVFZmoxwbAJBlwJuIOUE35dncopn1dVREVQREQEREBERAREQEREBERAREQEREBERAREQEREGuxuiqNW72An4hLXfmbBjhktFi+h+2nV5B4y/EyI7l1qLN5l/VlsaDo9oytQLmvc0sI2OJOtaDBYItO07Fv0RWTJhbqqIiqCIiAiIgIiICIiAiIgIiICIiAiIgIiICIiAiIg//Z",
25651
- available: true,
25652
- unavailableReason: null,
25653
- unavailableReasonCode: null,
25654
- ruleType: "VARIABLE_CREDIT_REWARD",
25655
- sourceUnit: "POINT",
25656
- sourceValue: null,
25657
- prettySourceValue: null,
25658
- sourceMinValue: 1,
25659
- prettySourceMinValue: "1 Point",
25660
- sourceMaxValue: 100,
25661
- prettySourceMaxValue: "100 Points",
25662
- destinationMinValue: 1,
25663
- prettyDestinationMinValue: "1 Salmon Coin",
25664
- destinationMaxValue: 100,
25665
- prettyDestinationMaxValue: "100 Salmons",
25666
- globalRewardKey: null,
25667
- destinationUnit: "TESTUNIT",
25668
- steps: [
25669
- {
25670
- sourceValue: 1,
25671
- prettySourceValue: "1 Point",
25672
- destinationValue: 1,
25673
- prettyDestinationValue: "1 Salmon Coin",
25674
- available: true,
25675
- unavailableReasonCode: null,
25676
- unavailableReason: "",
25677
- },
25678
- {
25679
- sourceValue: 2,
25680
- prettySourceValue: "2 Points",
25681
- destinationValue: 2,
25682
- prettyDestinationValue: "2 Salmons",
25683
- available: true,
25684
- unavailableReasonCode: null,
25685
- unavailableReason: "",
25686
- },
25687
- {
25688
- sourceValue: 3,
25689
- prettySourceValue: "3 Points",
25690
- destinationValue: 3,
25691
- prettyDestinationValue: "3 Salmons",
25692
- available: true,
25693
- unavailableReasonCode: null,
25694
- unavailableReason: "",
25695
- },
25696
- {
25697
- sourceValue: 4,
25698
- prettySourceValue: "4 Points",
25699
- destinationValue: 4,
25700
- prettyDestinationValue: "4 Salmons",
25701
- available: true,
25702
- unavailableReasonCode: null,
25703
- unavailableReason: "",
25704
- },
25705
- {
25706
- sourceValue: 5,
25707
- prettySourceValue: "5 Points",
25708
- destinationValue: 5,
25709
- prettyDestinationValue: "5 Salmons",
25710
- available: true,
25711
- unavailableReasonCode: null,
25712
- unavailableReason: "",
25713
- },
25714
- ],
25715
- },
25716
- selectedStep: null,
25717
- },
25718
- data: {
25719
- exchangeList: null,
25720
- },
25721
- callbacks: {
25722
- exchangeReward: null,
25723
- resetState: null,
25724
- setStage: null,
25725
- setExchangeState: null,
25726
- refs: {
25727
- drawerRef: {},
25728
- },
25729
- },
25730
- refs: null,
25771
+ const baseStep = (dst, dstUnit, src, srcUnit, available = true) => ({
25772
+ destinationValue: dst,
25773
+ prettyDestinationValue: dstUnit + dst,
25774
+ sourceValue: src,
25775
+ prettySourceValue: src + " " + srcUnit,
25776
+ available: available,
25777
+ unavailableReasonCode: null,
25778
+ unavailableReason: "",
25779
+ });
25780
+ const chooseAmountVariable = {
25781
+ ...baseResponse(data, "chooseAmount", {
25782
+ ...baseReward$2,
25783
+ ...name("Visa® Prepaid Card USD"),
25784
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25785
+ ...variableValue(20, 80, "SaaSquatch Points"),
25786
+ steps: [
25787
+ baseStep(20, "$", 40, "SaaSquatch Points"),
25788
+ baseStep(30, "$", 60, "SaaSquatch Points"),
25789
+ baseStep(40, "$", 80, "SaaSquatch Points"),
25790
+ baseStep(50, "$", 100, "SaaSquatch Points"),
25791
+ baseStep(60, "$", 120, "SaaSquatch Points"),
25792
+ ],
25793
+ }),
25794
+ };
25795
+ const chooseAmountFixed = {
25796
+ ...baseResponse(data, "chooseAmount", {
25797
+ ...baseReward$2,
25798
+ ...name("Free swag with a promo code"),
25799
+ ...imageUrl("https://i.imgur.com/n7vC4BR.png"),
25800
+ ...fixedValue("40 SaaSquatch Points"),
25801
+ }),
25802
+ };
25803
+ const confirmFixed = {
25804
+ ...baseResponse(data, "confirmation", {
25805
+ ...baseReward$2,
25806
+ ...name("A very exclusive gift box"),
25807
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
25808
+ ...fixedValue("30 SaaSquatch Points"),
25809
+ }),
25810
+ };
25811
+ const confirmVariable = {
25812
+ ...baseResponse(data, "confirmation", {
25813
+ ...baseReward$2,
25814
+ ...name("Visa® Prepaid Card USD"),
25815
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25816
+ ...variableValue(20, 80, "SaaSquatch Points"),
25817
+ }, baseStep(20, "$", 40, "SaaSquatch Points")),
25818
+ };
25819
+ const error$1 = {
25820
+ ...baseResponse(data, "confirmation", {
25821
+ ...baseReward$2,
25822
+ ...name("Visa® Prepaid Card USD"),
25823
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25824
+ ...variableValue(20, 80, "SaaSquatch Points"),
25825
+ }, baseStep(20, "$", 40, "SaaSquatch Points"), true),
25826
+ };
25827
+ const success = {
25828
+ ...baseResponse(data, "success", {
25829
+ ...baseReward$2,
25830
+ ...name("A very exclusive gift box"),
25831
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
25832
+ ...fixedValue("30 SaaSquatch Points"),
25833
+ }),
25834
+ };
25835
+ const loading = {
25836
+ ...baseResponse(null, "chooseReward", null, null, false, true),
25731
25837
  };
25732
25838
 
25733
25839
  const RewardExchangeList_stories = {
25734
25840
  title: "Components/Reward Exchange List",
25735
25841
  };
25736
- const resizable$1 = {
25737
- width: "683px",
25738
- minWidth: "260px",
25739
- resize: "horizontal",
25740
- height: "fit-content",
25741
- overflow: "hidden",
25842
+ const ChooseReward = () => {
25843
+ return h(RewardExchangeView, Object.assign({}, rewardExchange));
25844
+ };
25845
+ const ChooseRewardSelected = () => {
25846
+ return (h(RewardExchangeView, Object.assign({}, rewardExchangeSelected)));
25742
25847
  };
25743
- const rewardExchange$1 = () => {
25744
- return (h("div", { style: resizable$1 },
25745
- h(RewardExchangeView, Object.assign({}, rewardExchange))));
25848
+ const ChooseAmount = () => {
25849
+ return h(RewardExchangeView, Object.assign({}, chooseAmountFixed));
25746
25850
  };
25747
- const rewardExchangeSelected$1 = () => {
25748
- return (h("div", { style: resizable$1 },
25749
- h(RewardExchangeView, Object.assign({}, rewardExchangeSelected))));
25851
+ const ChooseAmountVariable = () => {
25852
+ return (h(RewardExchangeView, Object.assign({}, chooseAmountVariable)));
25750
25853
  };
25751
- const Default2 = () => {
25752
- return (h("div", { style: { ...resizable$1, height: "700px" } },
25753
- h(RewardExchangeView, Object.assign({}, test2))));
25854
+ const Confirm = () => {
25855
+ return h(RewardExchangeView, Object.assign({}, confirmFixed));
25856
+ };
25857
+ const ConfirmVariable = () => {
25858
+ return h(RewardExchangeView, Object.assign({}, confirmVariable));
25859
+ };
25860
+ const Error$3 = () => {
25861
+ return h(RewardExchangeView, Object.assign({}, error$1));
25862
+ };
25863
+ const Success$2 = () => {
25864
+ return h(RewardExchangeView, Object.assign({}, success));
25865
+ };
25866
+ const Loading$3 = () => {
25867
+ return h(RewardExchangeView, Object.assign({}, loading));
25754
25868
  };
25755
25869
 
25756
25870
  const RewardExchangeList = /*#__PURE__*/Object.freeze({
25757
25871
  __proto__: null,
25758
25872
  'default': RewardExchangeList_stories,
25759
- rewardExchange: rewardExchange$1,
25760
- rewardExchangeSelected: rewardExchangeSelected$1,
25761
- Default2: Default2
25873
+ ChooseReward: ChooseReward,
25874
+ ChooseRewardSelected: ChooseRewardSelected,
25875
+ ChooseAmount: ChooseAmount,
25876
+ ChooseAmountVariable: ChooseAmountVariable,
25877
+ Confirm: Confirm,
25878
+ ConfirmVariable: ConfirmVariable,
25879
+ Error: Error$3,
25880
+ Success: Success$2,
25881
+ Loading: Loading$3
25882
+ });
25883
+
25884
+ var chroma = createCommonjsModule(function (module, exports) {
25885
+ /**
25886
+ * chroma.js - JavaScript library for color conversions
25887
+ *
25888
+ * Copyright (c) 2011-2019, Gregor Aisch
25889
+ * All rights reserved.
25890
+ *
25891
+ * Redistribution and use in source and binary forms, with or without
25892
+ * modification, are permitted provided that the following conditions are met:
25893
+ *
25894
+ * 1. Redistributions of source code must retain the above copyright notice, this
25895
+ * list of conditions and the following disclaimer.
25896
+ *
25897
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
25898
+ * this list of conditions and the following disclaimer in the documentation
25899
+ * and/or other materials provided with the distribution.
25900
+ *
25901
+ * 3. The name Gregor Aisch may not be used to endorse or promote products
25902
+ * derived from this software without specific prior written permission.
25903
+ *
25904
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
25905
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25906
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
25907
+ * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
25908
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
25909
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25910
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
25911
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
25912
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
25913
+ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25914
+ *
25915
+ * -------------------------------------------------------
25916
+ *
25917
+ * chroma.js includes colors from colorbrewer2.org, which are released under
25918
+ * the following license:
25919
+ *
25920
+ * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,
25921
+ * and The Pennsylvania State University.
25922
+ *
25923
+ * Licensed under the Apache License, Version 2.0 (the "License");
25924
+ * you may not use this file except in compliance with the License.
25925
+ * You may obtain a copy of the License at
25926
+ * http://www.apache.org/licenses/LICENSE-2.0
25927
+ *
25928
+ * Unless required by applicable law or agreed to in writing,
25929
+ * software distributed under the License is distributed on an
25930
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
25931
+ * either express or implied. See the License for the specific
25932
+ * language governing permissions and limitations under the License.
25933
+ *
25934
+ * ------------------------------------------------------
25935
+ *
25936
+ * Named colors are taken from X11 Color Names.
25937
+ * http://www.w3.org/TR/css3-color/#svg-color
25938
+ *
25939
+ * @preserve
25940
+ */
25941
+
25942
+ (function (global, factory) {
25943
+ module.exports = factory() ;
25944
+ }(commonjsGlobal, (function () {
25945
+ var limit = function (x, min, max) {
25946
+ if ( min === void 0 ) min=0;
25947
+ if ( max === void 0 ) max=1;
25948
+
25949
+ return x < min ? min : x > max ? max : x;
25950
+ };
25951
+
25952
+ var clip_rgb = function (rgb) {
25953
+ rgb._clipped = false;
25954
+ rgb._unclipped = rgb.slice(0);
25955
+ for (var i=0; i<=3; i++) {
25956
+ if (i < 3) {
25957
+ if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }
25958
+ rgb[i] = limit(rgb[i], 0, 255);
25959
+ } else if (i === 3) {
25960
+ rgb[i] = limit(rgb[i], 0, 1);
25961
+ }
25962
+ }
25963
+ return rgb;
25964
+ };
25965
+
25966
+ // ported from jQuery's $.type
25967
+ var classToType = {};
25968
+ for (var i = 0, list = ['Boolean', 'Number', 'String', 'Function', 'Array', 'Date', 'RegExp', 'Undefined', 'Null']; i < list.length; i += 1) {
25969
+ var name = list[i];
25970
+
25971
+ classToType[("[object " + name + "]")] = name.toLowerCase();
25972
+ }
25973
+ var type = function(obj) {
25974
+ return classToType[Object.prototype.toString.call(obj)] || "object";
25975
+ };
25976
+
25977
+ var unpack = function (args, keyOrder) {
25978
+ if ( keyOrder === void 0 ) keyOrder=null;
25979
+
25980
+ // if called with more than 3 arguments, we return the arguments
25981
+ if (args.length >= 3) { return Array.prototype.slice.call(args); }
25982
+ // with less than 3 args we check if first arg is object
25983
+ // and use the keyOrder string to extract and sort properties
25984
+ if (type(args[0]) == 'object' && keyOrder) {
25985
+ return keyOrder.split('')
25986
+ .filter(function (k) { return args[0][k] !== undefined; })
25987
+ .map(function (k) { return args[0][k]; });
25988
+ }
25989
+ // otherwise we just return the first argument
25990
+ // (which we suppose is an array of args)
25991
+ return args[0];
25992
+ };
25993
+
25994
+ var last = function (args) {
25995
+ if (args.length < 2) { return null; }
25996
+ var l = args.length-1;
25997
+ if (type(args[l]) == 'string') { return args[l].toLowerCase(); }
25998
+ return null;
25999
+ };
26000
+
26001
+ var PI = Math.PI;
26002
+
26003
+ var utils = {
26004
+ clip_rgb: clip_rgb,
26005
+ limit: limit,
26006
+ type: type,
26007
+ unpack: unpack,
26008
+ last: last,
26009
+ PI: PI,
26010
+ TWOPI: PI*2,
26011
+ PITHIRD: PI/3,
26012
+ DEG2RAD: PI / 180,
26013
+ RAD2DEG: 180 / PI
26014
+ };
26015
+
26016
+ var input = {
26017
+ format: {},
26018
+ autodetect: []
26019
+ };
26020
+
26021
+ var last$1 = utils.last;
26022
+ var clip_rgb$1 = utils.clip_rgb;
26023
+ var type$1 = utils.type;
26024
+
26025
+
26026
+ var Color = function Color() {
26027
+ var args = [], len = arguments.length;
26028
+ while ( len-- ) args[ len ] = arguments[ len ];
26029
+
26030
+ var me = this;
26031
+ if (type$1(args[0]) === 'object' &&
26032
+ args[0].constructor &&
26033
+ args[0].constructor === this.constructor) {
26034
+ // the argument is already a Color instance
26035
+ return args[0];
26036
+ }
26037
+
26038
+ // last argument could be the mode
26039
+ var mode = last$1(args);
26040
+ var autodetect = false;
26041
+
26042
+ if (!mode) {
26043
+ autodetect = true;
26044
+ if (!input.sorted) {
26045
+ input.autodetect = input.autodetect.sort(function (a,b) { return b.p - a.p; });
26046
+ input.sorted = true;
26047
+ }
26048
+ // auto-detect format
26049
+ for (var i = 0, list = input.autodetect; i < list.length; i += 1) {
26050
+ var chk = list[i];
26051
+
26052
+ mode = chk.test.apply(chk, args);
26053
+ if (mode) { break; }
26054
+ }
26055
+ }
26056
+
26057
+ if (input.format[mode]) {
26058
+ var rgb = input.format[mode].apply(null, autodetect ? args : args.slice(0,-1));
26059
+ me._rgb = clip_rgb$1(rgb);
26060
+ } else {
26061
+ throw new Error('unknown format: '+args);
26062
+ }
26063
+
26064
+ // add alpha channel
26065
+ if (me._rgb.length === 3) { me._rgb.push(1); }
26066
+ };
26067
+
26068
+ Color.prototype.toString = function toString () {
26069
+ if (type$1(this.hex) == 'function') { return this.hex(); }
26070
+ return ("[" + (this._rgb.join(',')) + "]");
26071
+ };
26072
+
26073
+ var Color_1 = Color;
26074
+
26075
+ var chroma = function () {
26076
+ var args = [], len = arguments.length;
26077
+ while ( len-- ) args[ len ] = arguments[ len ];
26078
+
26079
+ return new (Function.prototype.bind.apply( chroma.Color, [ null ].concat( args) ));
26080
+ };
26081
+
26082
+ chroma.Color = Color_1;
26083
+ chroma.version = '2.1.2';
26084
+
26085
+ var chroma_1 = chroma;
26086
+
26087
+ var unpack$1 = utils.unpack;
26088
+ var max = Math.max;
26089
+
26090
+ var rgb2cmyk = function () {
26091
+ var args = [], len = arguments.length;
26092
+ while ( len-- ) args[ len ] = arguments[ len ];
26093
+
26094
+ var ref = unpack$1(args, 'rgb');
26095
+ var r = ref[0];
26096
+ var g = ref[1];
26097
+ var b = ref[2];
26098
+ r = r / 255;
26099
+ g = g / 255;
26100
+ b = b / 255;
26101
+ var k = 1 - max(r,max(g,b));
26102
+ var f = k < 1 ? 1 / (1-k) : 0;
26103
+ var c = (1-r-k) * f;
26104
+ var m = (1-g-k) * f;
26105
+ var y = (1-b-k) * f;
26106
+ return [c,m,y,k];
26107
+ };
26108
+
26109
+ var rgb2cmyk_1 = rgb2cmyk;
26110
+
26111
+ var unpack$2 = utils.unpack;
26112
+
26113
+ var cmyk2rgb = function () {
26114
+ var args = [], len = arguments.length;
26115
+ while ( len-- ) args[ len ] = arguments[ len ];
26116
+
26117
+ args = unpack$2(args, 'cmyk');
26118
+ var c = args[0];
26119
+ var m = args[1];
26120
+ var y = args[2];
26121
+ var k = args[3];
26122
+ var alpha = args.length > 4 ? args[4] : 1;
26123
+ if (k === 1) { return [0,0,0,alpha]; }
26124
+ return [
26125
+ c >= 1 ? 0 : 255 * (1-c) * (1-k), // r
26126
+ m >= 1 ? 0 : 255 * (1-m) * (1-k), // g
26127
+ y >= 1 ? 0 : 255 * (1-y) * (1-k), // b
26128
+ alpha
26129
+ ];
26130
+ };
26131
+
26132
+ var cmyk2rgb_1 = cmyk2rgb;
26133
+
26134
+ var unpack$3 = utils.unpack;
26135
+ var type$2 = utils.type;
26136
+
26137
+
26138
+
26139
+ Color_1.prototype.cmyk = function() {
26140
+ return rgb2cmyk_1(this._rgb);
26141
+ };
26142
+
26143
+ chroma_1.cmyk = function () {
26144
+ var args = [], len = arguments.length;
26145
+ while ( len-- ) args[ len ] = arguments[ len ];
26146
+
26147
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['cmyk']) ));
26148
+ };
26149
+
26150
+ input.format.cmyk = cmyk2rgb_1;
26151
+
26152
+ input.autodetect.push({
26153
+ p: 2,
26154
+ test: function () {
26155
+ var args = [], len = arguments.length;
26156
+ while ( len-- ) args[ len ] = arguments[ len ];
26157
+
26158
+ args = unpack$3(args, 'cmyk');
26159
+ if (type$2(args) === 'array' && args.length === 4) {
26160
+ return 'cmyk';
26161
+ }
26162
+ }
26163
+ });
26164
+
26165
+ var unpack$4 = utils.unpack;
26166
+ var last$2 = utils.last;
26167
+ var rnd = function (a) { return Math.round(a*100)/100; };
26168
+
26169
+ /*
26170
+ * supported arguments:
26171
+ * - hsl2css(h,s,l)
26172
+ * - hsl2css(h,s,l,a)
26173
+ * - hsl2css([h,s,l], mode)
26174
+ * - hsl2css([h,s,l,a], mode)
26175
+ * - hsl2css({h,s,l,a}, mode)
26176
+ */
26177
+ var hsl2css = function () {
26178
+ var args = [], len = arguments.length;
26179
+ while ( len-- ) args[ len ] = arguments[ len ];
26180
+
26181
+ var hsla = unpack$4(args, 'hsla');
26182
+ var mode = last$2(args) || 'lsa';
26183
+ hsla[0] = rnd(hsla[0] || 0);
26184
+ hsla[1] = rnd(hsla[1]*100) + '%';
26185
+ hsla[2] = rnd(hsla[2]*100) + '%';
26186
+ if (mode === 'hsla' || (hsla.length > 3 && hsla[3]<1)) {
26187
+ hsla[3] = hsla.length > 3 ? hsla[3] : 1;
26188
+ mode = 'hsla';
26189
+ } else {
26190
+ hsla.length = 3;
26191
+ }
26192
+ return (mode + "(" + (hsla.join(',')) + ")");
26193
+ };
26194
+
26195
+ var hsl2css_1 = hsl2css;
26196
+
26197
+ var unpack$5 = utils.unpack;
26198
+
26199
+ /*
26200
+ * supported arguments:
26201
+ * - rgb2hsl(r,g,b)
26202
+ * - rgb2hsl(r,g,b,a)
26203
+ * - rgb2hsl([r,g,b])
26204
+ * - rgb2hsl([r,g,b,a])
26205
+ * - rgb2hsl({r,g,b,a})
26206
+ */
26207
+ var rgb2hsl = function () {
26208
+ var args = [], len = arguments.length;
26209
+ while ( len-- ) args[ len ] = arguments[ len ];
26210
+
26211
+ args = unpack$5(args, 'rgba');
26212
+ var r = args[0];
26213
+ var g = args[1];
26214
+ var b = args[2];
26215
+
26216
+ r /= 255;
26217
+ g /= 255;
26218
+ b /= 255;
26219
+
26220
+ var min = Math.min(r, g, b);
26221
+ var max = Math.max(r, g, b);
26222
+
26223
+ var l = (max + min) / 2;
26224
+ var s, h;
26225
+
26226
+ if (max === min){
26227
+ s = 0;
26228
+ h = Number.NaN;
26229
+ } else {
26230
+ s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);
26231
+ }
26232
+
26233
+ if (r == max) { h = (g - b) / (max - min); }
26234
+ else if (g == max) { h = 2 + (b - r) / (max - min); }
26235
+ else if (b == max) { h = 4 + (r - g) / (max - min); }
26236
+
26237
+ h *= 60;
26238
+ if (h < 0) { h += 360; }
26239
+ if (args.length>3 && args[3]!==undefined) { return [h,s,l,args[3]]; }
26240
+ return [h,s,l];
26241
+ };
26242
+
26243
+ var rgb2hsl_1 = rgb2hsl;
26244
+
26245
+ var unpack$6 = utils.unpack;
26246
+ var last$3 = utils.last;
26247
+
26248
+
26249
+ var round = Math.round;
26250
+
26251
+ /*
26252
+ * supported arguments:
26253
+ * - rgb2css(r,g,b)
26254
+ * - rgb2css(r,g,b,a)
26255
+ * - rgb2css([r,g,b], mode)
26256
+ * - rgb2css([r,g,b,a], mode)
26257
+ * - rgb2css({r,g,b,a}, mode)
26258
+ */
26259
+ var rgb2css = function () {
26260
+ var args = [], len = arguments.length;
26261
+ while ( len-- ) args[ len ] = arguments[ len ];
26262
+
26263
+ var rgba = unpack$6(args, 'rgba');
26264
+ var mode = last$3(args) || 'rgb';
26265
+ if (mode.substr(0,3) == 'hsl') {
26266
+ return hsl2css_1(rgb2hsl_1(rgba), mode);
26267
+ }
26268
+ rgba[0] = round(rgba[0]);
26269
+ rgba[1] = round(rgba[1]);
26270
+ rgba[2] = round(rgba[2]);
26271
+ if (mode === 'rgba' || (rgba.length > 3 && rgba[3]<1)) {
26272
+ rgba[3] = rgba.length > 3 ? rgba[3] : 1;
26273
+ mode = 'rgba';
26274
+ }
26275
+ return (mode + "(" + (rgba.slice(0,mode==='rgb'?3:4).join(',')) + ")");
26276
+ };
26277
+
26278
+ var rgb2css_1 = rgb2css;
26279
+
26280
+ var unpack$7 = utils.unpack;
26281
+ var round$1 = Math.round;
26282
+
26283
+ var hsl2rgb = function () {
26284
+ var assign;
26285
+
26286
+ var args = [], len = arguments.length;
26287
+ while ( len-- ) args[ len ] = arguments[ len ];
26288
+ args = unpack$7(args, 'hsl');
26289
+ var h = args[0];
26290
+ var s = args[1];
26291
+ var l = args[2];
26292
+ var r,g,b;
26293
+ if (s === 0) {
26294
+ r = g = b = l*255;
26295
+ } else {
26296
+ var t3 = [0,0,0];
26297
+ var c = [0,0,0];
26298
+ var t2 = l < 0.5 ? l * (1+s) : l+s-l*s;
26299
+ var t1 = 2 * l - t2;
26300
+ var h_ = h / 360;
26301
+ t3[0] = h_ + 1/3;
26302
+ t3[1] = h_;
26303
+ t3[2] = h_ - 1/3;
26304
+ for (var i=0; i<3; i++) {
26305
+ if (t3[i] < 0) { t3[i] += 1; }
26306
+ if (t3[i] > 1) { t3[i] -= 1; }
26307
+ if (6 * t3[i] < 1)
26308
+ { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }
26309
+ else if (2 * t3[i] < 1)
26310
+ { c[i] = t2; }
26311
+ else if (3 * t3[i] < 2)
26312
+ { c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6; }
26313
+ else
26314
+ { c[i] = t1; }
26315
+ }
26316
+ (assign = [round$1(c[0]*255),round$1(c[1]*255),round$1(c[2]*255)], r = assign[0], g = assign[1], b = assign[2]);
26317
+ }
26318
+ if (args.length > 3) {
26319
+ // keep alpha channel
26320
+ return [r,g,b,args[3]];
26321
+ }
26322
+ return [r,g,b,1];
26323
+ };
26324
+
26325
+ var hsl2rgb_1 = hsl2rgb;
26326
+
26327
+ var RE_RGB = /^rgb\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*\)$/;
26328
+ var RE_RGBA = /^rgba\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*,\s*([01]|[01]?\.\d+)\)$/;
26329
+ var RE_RGB_PCT = /^rgb\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/;
26330
+ var RE_RGBA_PCT = /^rgba\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/;
26331
+ var RE_HSL = /^hsl\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/;
26332
+ var RE_HSLA = /^hsla\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/;
26333
+
26334
+ var round$2 = Math.round;
26335
+
26336
+ var css2rgb = function (css) {
26337
+ css = css.toLowerCase().trim();
26338
+ var m;
26339
+
26340
+ if (input.format.named) {
26341
+ try {
26342
+ return input.format.named(css);
26343
+ } catch (e) {
26344
+ // eslint-disable-next-line
26345
+ }
26346
+ }
26347
+
26348
+ // rgb(250,20,0)
26349
+ if ((m = css.match(RE_RGB))) {
26350
+ var rgb = m.slice(1,4);
26351
+ for (var i=0; i<3; i++) {
26352
+ rgb[i] = +rgb[i];
26353
+ }
26354
+ rgb[3] = 1; // default alpha
26355
+ return rgb;
26356
+ }
26357
+
26358
+ // rgba(250,20,0,0.4)
26359
+ if ((m = css.match(RE_RGBA))) {
26360
+ var rgb$1 = m.slice(1,5);
26361
+ for (var i$1=0; i$1<4; i$1++) {
26362
+ rgb$1[i$1] = +rgb$1[i$1];
26363
+ }
26364
+ return rgb$1;
26365
+ }
26366
+
26367
+ // rgb(100%,0%,0%)
26368
+ if ((m = css.match(RE_RGB_PCT))) {
26369
+ var rgb$2 = m.slice(1,4);
26370
+ for (var i$2=0; i$2<3; i$2++) {
26371
+ rgb$2[i$2] = round$2(rgb$2[i$2] * 2.55);
26372
+ }
26373
+ rgb$2[3] = 1; // default alpha
26374
+ return rgb$2;
26375
+ }
26376
+
26377
+ // rgba(100%,0%,0%,0.4)
26378
+ if ((m = css.match(RE_RGBA_PCT))) {
26379
+ var rgb$3 = m.slice(1,5);
26380
+ for (var i$3=0; i$3<3; i$3++) {
26381
+ rgb$3[i$3] = round$2(rgb$3[i$3] * 2.55);
26382
+ }
26383
+ rgb$3[3] = +rgb$3[3];
26384
+ return rgb$3;
26385
+ }
26386
+
26387
+ // hsl(0,100%,50%)
26388
+ if ((m = css.match(RE_HSL))) {
26389
+ var hsl = m.slice(1,4);
26390
+ hsl[1] *= 0.01;
26391
+ hsl[2] *= 0.01;
26392
+ var rgb$4 = hsl2rgb_1(hsl);
26393
+ rgb$4[3] = 1;
26394
+ return rgb$4;
26395
+ }
26396
+
26397
+ // hsla(0,100%,50%,0.5)
26398
+ if ((m = css.match(RE_HSLA))) {
26399
+ var hsl$1 = m.slice(1,4);
26400
+ hsl$1[1] *= 0.01;
26401
+ hsl$1[2] *= 0.01;
26402
+ var rgb$5 = hsl2rgb_1(hsl$1);
26403
+ rgb$5[3] = +m[4]; // default alpha = 1
26404
+ return rgb$5;
26405
+ }
26406
+ };
26407
+
26408
+ css2rgb.test = function (s) {
26409
+ return RE_RGB.test(s) ||
26410
+ RE_RGBA.test(s) ||
26411
+ RE_RGB_PCT.test(s) ||
26412
+ RE_RGBA_PCT.test(s) ||
26413
+ RE_HSL.test(s) ||
26414
+ RE_HSLA.test(s);
26415
+ };
26416
+
26417
+ var css2rgb_1 = css2rgb;
26418
+
26419
+ var type$3 = utils.type;
26420
+
26421
+
26422
+
26423
+
26424
+ Color_1.prototype.css = function(mode) {
26425
+ return rgb2css_1(this._rgb, mode);
26426
+ };
26427
+
26428
+ chroma_1.css = function () {
26429
+ var args = [], len = arguments.length;
26430
+ while ( len-- ) args[ len ] = arguments[ len ];
26431
+
26432
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['css']) ));
26433
+ };
26434
+
26435
+ input.format.css = css2rgb_1;
26436
+
26437
+ input.autodetect.push({
26438
+ p: 5,
26439
+ test: function (h) {
26440
+ var rest = [], len = arguments.length - 1;
26441
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
26442
+
26443
+ if (!rest.length && type$3(h) === 'string' && css2rgb_1.test(h)) {
26444
+ return 'css';
26445
+ }
26446
+ }
26447
+ });
26448
+
26449
+ var unpack$8 = utils.unpack;
26450
+
26451
+ input.format.gl = function () {
26452
+ var args = [], len = arguments.length;
26453
+ while ( len-- ) args[ len ] = arguments[ len ];
26454
+
26455
+ var rgb = unpack$8(args, 'rgba');
26456
+ rgb[0] *= 255;
26457
+ rgb[1] *= 255;
26458
+ rgb[2] *= 255;
26459
+ return rgb;
26460
+ };
26461
+
26462
+ chroma_1.gl = function () {
26463
+ var args = [], len = arguments.length;
26464
+ while ( len-- ) args[ len ] = arguments[ len ];
26465
+
26466
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['gl']) ));
26467
+ };
26468
+
26469
+ Color_1.prototype.gl = function() {
26470
+ var rgb = this._rgb;
26471
+ return [rgb[0]/255, rgb[1]/255, rgb[2]/255, rgb[3]];
26472
+ };
26473
+
26474
+ var unpack$9 = utils.unpack;
26475
+
26476
+ var rgb2hcg = function () {
26477
+ var args = [], len = arguments.length;
26478
+ while ( len-- ) args[ len ] = arguments[ len ];
26479
+
26480
+ var ref = unpack$9(args, 'rgb');
26481
+ var r = ref[0];
26482
+ var g = ref[1];
26483
+ var b = ref[2];
26484
+ var min = Math.min(r, g, b);
26485
+ var max = Math.max(r, g, b);
26486
+ var delta = max - min;
26487
+ var c = delta * 100 / 255;
26488
+ var _g = min / (255 - delta) * 100;
26489
+ var h;
26490
+ if (delta === 0) {
26491
+ h = Number.NaN;
26492
+ } else {
26493
+ if (r === max) { h = (g - b) / delta; }
26494
+ if (g === max) { h = 2+(b - r) / delta; }
26495
+ if (b === max) { h = 4+(r - g) / delta; }
26496
+ h *= 60;
26497
+ if (h < 0) { h += 360; }
26498
+ }
26499
+ return [h, c, _g];
26500
+ };
26501
+
26502
+ var rgb2hcg_1 = rgb2hcg;
26503
+
26504
+ var unpack$a = utils.unpack;
26505
+ var floor = Math.floor;
26506
+
26507
+ /*
26508
+ * this is basically just HSV with some minor tweaks
26509
+ *
26510
+ * hue.. [0..360]
26511
+ * chroma .. [0..1]
26512
+ * grayness .. [0..1]
26513
+ */
26514
+
26515
+ var hcg2rgb = function () {
26516
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
26517
+
26518
+ var args = [], len = arguments.length;
26519
+ while ( len-- ) args[ len ] = arguments[ len ];
26520
+ args = unpack$a(args, 'hcg');
26521
+ var h = args[0];
26522
+ var c = args[1];
26523
+ var _g = args[2];
26524
+ var r,g,b;
26525
+ _g = _g * 255;
26526
+ var _c = c * 255;
26527
+ if (c === 0) {
26528
+ r = g = b = _g;
26529
+ } else {
26530
+ if (h === 360) { h = 0; }
26531
+ if (h > 360) { h -= 360; }
26532
+ if (h < 0) { h += 360; }
26533
+ h /= 60;
26534
+ var i = floor(h);
26535
+ var f = h - i;
26536
+ var p = _g * (1 - c);
26537
+ var q = p + _c * (1 - f);
26538
+ var t = p + _c * f;
26539
+ var v = p + _c;
26540
+ switch (i) {
26541
+ case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break
26542
+ case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break
26543
+ case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break
26544
+ case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break
26545
+ case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break
26546
+ case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break
26547
+ }
26548
+ }
26549
+ return [r, g, b, args.length > 3 ? args[3] : 1];
26550
+ };
26551
+
26552
+ var hcg2rgb_1 = hcg2rgb;
26553
+
26554
+ var unpack$b = utils.unpack;
26555
+ var type$4 = utils.type;
26556
+
26557
+
26558
+
26559
+
26560
+
26561
+
26562
+ Color_1.prototype.hcg = function() {
26563
+ return rgb2hcg_1(this._rgb);
26564
+ };
26565
+
26566
+ chroma_1.hcg = function () {
26567
+ var args = [], len = arguments.length;
26568
+ while ( len-- ) args[ len ] = arguments[ len ];
26569
+
26570
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcg']) ));
26571
+ };
26572
+
26573
+ input.format.hcg = hcg2rgb_1;
26574
+
26575
+ input.autodetect.push({
26576
+ p: 1,
26577
+ test: function () {
26578
+ var args = [], len = arguments.length;
26579
+ while ( len-- ) args[ len ] = arguments[ len ];
26580
+
26581
+ args = unpack$b(args, 'hcg');
26582
+ if (type$4(args) === 'array' && args.length === 3) {
26583
+ return 'hcg';
26584
+ }
26585
+ }
26586
+ });
26587
+
26588
+ var unpack$c = utils.unpack;
26589
+ var last$4 = utils.last;
26590
+ var round$3 = Math.round;
26591
+
26592
+ var rgb2hex = function () {
26593
+ var args = [], len = arguments.length;
26594
+ while ( len-- ) args[ len ] = arguments[ len ];
26595
+
26596
+ var ref = unpack$c(args, 'rgba');
26597
+ var r = ref[0];
26598
+ var g = ref[1];
26599
+ var b = ref[2];
26600
+ var a = ref[3];
26601
+ var mode = last$4(args) || 'auto';
26602
+ if (a === undefined) { a = 1; }
26603
+ if (mode === 'auto') {
26604
+ mode = a < 1 ? 'rgba' : 'rgb';
26605
+ }
26606
+ r = round$3(r);
26607
+ g = round$3(g);
26608
+ b = round$3(b);
26609
+ var u = r << 16 | g << 8 | b;
26610
+ var str = "000000" + u.toString(16); //#.toUpperCase();
26611
+ str = str.substr(str.length - 6);
26612
+ var hxa = '0' + round$3(a * 255).toString(16);
26613
+ hxa = hxa.substr(hxa.length - 2);
26614
+ switch (mode.toLowerCase()) {
26615
+ case 'rgba': return ("#" + str + hxa);
26616
+ case 'argb': return ("#" + hxa + str);
26617
+ default: return ("#" + str);
26618
+ }
26619
+ };
26620
+
26621
+ var rgb2hex_1 = rgb2hex;
26622
+
26623
+ var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
26624
+ var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;
26625
+
26626
+ var hex2rgb = function (hex) {
26627
+ if (hex.match(RE_HEX)) {
26628
+ // remove optional leading #
26629
+ if (hex.length === 4 || hex.length === 7) {
26630
+ hex = hex.substr(1);
26631
+ }
26632
+ // expand short-notation to full six-digit
26633
+ if (hex.length === 3) {
26634
+ hex = hex.split('');
26635
+ hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2];
26636
+ }
26637
+ var u = parseInt(hex, 16);
26638
+ var r = u >> 16;
26639
+ var g = u >> 8 & 0xFF;
26640
+ var b = u & 0xFF;
26641
+ return [r,g,b,1];
26642
+ }
26643
+
26644
+ // match rgba hex format, eg #FF000077
26645
+ if (hex.match(RE_HEXA)) {
26646
+ if (hex.length === 5 || hex.length === 9) {
26647
+ // remove optional leading #
26648
+ hex = hex.substr(1);
26649
+ }
26650
+ // expand short-notation to full eight-digit
26651
+ if (hex.length === 4) {
26652
+ hex = hex.split('');
26653
+ hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2]+hex[3]+hex[3];
26654
+ }
26655
+ var u$1 = parseInt(hex, 16);
26656
+ var r$1 = u$1 >> 24 & 0xFF;
26657
+ var g$1 = u$1 >> 16 & 0xFF;
26658
+ var b$1 = u$1 >> 8 & 0xFF;
26659
+ var a = Math.round((u$1 & 0xFF) / 0xFF * 100) / 100;
26660
+ return [r$1,g$1,b$1,a];
26661
+ }
26662
+
26663
+ // we used to check for css colors here
26664
+ // if _input.css? and rgb = _input.css hex
26665
+ // return rgb
26666
+
26667
+ throw new Error(("unknown hex color: " + hex));
26668
+ };
26669
+
26670
+ var hex2rgb_1 = hex2rgb;
26671
+
26672
+ var type$5 = utils.type;
26673
+
26674
+
26675
+
26676
+
26677
+ Color_1.prototype.hex = function(mode) {
26678
+ return rgb2hex_1(this._rgb, mode);
26679
+ };
26680
+
26681
+ chroma_1.hex = function () {
26682
+ var args = [], len = arguments.length;
26683
+ while ( len-- ) args[ len ] = arguments[ len ];
26684
+
26685
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hex']) ));
26686
+ };
26687
+
26688
+ input.format.hex = hex2rgb_1;
26689
+ input.autodetect.push({
26690
+ p: 4,
26691
+ test: function (h) {
26692
+ var rest = [], len = arguments.length - 1;
26693
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
26694
+
26695
+ if (!rest.length && type$5(h) === 'string' && [3,4,5,6,7,8,9].indexOf(h.length) >= 0) {
26696
+ return 'hex';
26697
+ }
26698
+ }
26699
+ });
26700
+
26701
+ var unpack$d = utils.unpack;
26702
+ var TWOPI = utils.TWOPI;
26703
+ var min = Math.min;
26704
+ var sqrt = Math.sqrt;
26705
+ var acos = Math.acos;
26706
+
26707
+ var rgb2hsi = function () {
26708
+ var args = [], len = arguments.length;
26709
+ while ( len-- ) args[ len ] = arguments[ len ];
26710
+
26711
+ /*
26712
+ borrowed from here:
26713
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp
26714
+ */
26715
+ var ref = unpack$d(args, 'rgb');
26716
+ var r = ref[0];
26717
+ var g = ref[1];
26718
+ var b = ref[2];
26719
+ r /= 255;
26720
+ g /= 255;
26721
+ b /= 255;
26722
+ var h;
26723
+ var min_ = min(r,g,b);
26724
+ var i = (r+g+b) / 3;
26725
+ var s = i > 0 ? 1 - min_/i : 0;
26726
+ if (s === 0) {
26727
+ h = NaN;
26728
+ } else {
26729
+ h = ((r-g)+(r-b)) / 2;
26730
+ h /= sqrt((r-g)*(r-g) + (r-b)*(g-b));
26731
+ h = acos(h);
26732
+ if (b > g) {
26733
+ h = TWOPI - h;
26734
+ }
26735
+ h /= TWOPI;
26736
+ }
26737
+ return [h*360,s,i];
26738
+ };
26739
+
26740
+ var rgb2hsi_1 = rgb2hsi;
26741
+
26742
+ var unpack$e = utils.unpack;
26743
+ var limit$1 = utils.limit;
26744
+ var TWOPI$1 = utils.TWOPI;
26745
+ var PITHIRD = utils.PITHIRD;
26746
+ var cos = Math.cos;
26747
+
26748
+ /*
26749
+ * hue [0..360]
26750
+ * saturation [0..1]
26751
+ * intensity [0..1]
26752
+ */
26753
+ var hsi2rgb = function () {
26754
+ var args = [], len = arguments.length;
26755
+ while ( len-- ) args[ len ] = arguments[ len ];
26756
+
26757
+ /*
26758
+ borrowed from here:
26759
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp
26760
+ */
26761
+ args = unpack$e(args, 'hsi');
26762
+ var h = args[0];
26763
+ var s = args[1];
26764
+ var i = args[2];
26765
+ var r,g,b;
26766
+
26767
+ if (isNaN(h)) { h = 0; }
26768
+ if (isNaN(s)) { s = 0; }
26769
+ // normalize hue
26770
+ if (h > 360) { h -= 360; }
26771
+ if (h < 0) { h += 360; }
26772
+ h /= 360;
26773
+ if (h < 1/3) {
26774
+ b = (1-s)/3;
26775
+ r = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26776
+ g = 1 - (b+r);
26777
+ } else if (h < 2/3) {
26778
+ h -= 1/3;
26779
+ r = (1-s)/3;
26780
+ g = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26781
+ b = 1 - (r+g);
26782
+ } else {
26783
+ h -= 2/3;
26784
+ g = (1-s)/3;
26785
+ b = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26786
+ r = 1 - (g+b);
26787
+ }
26788
+ r = limit$1(i*r*3);
26789
+ g = limit$1(i*g*3);
26790
+ b = limit$1(i*b*3);
26791
+ return [r*255, g*255, b*255, args.length > 3 ? args[3] : 1];
26792
+ };
26793
+
26794
+ var hsi2rgb_1 = hsi2rgb;
26795
+
26796
+ var unpack$f = utils.unpack;
26797
+ var type$6 = utils.type;
26798
+
26799
+
26800
+
26801
+
26802
+
26803
+
26804
+ Color_1.prototype.hsi = function() {
26805
+ return rgb2hsi_1(this._rgb);
26806
+ };
26807
+
26808
+ chroma_1.hsi = function () {
26809
+ var args = [], len = arguments.length;
26810
+ while ( len-- ) args[ len ] = arguments[ len ];
26811
+
26812
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsi']) ));
26813
+ };
26814
+
26815
+ input.format.hsi = hsi2rgb_1;
26816
+
26817
+ input.autodetect.push({
26818
+ p: 2,
26819
+ test: function () {
26820
+ var args = [], len = arguments.length;
26821
+ while ( len-- ) args[ len ] = arguments[ len ];
26822
+
26823
+ args = unpack$f(args, 'hsi');
26824
+ if (type$6(args) === 'array' && args.length === 3) {
26825
+ return 'hsi';
26826
+ }
26827
+ }
26828
+ });
26829
+
26830
+ var unpack$g = utils.unpack;
26831
+ var type$7 = utils.type;
26832
+
26833
+
26834
+
26835
+
26836
+
26837
+
26838
+ Color_1.prototype.hsl = function() {
26839
+ return rgb2hsl_1(this._rgb);
26840
+ };
26841
+
26842
+ chroma_1.hsl = function () {
26843
+ var args = [], len = arguments.length;
26844
+ while ( len-- ) args[ len ] = arguments[ len ];
26845
+
26846
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsl']) ));
26847
+ };
26848
+
26849
+ input.format.hsl = hsl2rgb_1;
26850
+
26851
+ input.autodetect.push({
26852
+ p: 2,
26853
+ test: function () {
26854
+ var args = [], len = arguments.length;
26855
+ while ( len-- ) args[ len ] = arguments[ len ];
26856
+
26857
+ args = unpack$g(args, 'hsl');
26858
+ if (type$7(args) === 'array' && args.length === 3) {
26859
+ return 'hsl';
26860
+ }
26861
+ }
26862
+ });
26863
+
26864
+ var unpack$h = utils.unpack;
26865
+ var min$1 = Math.min;
26866
+ var max$1 = Math.max;
26867
+
26868
+ /*
26869
+ * supported arguments:
26870
+ * - rgb2hsv(r,g,b)
26871
+ * - rgb2hsv([r,g,b])
26872
+ * - rgb2hsv({r,g,b})
26873
+ */
26874
+ var rgb2hsl$1 = function () {
26875
+ var args = [], len = arguments.length;
26876
+ while ( len-- ) args[ len ] = arguments[ len ];
26877
+
26878
+ args = unpack$h(args, 'rgb');
26879
+ var r = args[0];
26880
+ var g = args[1];
26881
+ var b = args[2];
26882
+ var min_ = min$1(r, g, b);
26883
+ var max_ = max$1(r, g, b);
26884
+ var delta = max_ - min_;
26885
+ var h,s,v;
26886
+ v = max_ / 255.0;
26887
+ if (max_ === 0) {
26888
+ h = Number.NaN;
26889
+ s = 0;
26890
+ } else {
26891
+ s = delta / max_;
26892
+ if (r === max_) { h = (g - b) / delta; }
26893
+ if (g === max_) { h = 2+(b - r) / delta; }
26894
+ if (b === max_) { h = 4+(r - g) / delta; }
26895
+ h *= 60;
26896
+ if (h < 0) { h += 360; }
26897
+ }
26898
+ return [h, s, v]
26899
+ };
26900
+
26901
+ var rgb2hsv = rgb2hsl$1;
26902
+
26903
+ var unpack$i = utils.unpack;
26904
+ var floor$1 = Math.floor;
26905
+
26906
+ var hsv2rgb = function () {
26907
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
26908
+
26909
+ var args = [], len = arguments.length;
26910
+ while ( len-- ) args[ len ] = arguments[ len ];
26911
+ args = unpack$i(args, 'hsv');
26912
+ var h = args[0];
26913
+ var s = args[1];
26914
+ var v = args[2];
26915
+ var r,g,b;
26916
+ v *= 255;
26917
+ if (s === 0) {
26918
+ r = g = b = v;
26919
+ } else {
26920
+ if (h === 360) { h = 0; }
26921
+ if (h > 360) { h -= 360; }
26922
+ if (h < 0) { h += 360; }
26923
+ h /= 60;
26924
+
26925
+ var i = floor$1(h);
26926
+ var f = h - i;
26927
+ var p = v * (1 - s);
26928
+ var q = v * (1 - s * f);
26929
+ var t = v * (1 - s * (1 - f));
26930
+
26931
+ switch (i) {
26932
+ case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break
26933
+ case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break
26934
+ case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break
26935
+ case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break
26936
+ case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break
26937
+ case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break
26938
+ }
26939
+ }
26940
+ return [r,g,b,args.length > 3?args[3]:1];
26941
+ };
26942
+
26943
+ var hsv2rgb_1 = hsv2rgb;
26944
+
26945
+ var unpack$j = utils.unpack;
26946
+ var type$8 = utils.type;
26947
+
26948
+
26949
+
26950
+
26951
+
26952
+
26953
+ Color_1.prototype.hsv = function() {
26954
+ return rgb2hsv(this._rgb);
26955
+ };
26956
+
26957
+ chroma_1.hsv = function () {
26958
+ var args = [], len = arguments.length;
26959
+ while ( len-- ) args[ len ] = arguments[ len ];
26960
+
26961
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsv']) ));
26962
+ };
26963
+
26964
+ input.format.hsv = hsv2rgb_1;
26965
+
26966
+ input.autodetect.push({
26967
+ p: 2,
26968
+ test: function () {
26969
+ var args = [], len = arguments.length;
26970
+ while ( len-- ) args[ len ] = arguments[ len ];
26971
+
26972
+ args = unpack$j(args, 'hsv');
26973
+ if (type$8(args) === 'array' && args.length === 3) {
26974
+ return 'hsv';
26975
+ }
26976
+ }
26977
+ });
26978
+
26979
+ var labConstants = {
26980
+ // Corresponds roughly to RGB brighter/darker
26981
+ Kn: 18,
26982
+
26983
+ // D65 standard referent
26984
+ Xn: 0.950470,
26985
+ Yn: 1,
26986
+ Zn: 1.088830,
26987
+
26988
+ t0: 0.137931034, // 4 / 29
26989
+ t1: 0.206896552, // 6 / 29
26990
+ t2: 0.12841855, // 3 * t1 * t1
26991
+ t3: 0.008856452, // t1 * t1 * t1
26992
+ };
26993
+
26994
+ var unpack$k = utils.unpack;
26995
+ var pow = Math.pow;
26996
+
26997
+ var rgb2lab = function () {
26998
+ var args = [], len = arguments.length;
26999
+ while ( len-- ) args[ len ] = arguments[ len ];
27000
+
27001
+ var ref = unpack$k(args, 'rgb');
27002
+ var r = ref[0];
27003
+ var g = ref[1];
27004
+ var b = ref[2];
27005
+ var ref$1 = rgb2xyz(r,g,b);
27006
+ var x = ref$1[0];
27007
+ var y = ref$1[1];
27008
+ var z = ref$1[2];
27009
+ var l = 116 * y - 16;
27010
+ return [l < 0 ? 0 : l, 500 * (x - y), 200 * (y - z)];
27011
+ };
27012
+
27013
+ var rgb_xyz = function (r) {
27014
+ if ((r /= 255) <= 0.04045) { return r / 12.92; }
27015
+ return pow((r + 0.055) / 1.055, 2.4);
27016
+ };
27017
+
27018
+ var xyz_lab = function (t) {
27019
+ if (t > labConstants.t3) { return pow(t, 1 / 3); }
27020
+ return t / labConstants.t2 + labConstants.t0;
27021
+ };
27022
+
27023
+ var rgb2xyz = function (r,g,b) {
27024
+ r = rgb_xyz(r);
27025
+ g = rgb_xyz(g);
27026
+ b = rgb_xyz(b);
27027
+ var x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / labConstants.Xn);
27028
+ var y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / labConstants.Yn);
27029
+ var z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / labConstants.Zn);
27030
+ return [x,y,z];
27031
+ };
27032
+
27033
+ var rgb2lab_1 = rgb2lab;
27034
+
27035
+ var unpack$l = utils.unpack;
27036
+ var pow$1 = Math.pow;
27037
+
27038
+ /*
27039
+ * L* [0..100]
27040
+ * a [-100..100]
27041
+ * b [-100..100]
27042
+ */
27043
+ var lab2rgb = function () {
27044
+ var args = [], len = arguments.length;
27045
+ while ( len-- ) args[ len ] = arguments[ len ];
27046
+
27047
+ args = unpack$l(args, 'lab');
27048
+ var l = args[0];
27049
+ var a = args[1];
27050
+ var b = args[2];
27051
+ var x,y,z, r,g,b_;
27052
+
27053
+ y = (l + 16) / 116;
27054
+ x = isNaN(a) ? y : y + a / 500;
27055
+ z = isNaN(b) ? y : y - b / 200;
27056
+
27057
+ y = labConstants.Yn * lab_xyz(y);
27058
+ x = labConstants.Xn * lab_xyz(x);
27059
+ z = labConstants.Zn * lab_xyz(z);
27060
+
27061
+ r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z); // D65 -> sRGB
27062
+ g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);
27063
+ b_ = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);
27064
+
27065
+ return [r,g,b_,args.length > 3 ? args[3] : 1];
27066
+ };
27067
+
27068
+ var xyz_rgb = function (r) {
27069
+ return 255 * (r <= 0.00304 ? 12.92 * r : 1.055 * pow$1(r, 1 / 2.4) - 0.055)
27070
+ };
27071
+
27072
+ var lab_xyz = function (t) {
27073
+ return t > labConstants.t1 ? t * t * t : labConstants.t2 * (t - labConstants.t0)
27074
+ };
27075
+
27076
+ var lab2rgb_1 = lab2rgb;
27077
+
27078
+ var unpack$m = utils.unpack;
27079
+ var type$9 = utils.type;
27080
+
27081
+
27082
+
27083
+
27084
+
27085
+
27086
+ Color_1.prototype.lab = function() {
27087
+ return rgb2lab_1(this._rgb);
27088
+ };
27089
+
27090
+ chroma_1.lab = function () {
27091
+ var args = [], len = arguments.length;
27092
+ while ( len-- ) args[ len ] = arguments[ len ];
27093
+
27094
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lab']) ));
27095
+ };
27096
+
27097
+ input.format.lab = lab2rgb_1;
27098
+
27099
+ input.autodetect.push({
27100
+ p: 2,
27101
+ test: function () {
27102
+ var args = [], len = arguments.length;
27103
+ while ( len-- ) args[ len ] = arguments[ len ];
27104
+
27105
+ args = unpack$m(args, 'lab');
27106
+ if (type$9(args) === 'array' && args.length === 3) {
27107
+ return 'lab';
27108
+ }
27109
+ }
27110
+ });
27111
+
27112
+ var unpack$n = utils.unpack;
27113
+ var RAD2DEG = utils.RAD2DEG;
27114
+ var sqrt$1 = Math.sqrt;
27115
+ var atan2 = Math.atan2;
27116
+ var round$4 = Math.round;
27117
+
27118
+ var lab2lch = function () {
27119
+ var args = [], len = arguments.length;
27120
+ while ( len-- ) args[ len ] = arguments[ len ];
27121
+
27122
+ var ref = unpack$n(args, 'lab');
27123
+ var l = ref[0];
27124
+ var a = ref[1];
27125
+ var b = ref[2];
27126
+ var c = sqrt$1(a * a + b * b);
27127
+ var h = (atan2(b, a) * RAD2DEG + 360) % 360;
27128
+ if (round$4(c*10000) === 0) { h = Number.NaN; }
27129
+ return [l, c, h];
27130
+ };
27131
+
27132
+ var lab2lch_1 = lab2lch;
27133
+
27134
+ var unpack$o = utils.unpack;
27135
+
27136
+
27137
+
27138
+ var rgb2lch = function () {
27139
+ var args = [], len = arguments.length;
27140
+ while ( len-- ) args[ len ] = arguments[ len ];
27141
+
27142
+ var ref = unpack$o(args, 'rgb');
27143
+ var r = ref[0];
27144
+ var g = ref[1];
27145
+ var b = ref[2];
27146
+ var ref$1 = rgb2lab_1(r,g,b);
27147
+ var l = ref$1[0];
27148
+ var a = ref$1[1];
27149
+ var b_ = ref$1[2];
27150
+ return lab2lch_1(l,a,b_);
27151
+ };
27152
+
27153
+ var rgb2lch_1 = rgb2lch;
27154
+
27155
+ var unpack$p = utils.unpack;
27156
+ var DEG2RAD = utils.DEG2RAD;
27157
+ var sin = Math.sin;
27158
+ var cos$1 = Math.cos;
27159
+
27160
+ var lch2lab = function () {
27161
+ var args = [], len = arguments.length;
27162
+ while ( len-- ) args[ len ] = arguments[ len ];
27163
+
27164
+ /*
27165
+ Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.
27166
+ These formulas were invented by David Dalrymple to obtain maximum contrast without going
27167
+ out of gamut if the parameters are in the range 0-1.
27168
+
27169
+ A saturation multiplier was added by Gregor Aisch
27170
+ */
27171
+ var ref = unpack$p(args, 'lch');
27172
+ var l = ref[0];
27173
+ var c = ref[1];
27174
+ var h = ref[2];
27175
+ if (isNaN(h)) { h = 0; }
27176
+ h = h * DEG2RAD;
27177
+ return [l, cos$1(h) * c, sin(h) * c]
27178
+ };
27179
+
27180
+ var lch2lab_1 = lch2lab;
27181
+
27182
+ var unpack$q = utils.unpack;
27183
+
27184
+
27185
+
27186
+ var lch2rgb = function () {
27187
+ var args = [], len = arguments.length;
27188
+ while ( len-- ) args[ len ] = arguments[ len ];
27189
+
27190
+ args = unpack$q(args, 'lch');
27191
+ var l = args[0];
27192
+ var c = args[1];
27193
+ var h = args[2];
27194
+ var ref = lch2lab_1 (l,c,h);
27195
+ var L = ref[0];
27196
+ var a = ref[1];
27197
+ var b_ = ref[2];
27198
+ var ref$1 = lab2rgb_1 (L,a,b_);
27199
+ var r = ref$1[0];
27200
+ var g = ref$1[1];
27201
+ var b = ref$1[2];
27202
+ return [r, g, b, args.length > 3 ? args[3] : 1];
27203
+ };
27204
+
27205
+ var lch2rgb_1 = lch2rgb;
27206
+
27207
+ var unpack$r = utils.unpack;
27208
+
27209
+
27210
+ var hcl2rgb = function () {
27211
+ var args = [], len = arguments.length;
27212
+ while ( len-- ) args[ len ] = arguments[ len ];
27213
+
27214
+ var hcl = unpack$r(args, 'hcl').reverse();
27215
+ return lch2rgb_1.apply(void 0, hcl);
27216
+ };
27217
+
27218
+ var hcl2rgb_1 = hcl2rgb;
27219
+
27220
+ var unpack$s = utils.unpack;
27221
+ var type$a = utils.type;
27222
+
27223
+
27224
+
27225
+
27226
+
27227
+
27228
+ Color_1.prototype.lch = function() { return rgb2lch_1(this._rgb); };
27229
+ Color_1.prototype.hcl = function() { return rgb2lch_1(this._rgb).reverse(); };
27230
+
27231
+ chroma_1.lch = function () {
27232
+ var args = [], len = arguments.length;
27233
+ while ( len-- ) args[ len ] = arguments[ len ];
27234
+
27235
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lch']) ));
27236
+ };
27237
+ chroma_1.hcl = function () {
27238
+ var args = [], len = arguments.length;
27239
+ while ( len-- ) args[ len ] = arguments[ len ];
27240
+
27241
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcl']) ));
27242
+ };
27243
+
27244
+ input.format.lch = lch2rgb_1;
27245
+ input.format.hcl = hcl2rgb_1;
27246
+
27247
+ ['lch','hcl'].forEach(function (m) { return input.autodetect.push({
27248
+ p: 2,
27249
+ test: function () {
27250
+ var args = [], len = arguments.length;
27251
+ while ( len-- ) args[ len ] = arguments[ len ];
27252
+
27253
+ args = unpack$s(args, m);
27254
+ if (type$a(args) === 'array' && args.length === 3) {
27255
+ return m;
27256
+ }
27257
+ }
27258
+ }); });
27259
+
27260
+ /**
27261
+ X11 color names
27262
+
27263
+ http://www.w3.org/TR/css3-color/#svg-color
27264
+ */
27265
+
27266
+ var w3cx11 = {
27267
+ aliceblue: '#f0f8ff',
27268
+ antiquewhite: '#faebd7',
27269
+ aqua: '#00ffff',
27270
+ aquamarine: '#7fffd4',
27271
+ azure: '#f0ffff',
27272
+ beige: '#f5f5dc',
27273
+ bisque: '#ffe4c4',
27274
+ black: '#000000',
27275
+ blanchedalmond: '#ffebcd',
27276
+ blue: '#0000ff',
27277
+ blueviolet: '#8a2be2',
27278
+ brown: '#a52a2a',
27279
+ burlywood: '#deb887',
27280
+ cadetblue: '#5f9ea0',
27281
+ chartreuse: '#7fff00',
27282
+ chocolate: '#d2691e',
27283
+ coral: '#ff7f50',
27284
+ cornflower: '#6495ed',
27285
+ cornflowerblue: '#6495ed',
27286
+ cornsilk: '#fff8dc',
27287
+ crimson: '#dc143c',
27288
+ cyan: '#00ffff',
27289
+ darkblue: '#00008b',
27290
+ darkcyan: '#008b8b',
27291
+ darkgoldenrod: '#b8860b',
27292
+ darkgray: '#a9a9a9',
27293
+ darkgreen: '#006400',
27294
+ darkgrey: '#a9a9a9',
27295
+ darkkhaki: '#bdb76b',
27296
+ darkmagenta: '#8b008b',
27297
+ darkolivegreen: '#556b2f',
27298
+ darkorange: '#ff8c00',
27299
+ darkorchid: '#9932cc',
27300
+ darkred: '#8b0000',
27301
+ darksalmon: '#e9967a',
27302
+ darkseagreen: '#8fbc8f',
27303
+ darkslateblue: '#483d8b',
27304
+ darkslategray: '#2f4f4f',
27305
+ darkslategrey: '#2f4f4f',
27306
+ darkturquoise: '#00ced1',
27307
+ darkviolet: '#9400d3',
27308
+ deeppink: '#ff1493',
27309
+ deepskyblue: '#00bfff',
27310
+ dimgray: '#696969',
27311
+ dimgrey: '#696969',
27312
+ dodgerblue: '#1e90ff',
27313
+ firebrick: '#b22222',
27314
+ floralwhite: '#fffaf0',
27315
+ forestgreen: '#228b22',
27316
+ fuchsia: '#ff00ff',
27317
+ gainsboro: '#dcdcdc',
27318
+ ghostwhite: '#f8f8ff',
27319
+ gold: '#ffd700',
27320
+ goldenrod: '#daa520',
27321
+ gray: '#808080',
27322
+ green: '#008000',
27323
+ greenyellow: '#adff2f',
27324
+ grey: '#808080',
27325
+ honeydew: '#f0fff0',
27326
+ hotpink: '#ff69b4',
27327
+ indianred: '#cd5c5c',
27328
+ indigo: '#4b0082',
27329
+ ivory: '#fffff0',
27330
+ khaki: '#f0e68c',
27331
+ laserlemon: '#ffff54',
27332
+ lavender: '#e6e6fa',
27333
+ lavenderblush: '#fff0f5',
27334
+ lawngreen: '#7cfc00',
27335
+ lemonchiffon: '#fffacd',
27336
+ lightblue: '#add8e6',
27337
+ lightcoral: '#f08080',
27338
+ lightcyan: '#e0ffff',
27339
+ lightgoldenrod: '#fafad2',
27340
+ lightgoldenrodyellow: '#fafad2',
27341
+ lightgray: '#d3d3d3',
27342
+ lightgreen: '#90ee90',
27343
+ lightgrey: '#d3d3d3',
27344
+ lightpink: '#ffb6c1',
27345
+ lightsalmon: '#ffa07a',
27346
+ lightseagreen: '#20b2aa',
27347
+ lightskyblue: '#87cefa',
27348
+ lightslategray: '#778899',
27349
+ lightslategrey: '#778899',
27350
+ lightsteelblue: '#b0c4de',
27351
+ lightyellow: '#ffffe0',
27352
+ lime: '#00ff00',
27353
+ limegreen: '#32cd32',
27354
+ linen: '#faf0e6',
27355
+ magenta: '#ff00ff',
27356
+ maroon: '#800000',
27357
+ maroon2: '#7f0000',
27358
+ maroon3: '#b03060',
27359
+ mediumaquamarine: '#66cdaa',
27360
+ mediumblue: '#0000cd',
27361
+ mediumorchid: '#ba55d3',
27362
+ mediumpurple: '#9370db',
27363
+ mediumseagreen: '#3cb371',
27364
+ mediumslateblue: '#7b68ee',
27365
+ mediumspringgreen: '#00fa9a',
27366
+ mediumturquoise: '#48d1cc',
27367
+ mediumvioletred: '#c71585',
27368
+ midnightblue: '#191970',
27369
+ mintcream: '#f5fffa',
27370
+ mistyrose: '#ffe4e1',
27371
+ moccasin: '#ffe4b5',
27372
+ navajowhite: '#ffdead',
27373
+ navy: '#000080',
27374
+ oldlace: '#fdf5e6',
27375
+ olive: '#808000',
27376
+ olivedrab: '#6b8e23',
27377
+ orange: '#ffa500',
27378
+ orangered: '#ff4500',
27379
+ orchid: '#da70d6',
27380
+ palegoldenrod: '#eee8aa',
27381
+ palegreen: '#98fb98',
27382
+ paleturquoise: '#afeeee',
27383
+ palevioletred: '#db7093',
27384
+ papayawhip: '#ffefd5',
27385
+ peachpuff: '#ffdab9',
27386
+ peru: '#cd853f',
27387
+ pink: '#ffc0cb',
27388
+ plum: '#dda0dd',
27389
+ powderblue: '#b0e0e6',
27390
+ purple: '#800080',
27391
+ purple2: '#7f007f',
27392
+ purple3: '#a020f0',
27393
+ rebeccapurple: '#663399',
27394
+ red: '#ff0000',
27395
+ rosybrown: '#bc8f8f',
27396
+ royalblue: '#4169e1',
27397
+ saddlebrown: '#8b4513',
27398
+ salmon: '#fa8072',
27399
+ sandybrown: '#f4a460',
27400
+ seagreen: '#2e8b57',
27401
+ seashell: '#fff5ee',
27402
+ sienna: '#a0522d',
27403
+ silver: '#c0c0c0',
27404
+ skyblue: '#87ceeb',
27405
+ slateblue: '#6a5acd',
27406
+ slategray: '#708090',
27407
+ slategrey: '#708090',
27408
+ snow: '#fffafa',
27409
+ springgreen: '#00ff7f',
27410
+ steelblue: '#4682b4',
27411
+ tan: '#d2b48c',
27412
+ teal: '#008080',
27413
+ thistle: '#d8bfd8',
27414
+ tomato: '#ff6347',
27415
+ turquoise: '#40e0d0',
27416
+ violet: '#ee82ee',
27417
+ wheat: '#f5deb3',
27418
+ white: '#ffffff',
27419
+ whitesmoke: '#f5f5f5',
27420
+ yellow: '#ffff00',
27421
+ yellowgreen: '#9acd32'
27422
+ };
27423
+
27424
+ var w3cx11_1 = w3cx11;
27425
+
27426
+ var type$b = utils.type;
27427
+
27428
+
27429
+
27430
+
27431
+
27432
+ Color_1.prototype.name = function() {
27433
+ var hex = rgb2hex_1(this._rgb, 'rgb');
27434
+ for (var i = 0, list = Object.keys(w3cx11_1); i < list.length; i += 1) {
27435
+ var n = list[i];
27436
+
27437
+ if (w3cx11_1[n] === hex) { return n.toLowerCase(); }
27438
+ }
27439
+ return hex;
27440
+ };
27441
+
27442
+ input.format.named = function (name) {
27443
+ name = name.toLowerCase();
27444
+ if (w3cx11_1[name]) { return hex2rgb_1(w3cx11_1[name]); }
27445
+ throw new Error('unknown color name: '+name);
27446
+ };
27447
+
27448
+ input.autodetect.push({
27449
+ p: 5,
27450
+ test: function (h) {
27451
+ var rest = [], len = arguments.length - 1;
27452
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
27453
+
27454
+ if (!rest.length && type$b(h) === 'string' && w3cx11_1[h.toLowerCase()]) {
27455
+ return 'named';
27456
+ }
27457
+ }
27458
+ });
27459
+
27460
+ var unpack$t = utils.unpack;
27461
+
27462
+ var rgb2num = function () {
27463
+ var args = [], len = arguments.length;
27464
+ while ( len-- ) args[ len ] = arguments[ len ];
27465
+
27466
+ var ref = unpack$t(args, 'rgb');
27467
+ var r = ref[0];
27468
+ var g = ref[1];
27469
+ var b = ref[2];
27470
+ return (r << 16) + (g << 8) + b;
27471
+ };
27472
+
27473
+ var rgb2num_1 = rgb2num;
27474
+
27475
+ var type$c = utils.type;
27476
+
27477
+ var num2rgb = function (num) {
27478
+ if (type$c(num) == "number" && num >= 0 && num <= 0xFFFFFF) {
27479
+ var r = num >> 16;
27480
+ var g = (num >> 8) & 0xFF;
27481
+ var b = num & 0xFF;
27482
+ return [r,g,b,1];
27483
+ }
27484
+ throw new Error("unknown num color: "+num);
27485
+ };
27486
+
27487
+ var num2rgb_1 = num2rgb;
27488
+
27489
+ var type$d = utils.type;
27490
+
27491
+
27492
+
27493
+ Color_1.prototype.num = function() {
27494
+ return rgb2num_1(this._rgb);
27495
+ };
27496
+
27497
+ chroma_1.num = function () {
27498
+ var args = [], len = arguments.length;
27499
+ while ( len-- ) args[ len ] = arguments[ len ];
27500
+
27501
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['num']) ));
27502
+ };
27503
+
27504
+ input.format.num = num2rgb_1;
27505
+
27506
+ input.autodetect.push({
27507
+ p: 5,
27508
+ test: function () {
27509
+ var args = [], len = arguments.length;
27510
+ while ( len-- ) args[ len ] = arguments[ len ];
27511
+
27512
+ if (args.length === 1 && type$d(args[0]) === 'number' && args[0] >= 0 && args[0] <= 0xFFFFFF) {
27513
+ return 'num';
27514
+ }
27515
+ }
27516
+ });
27517
+
27518
+ var unpack$u = utils.unpack;
27519
+ var type$e = utils.type;
27520
+ var round$5 = Math.round;
27521
+
27522
+ Color_1.prototype.rgb = function(rnd) {
27523
+ if ( rnd === void 0 ) rnd=true;
27524
+
27525
+ if (rnd === false) { return this._rgb.slice(0,3); }
27526
+ return this._rgb.slice(0,3).map(round$5);
27527
+ };
27528
+
27529
+ Color_1.prototype.rgba = function(rnd) {
27530
+ if ( rnd === void 0 ) rnd=true;
27531
+
27532
+ return this._rgb.slice(0,4).map(function (v,i) {
27533
+ return i<3 ? (rnd === false ? v : round$5(v)) : v;
27534
+ });
27535
+ };
27536
+
27537
+ chroma_1.rgb = function () {
27538
+ var args = [], len = arguments.length;
27539
+ while ( len-- ) args[ len ] = arguments[ len ];
27540
+
27541
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['rgb']) ));
27542
+ };
27543
+
27544
+ input.format.rgb = function () {
27545
+ var args = [], len = arguments.length;
27546
+ while ( len-- ) args[ len ] = arguments[ len ];
27547
+
27548
+ var rgba = unpack$u(args, 'rgba');
27549
+ if (rgba[3] === undefined) { rgba[3] = 1; }
27550
+ return rgba;
27551
+ };
27552
+
27553
+ input.autodetect.push({
27554
+ p: 3,
27555
+ test: function () {
27556
+ var args = [], len = arguments.length;
27557
+ while ( len-- ) args[ len ] = arguments[ len ];
27558
+
27559
+ args = unpack$u(args, 'rgba');
27560
+ if (type$e(args) === 'array' && (args.length === 3 ||
27561
+ args.length === 4 && type$e(args[3]) == 'number' && args[3] >= 0 && args[3] <= 1)) {
27562
+ return 'rgb';
27563
+ }
27564
+ }
27565
+ });
27566
+
27567
+ /*
27568
+ * Based on implementation by Neil Bartlett
27569
+ * https://github.com/neilbartlett/color-temperature
27570
+ */
27571
+
27572
+ var log = Math.log;
27573
+
27574
+ var temperature2rgb = function (kelvin) {
27575
+ var temp = kelvin / 100;
27576
+ var r,g,b;
27577
+ if (temp < 66) {
27578
+ r = 255;
27579
+ g = -155.25485562709179 - 0.44596950469579133 * (g = temp-2) + 104.49216199393888 * log(g);
27580
+ b = temp < 20 ? 0 : -254.76935184120902 + 0.8274096064007395 * (b = temp-10) + 115.67994401066147 * log(b);
27581
+ } else {
27582
+ r = 351.97690566805693 + 0.114206453784165 * (r = temp-55) - 40.25366309332127 * log(r);
27583
+ g = 325.4494125711974 + 0.07943456536662342 * (g = temp-50) - 28.0852963507957 * log(g);
27584
+ b = 255;
27585
+ }
27586
+ return [r,g,b,1];
27587
+ };
27588
+
27589
+ var temperature2rgb_1 = temperature2rgb;
27590
+
27591
+ /*
27592
+ * Based on implementation by Neil Bartlett
27593
+ * https://github.com/neilbartlett/color-temperature
27594
+ **/
27595
+
27596
+
27597
+ var unpack$v = utils.unpack;
27598
+ var round$6 = Math.round;
27599
+
27600
+ var rgb2temperature = function () {
27601
+ var args = [], len = arguments.length;
27602
+ while ( len-- ) args[ len ] = arguments[ len ];
27603
+
27604
+ var rgb = unpack$v(args, 'rgb');
27605
+ var r = rgb[0], b = rgb[2];
27606
+ var minTemp = 1000;
27607
+ var maxTemp = 40000;
27608
+ var eps = 0.4;
27609
+ var temp;
27610
+ while (maxTemp - minTemp > eps) {
27611
+ temp = (maxTemp + minTemp) * 0.5;
27612
+ var rgb$1 = temperature2rgb_1(temp);
27613
+ if ((rgb$1[2] / rgb$1[0]) >= (b / r)) {
27614
+ maxTemp = temp;
27615
+ } else {
27616
+ minTemp = temp;
27617
+ }
27618
+ }
27619
+ return round$6(temp);
27620
+ };
27621
+
27622
+ var rgb2temperature_1 = rgb2temperature;
27623
+
27624
+ Color_1.prototype.temp =
27625
+ Color_1.prototype.kelvin =
27626
+ Color_1.prototype.temperature = function() {
27627
+ return rgb2temperature_1(this._rgb);
27628
+ };
27629
+
27630
+ chroma_1.temp =
27631
+ chroma_1.kelvin =
27632
+ chroma_1.temperature = function () {
27633
+ var args = [], len = arguments.length;
27634
+ while ( len-- ) args[ len ] = arguments[ len ];
27635
+
27636
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['temp']) ));
27637
+ };
27638
+
27639
+ input.format.temp =
27640
+ input.format.kelvin =
27641
+ input.format.temperature = temperature2rgb_1;
27642
+
27643
+ var type$f = utils.type;
27644
+
27645
+ Color_1.prototype.alpha = function(a, mutate) {
27646
+ if ( mutate === void 0 ) mutate=false;
27647
+
27648
+ if (a !== undefined && type$f(a) === 'number') {
27649
+ if (mutate) {
27650
+ this._rgb[3] = a;
27651
+ return this;
27652
+ }
27653
+ return new Color_1([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');
27654
+ }
27655
+ return this._rgb[3];
27656
+ };
27657
+
27658
+ Color_1.prototype.clipped = function() {
27659
+ return this._rgb._clipped || false;
27660
+ };
27661
+
27662
+ Color_1.prototype.darken = function(amount) {
27663
+ if ( amount === void 0 ) amount=1;
27664
+
27665
+ var me = this;
27666
+ var lab = me.lab();
27667
+ lab[0] -= labConstants.Kn * amount;
27668
+ return new Color_1(lab, 'lab').alpha(me.alpha(), true);
27669
+ };
27670
+
27671
+ Color_1.prototype.brighten = function(amount) {
27672
+ if ( amount === void 0 ) amount=1;
27673
+
27674
+ return this.darken(-amount);
27675
+ };
27676
+
27677
+ Color_1.prototype.darker = Color_1.prototype.darken;
27678
+ Color_1.prototype.brighter = Color_1.prototype.brighten;
27679
+
27680
+ Color_1.prototype.get = function(mc) {
27681
+ var ref = mc.split('.');
27682
+ var mode = ref[0];
27683
+ var channel = ref[1];
27684
+ var src = this[mode]();
27685
+ if (channel) {
27686
+ var i = mode.indexOf(channel);
27687
+ if (i > -1) { return src[i]; }
27688
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
27689
+ } else {
27690
+ return src;
27691
+ }
27692
+ };
27693
+
27694
+ var type$g = utils.type;
27695
+ var pow$2 = Math.pow;
27696
+
27697
+ var EPS = 1e-7;
27698
+ var MAX_ITER = 20;
27699
+
27700
+ Color_1.prototype.luminance = function(lum) {
27701
+ if (lum !== undefined && type$g(lum) === 'number') {
27702
+ if (lum === 0) {
27703
+ // return pure black
27704
+ return new Color_1([0,0,0,this._rgb[3]], 'rgb');
27705
+ }
27706
+ if (lum === 1) {
27707
+ // return pure white
27708
+ return new Color_1([255,255,255,this._rgb[3]], 'rgb');
27709
+ }
27710
+ // compute new color using...
27711
+ var cur_lum = this.luminance();
27712
+ var mode = 'rgb';
27713
+ var max_iter = MAX_ITER;
27714
+
27715
+ var test = function (low, high) {
27716
+ var mid = low.interpolate(high, 0.5, mode);
27717
+ var lm = mid.luminance();
27718
+ if (Math.abs(lum - lm) < EPS || !max_iter--) {
27719
+ // close enough
27720
+ return mid;
27721
+ }
27722
+ return lm > lum ? test(low, mid) : test(mid, high);
27723
+ };
27724
+
27725
+ var rgb = (cur_lum > lum ? test(new Color_1([0,0,0]), this) : test(this, new Color_1([255,255,255]))).rgb();
27726
+ return new Color_1(rgb.concat( [this._rgb[3]]));
27727
+ }
27728
+ return rgb2luminance.apply(void 0, (this._rgb).slice(0,3));
27729
+ };
27730
+
27731
+
27732
+ var rgb2luminance = function (r,g,b) {
27733
+ // relative luminance
27734
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef
27735
+ r = luminance_x(r);
27736
+ g = luminance_x(g);
27737
+ b = luminance_x(b);
27738
+ return 0.2126 * r + 0.7152 * g + 0.0722 * b;
27739
+ };
27740
+
27741
+ var luminance_x = function (x) {
27742
+ x /= 255;
27743
+ return x <= 0.03928 ? x/12.92 : pow$2((x+0.055)/1.055, 2.4);
27744
+ };
27745
+
27746
+ var interpolator = {};
27747
+
27748
+ var type$h = utils.type;
27749
+
27750
+
27751
+ var mix = function (col1, col2, f) {
27752
+ if ( f === void 0 ) f=0.5;
27753
+ var rest = [], len = arguments.length - 3;
27754
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];
27755
+
27756
+ var mode = rest[0] || 'lrgb';
27757
+ if (!interpolator[mode] && !rest.length) {
27758
+ // fall back to the first supported mode
27759
+ mode = Object.keys(interpolator)[0];
27760
+ }
27761
+ if (!interpolator[mode]) {
27762
+ throw new Error(("interpolation mode " + mode + " is not defined"));
27763
+ }
27764
+ if (type$h(col1) !== 'object') { col1 = new Color_1(col1); }
27765
+ if (type$h(col2) !== 'object') { col2 = new Color_1(col2); }
27766
+ return interpolator[mode](col1, col2, f)
27767
+ .alpha(col1.alpha() + f * (col2.alpha() - col1.alpha()));
27768
+ };
27769
+
27770
+ Color_1.prototype.mix =
27771
+ Color_1.prototype.interpolate = function(col2, f) {
27772
+ if ( f === void 0 ) f=0.5;
27773
+ var rest = [], len = arguments.length - 2;
27774
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];
27775
+
27776
+ return mix.apply(void 0, [ this, col2, f ].concat( rest ));
27777
+ };
27778
+
27779
+ Color_1.prototype.premultiply = function(mutate) {
27780
+ if ( mutate === void 0 ) mutate=false;
27781
+
27782
+ var rgb = this._rgb;
27783
+ var a = rgb[3];
27784
+ if (mutate) {
27785
+ this._rgb = [rgb[0]*a, rgb[1]*a, rgb[2]*a, a];
27786
+ return this;
27787
+ } else {
27788
+ return new Color_1([rgb[0]*a, rgb[1]*a, rgb[2]*a, a], 'rgb');
27789
+ }
27790
+ };
27791
+
27792
+ Color_1.prototype.saturate = function(amount) {
27793
+ if ( amount === void 0 ) amount=1;
27794
+
27795
+ var me = this;
27796
+ var lch = me.lch();
27797
+ lch[1] += labConstants.Kn * amount;
27798
+ if (lch[1] < 0) { lch[1] = 0; }
27799
+ return new Color_1(lch, 'lch').alpha(me.alpha(), true);
27800
+ };
27801
+
27802
+ Color_1.prototype.desaturate = function(amount) {
27803
+ if ( amount === void 0 ) amount=1;
27804
+
27805
+ return this.saturate(-amount);
27806
+ };
27807
+
27808
+ var type$i = utils.type;
27809
+
27810
+ Color_1.prototype.set = function(mc, value, mutate) {
27811
+ if ( mutate === void 0 ) mutate=false;
27812
+
27813
+ var ref = mc.split('.');
27814
+ var mode = ref[0];
27815
+ var channel = ref[1];
27816
+ var src = this[mode]();
27817
+ if (channel) {
27818
+ var i = mode.indexOf(channel);
27819
+ if (i > -1) {
27820
+ if (type$i(value) == 'string') {
27821
+ switch(value.charAt(0)) {
27822
+ case '+': src[i] += +value; break;
27823
+ case '-': src[i] += +value; break;
27824
+ case '*': src[i] *= +(value.substr(1)); break;
27825
+ case '/': src[i] /= +(value.substr(1)); break;
27826
+ default: src[i] = +value;
27827
+ }
27828
+ } else if (type$i(value) === 'number') {
27829
+ src[i] = value;
27830
+ } else {
27831
+ throw new Error("unsupported value for Color.set");
27832
+ }
27833
+ var out = new Color_1(src, mode);
27834
+ if (mutate) {
27835
+ this._rgb = out._rgb;
27836
+ return this;
27837
+ }
27838
+ return out;
27839
+ }
27840
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
27841
+ } else {
27842
+ return src;
27843
+ }
27844
+ };
27845
+
27846
+ var rgb$1 = function (col1, col2, f) {
27847
+ var xyz0 = col1._rgb;
27848
+ var xyz1 = col2._rgb;
27849
+ return new Color_1(
27850
+ xyz0[0] + f * (xyz1[0]-xyz0[0]),
27851
+ xyz0[1] + f * (xyz1[1]-xyz0[1]),
27852
+ xyz0[2] + f * (xyz1[2]-xyz0[2]),
27853
+ 'rgb'
27854
+ )
27855
+ };
27856
+
27857
+ // register interpolator
27858
+ interpolator.rgb = rgb$1;
27859
+
27860
+ var sqrt$2 = Math.sqrt;
27861
+ var pow$3 = Math.pow;
27862
+
27863
+ var lrgb = function (col1, col2, f) {
27864
+ var ref = col1._rgb;
27865
+ var x1 = ref[0];
27866
+ var y1 = ref[1];
27867
+ var z1 = ref[2];
27868
+ var ref$1 = col2._rgb;
27869
+ var x2 = ref$1[0];
27870
+ var y2 = ref$1[1];
27871
+ var z2 = ref$1[2];
27872
+ return new Color_1(
27873
+ sqrt$2(pow$3(x1,2) * (1-f) + pow$3(x2,2) * f),
27874
+ sqrt$2(pow$3(y1,2) * (1-f) + pow$3(y2,2) * f),
27875
+ sqrt$2(pow$3(z1,2) * (1-f) + pow$3(z2,2) * f),
27876
+ 'rgb'
27877
+ )
27878
+ };
27879
+
27880
+ // register interpolator
27881
+ interpolator.lrgb = lrgb;
27882
+
27883
+ var lab$1 = function (col1, col2, f) {
27884
+ var xyz0 = col1.lab();
27885
+ var xyz1 = col2.lab();
27886
+ return new Color_1(
27887
+ xyz0[0] + f * (xyz1[0]-xyz0[0]),
27888
+ xyz0[1] + f * (xyz1[1]-xyz0[1]),
27889
+ xyz0[2] + f * (xyz1[2]-xyz0[2]),
27890
+ 'lab'
27891
+ )
27892
+ };
27893
+
27894
+ // register interpolator
27895
+ interpolator.lab = lab$1;
27896
+
27897
+ var _hsx = function (col1, col2, f, m) {
27898
+ var assign, assign$1;
27899
+
27900
+ var xyz0, xyz1;
27901
+ if (m === 'hsl') {
27902
+ xyz0 = col1.hsl();
27903
+ xyz1 = col2.hsl();
27904
+ } else if (m === 'hsv') {
27905
+ xyz0 = col1.hsv();
27906
+ xyz1 = col2.hsv();
27907
+ } else if (m === 'hcg') {
27908
+ xyz0 = col1.hcg();
27909
+ xyz1 = col2.hcg();
27910
+ } else if (m === 'hsi') {
27911
+ xyz0 = col1.hsi();
27912
+ xyz1 = col2.hsi();
27913
+ } else if (m === 'lch' || m === 'hcl') {
27914
+ m = 'hcl';
27915
+ xyz0 = col1.hcl();
27916
+ xyz1 = col2.hcl();
27917
+ }
27918
+
27919
+ var hue0, hue1, sat0, sat1, lbv0, lbv1;
27920
+ if (m.substr(0, 1) === 'h') {
27921
+ (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);
27922
+ (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);
27923
+ }
27924
+
27925
+ var sat, hue, lbv, dh;
27926
+
27927
+ if (!isNaN(hue0) && !isNaN(hue1)) {
27928
+ // both colors have hue
27929
+ if (hue1 > hue0 && hue1 - hue0 > 180) {
27930
+ dh = hue1-(hue0+360);
27931
+ } else if (hue1 < hue0 && hue0 - hue1 > 180) {
27932
+ dh = hue1+360-hue0;
27933
+ } else {
27934
+ dh = hue1 - hue0;
27935
+ }
27936
+ hue = hue0 + f * dh;
27937
+ } else if (!isNaN(hue0)) {
27938
+ hue = hue0;
27939
+ if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }
27940
+ } else if (!isNaN(hue1)) {
27941
+ hue = hue1;
27942
+ if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }
27943
+ } else {
27944
+ hue = Number.NaN;
27945
+ }
27946
+
27947
+ if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }
27948
+ lbv = lbv0 + f * (lbv1-lbv0);
27949
+ return new Color_1([hue, sat, lbv], m);
27950
+ };
27951
+
27952
+ var lch$1 = function (col1, col2, f) {
27953
+ return _hsx(col1, col2, f, 'lch');
27954
+ };
27955
+
27956
+ // register interpolator
27957
+ interpolator.lch = lch$1;
27958
+ interpolator.hcl = lch$1;
27959
+
27960
+ var num$1 = function (col1, col2, f) {
27961
+ var c1 = col1.num();
27962
+ var c2 = col2.num();
27963
+ return new Color_1(c1 + f * (c2-c1), 'num')
27964
+ };
27965
+
27966
+ // register interpolator
27967
+ interpolator.num = num$1;
27968
+
27969
+ var hcg$1 = function (col1, col2, f) {
27970
+ return _hsx(col1, col2, f, 'hcg');
27971
+ };
27972
+
27973
+ // register interpolator
27974
+ interpolator.hcg = hcg$1;
27975
+
27976
+ var hsi$1 = function (col1, col2, f) {
27977
+ return _hsx(col1, col2, f, 'hsi');
27978
+ };
27979
+
27980
+ // register interpolator
27981
+ interpolator.hsi = hsi$1;
27982
+
27983
+ var hsl$1 = function (col1, col2, f) {
27984
+ return _hsx(col1, col2, f, 'hsl');
27985
+ };
27986
+
27987
+ // register interpolator
27988
+ interpolator.hsl = hsl$1;
27989
+
27990
+ var hsv$1 = function (col1, col2, f) {
27991
+ return _hsx(col1, col2, f, 'hsv');
27992
+ };
27993
+
27994
+ // register interpolator
27995
+ interpolator.hsv = hsv$1;
27996
+
27997
+ var clip_rgb$2 = utils.clip_rgb;
27998
+ var pow$4 = Math.pow;
27999
+ var sqrt$3 = Math.sqrt;
28000
+ var PI$1 = Math.PI;
28001
+ var cos$2 = Math.cos;
28002
+ var sin$1 = Math.sin;
28003
+ var atan2$1 = Math.atan2;
28004
+
28005
+ var average = function (colors, mode, weights) {
28006
+ if ( mode === void 0 ) mode='lrgb';
28007
+ if ( weights === void 0 ) weights=null;
28008
+
28009
+ var l = colors.length;
28010
+ if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }
28011
+ // normalize weights
28012
+ var k = l / weights.reduce(function(a, b) { return a + b; });
28013
+ weights.forEach(function (w,i) { weights[i] *= k; });
28014
+ // convert colors to Color objects
28015
+ colors = colors.map(function (c) { return new Color_1(c); });
28016
+ if (mode === 'lrgb') {
28017
+ return _average_lrgb(colors, weights)
28018
+ }
28019
+ var first = colors.shift();
28020
+ var xyz = first.get(mode);
28021
+ var cnt = [];
28022
+ var dx = 0;
28023
+ var dy = 0;
28024
+ // initial color
28025
+ for (var i=0; i<xyz.length; i++) {
28026
+ xyz[i] = (xyz[i] || 0) * weights[0];
28027
+ cnt.push(isNaN(xyz[i]) ? 0 : weights[0]);
28028
+ if (mode.charAt(i) === 'h' && !isNaN(xyz[i])) {
28029
+ var A = xyz[i] / 180 * PI$1;
28030
+ dx += cos$2(A) * weights[0];
28031
+ dy += sin$1(A) * weights[0];
28032
+ }
28033
+ }
28034
+
28035
+ var alpha = first.alpha() * weights[0];
28036
+ colors.forEach(function (c,ci) {
28037
+ var xyz2 = c.get(mode);
28038
+ alpha += c.alpha() * weights[ci+1];
28039
+ for (var i=0; i<xyz.length; i++) {
28040
+ if (!isNaN(xyz2[i])) {
28041
+ cnt[i] += weights[ci+1];
28042
+ if (mode.charAt(i) === 'h') {
28043
+ var A = xyz2[i] / 180 * PI$1;
28044
+ dx += cos$2(A) * weights[ci+1];
28045
+ dy += sin$1(A) * weights[ci+1];
28046
+ } else {
28047
+ xyz[i] += xyz2[i] * weights[ci+1];
28048
+ }
28049
+ }
28050
+ }
28051
+ });
28052
+
28053
+ for (var i$1=0; i$1<xyz.length; i$1++) {
28054
+ if (mode.charAt(i$1) === 'h') {
28055
+ var A$1 = atan2$1(dy / cnt[i$1], dx / cnt[i$1]) / PI$1 * 180;
28056
+ while (A$1 < 0) { A$1 += 360; }
28057
+ while (A$1 >= 360) { A$1 -= 360; }
28058
+ xyz[i$1] = A$1;
28059
+ } else {
28060
+ xyz[i$1] = xyz[i$1]/cnt[i$1];
28061
+ }
28062
+ }
28063
+ alpha /= l;
28064
+ return (new Color_1(xyz, mode)).alpha(alpha > 0.99999 ? 1 : alpha, true);
28065
+ };
28066
+
28067
+
28068
+ var _average_lrgb = function (colors, weights) {
28069
+ var l = colors.length;
28070
+ var xyz = [0,0,0,0];
28071
+ for (var i=0; i < colors.length; i++) {
28072
+ var col = colors[i];
28073
+ var f = weights[i] / l;
28074
+ var rgb = col._rgb;
28075
+ xyz[0] += pow$4(rgb[0],2) * f;
28076
+ xyz[1] += pow$4(rgb[1],2) * f;
28077
+ xyz[2] += pow$4(rgb[2],2) * f;
28078
+ xyz[3] += rgb[3] * f;
28079
+ }
28080
+ xyz[0] = sqrt$3(xyz[0]);
28081
+ xyz[1] = sqrt$3(xyz[1]);
28082
+ xyz[2] = sqrt$3(xyz[2]);
28083
+ if (xyz[3] > 0.9999999) { xyz[3] = 1; }
28084
+ return new Color_1(clip_rgb$2(xyz));
28085
+ };
28086
+
28087
+ // minimal multi-purpose interface
28088
+
28089
+ // @requires utils color analyze
28090
+
28091
+
28092
+ var type$j = utils.type;
28093
+
28094
+ var pow$5 = Math.pow;
28095
+
28096
+ var scale = function(colors) {
28097
+
28098
+ // constructor
28099
+ var _mode = 'rgb';
28100
+ var _nacol = chroma_1('#ccc');
28101
+ var _spread = 0;
28102
+ // const _fixed = false;
28103
+ var _domain = [0, 1];
28104
+ var _pos = [];
28105
+ var _padding = [0,0];
28106
+ var _classes = false;
28107
+ var _colors = [];
28108
+ var _out = false;
28109
+ var _min = 0;
28110
+ var _max = 1;
28111
+ var _correctLightness = false;
28112
+ var _colorCache = {};
28113
+ var _useCache = true;
28114
+ var _gamma = 1;
28115
+
28116
+ // private methods
28117
+
28118
+ var setColors = function(colors) {
28119
+ colors = colors || ['#fff', '#000'];
28120
+ if (colors && type$j(colors) === 'string' && chroma_1.brewer &&
28121
+ chroma_1.brewer[colors.toLowerCase()]) {
28122
+ colors = chroma_1.brewer[colors.toLowerCase()];
28123
+ }
28124
+ if (type$j(colors) === 'array') {
28125
+ // handle single color
28126
+ if (colors.length === 1) {
28127
+ colors = [colors[0], colors[0]];
28128
+ }
28129
+ // make a copy of the colors
28130
+ colors = colors.slice(0);
28131
+ // convert to chroma classes
28132
+ for (var c=0; c<colors.length; c++) {
28133
+ colors[c] = chroma_1(colors[c]);
28134
+ }
28135
+ // auto-fill color position
28136
+ _pos.length = 0;
28137
+ for (var c$1=0; c$1<colors.length; c$1++) {
28138
+ _pos.push(c$1/(colors.length-1));
28139
+ }
28140
+ }
28141
+ resetCache();
28142
+ return _colors = colors;
28143
+ };
28144
+
28145
+ var getClass = function(value) {
28146
+ if (_classes != null) {
28147
+ var n = _classes.length-1;
28148
+ var i = 0;
28149
+ while (i < n && value >= _classes[i]) {
28150
+ i++;
28151
+ }
28152
+ return i-1;
28153
+ }
28154
+ return 0;
28155
+ };
28156
+
28157
+ var tMapLightness = function (t) { return t; };
28158
+ var tMapDomain = function (t) { return t; };
28159
+
28160
+ // const classifyValue = function(value) {
28161
+ // let val = value;
28162
+ // if (_classes.length > 2) {
28163
+ // const n = _classes.length-1;
28164
+ // const i = getClass(value);
28165
+ // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class
28166
+ // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class
28167
+ // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));
28168
+ // }
28169
+ // return val;
28170
+ // };
28171
+
28172
+ var getColor = function(val, bypassMap) {
28173
+ var col, t;
28174
+ if (bypassMap == null) { bypassMap = false; }
28175
+ if (isNaN(val) || (val === null)) { return _nacol; }
28176
+ if (!bypassMap) {
28177
+ if (_classes && (_classes.length > 2)) {
28178
+ // find the class
28179
+ var c = getClass(val);
28180
+ t = c / (_classes.length-2);
28181
+ } else if (_max !== _min) {
28182
+ // just interpolate between min/max
28183
+ t = (val - _min) / (_max - _min);
28184
+ } else {
28185
+ t = 1;
28186
+ }
28187
+ } else {
28188
+ t = val;
28189
+ }
28190
+
28191
+ // domain map
28192
+ t = tMapDomain(t);
28193
+
28194
+ if (!bypassMap) {
28195
+ t = tMapLightness(t); // lightness correction
28196
+ }
28197
+
28198
+ if (_gamma !== 1) { t = pow$5(t, _gamma); }
28199
+
28200
+ t = _padding[0] + (t * (1 - _padding[0] - _padding[1]));
28201
+
28202
+ t = Math.min(1, Math.max(0, t));
28203
+
28204
+ var k = Math.floor(t * 10000);
28205
+
28206
+ if (_useCache && _colorCache[k]) {
28207
+ col = _colorCache[k];
28208
+ } else {
28209
+ if (type$j(_colors) === 'array') {
28210
+ //for i in [0.._pos.length-1]
28211
+ for (var i=0; i<_pos.length; i++) {
28212
+ var p = _pos[i];
28213
+ if (t <= p) {
28214
+ col = _colors[i];
28215
+ break;
28216
+ }
28217
+ if ((t >= p) && (i === (_pos.length-1))) {
28218
+ col = _colors[i];
28219
+ break;
28220
+ }
28221
+ if (t > p && t < _pos[i+1]) {
28222
+ t = (t-p)/(_pos[i+1]-p);
28223
+ col = chroma_1.interpolate(_colors[i], _colors[i+1], t, _mode);
28224
+ break;
28225
+ }
28226
+ }
28227
+ } else if (type$j(_colors) === 'function') {
28228
+ col = _colors(t);
28229
+ }
28230
+ if (_useCache) { _colorCache[k] = col; }
28231
+ }
28232
+ return col;
28233
+ };
28234
+
28235
+ var resetCache = function () { return _colorCache = {}; };
28236
+
28237
+ setColors(colors);
28238
+
28239
+ // public interface
28240
+
28241
+ var f = function(v) {
28242
+ var c = chroma_1(getColor(v));
28243
+ if (_out && c[_out]) { return c[_out](); } else { return c; }
28244
+ };
28245
+
28246
+ f.classes = function(classes) {
28247
+ if (classes != null) {
28248
+ if (type$j(classes) === 'array') {
28249
+ _classes = classes;
28250
+ _domain = [classes[0], classes[classes.length-1]];
28251
+ } else {
28252
+ var d = chroma_1.analyze(_domain);
28253
+ if (classes === 0) {
28254
+ _classes = [d.min, d.max];
28255
+ } else {
28256
+ _classes = chroma_1.limits(d, 'e', classes);
28257
+ }
28258
+ }
28259
+ return f;
28260
+ }
28261
+ return _classes;
28262
+ };
28263
+
28264
+
28265
+ f.domain = function(domain) {
28266
+ if (!arguments.length) {
28267
+ return _domain;
28268
+ }
28269
+ _min = domain[0];
28270
+ _max = domain[domain.length-1];
28271
+ _pos = [];
28272
+ var k = _colors.length;
28273
+ if ((domain.length === k) && (_min !== _max)) {
28274
+ // update positions
28275
+ for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {
28276
+ var d = list[i];
28277
+
28278
+ _pos.push((d-_min) / (_max-_min));
28279
+ }
28280
+ } else {
28281
+ for (var c=0; c<k; c++) {
28282
+ _pos.push(c/(k-1));
28283
+ }
28284
+ if (domain.length > 2) {
28285
+ // set domain map
28286
+ var tOut = domain.map(function (d,i) { return i/(domain.length-1); });
28287
+ var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });
28288
+ if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {
28289
+ tMapDomain = function (t) {
28290
+ if (t <= 0 || t >= 1) { return t; }
28291
+ var i = 0;
28292
+ while (t >= tBreaks[i+1]) { i++; }
28293
+ var f = (t - tBreaks[i]) / (tBreaks[i+1] - tBreaks[i]);
28294
+ var out = tOut[i] + f * (tOut[i+1] - tOut[i]);
28295
+ return out;
28296
+ };
28297
+ }
28298
+
28299
+ }
28300
+ }
28301
+ _domain = [_min, _max];
28302
+ return f;
28303
+ };
28304
+
28305
+ f.mode = function(_m) {
28306
+ if (!arguments.length) {
28307
+ return _mode;
28308
+ }
28309
+ _mode = _m;
28310
+ resetCache();
28311
+ return f;
28312
+ };
28313
+
28314
+ f.range = function(colors, _pos) {
28315
+ setColors(colors);
28316
+ return f;
28317
+ };
28318
+
28319
+ f.out = function(_o) {
28320
+ _out = _o;
28321
+ return f;
28322
+ };
28323
+
28324
+ f.spread = function(val) {
28325
+ if (!arguments.length) {
28326
+ return _spread;
28327
+ }
28328
+ _spread = val;
28329
+ return f;
28330
+ };
28331
+
28332
+ f.correctLightness = function(v) {
28333
+ if (v == null) { v = true; }
28334
+ _correctLightness = v;
28335
+ resetCache();
28336
+ if (_correctLightness) {
28337
+ tMapLightness = function(t) {
28338
+ var L0 = getColor(0, true).lab()[0];
28339
+ var L1 = getColor(1, true).lab()[0];
28340
+ var pol = L0 > L1;
28341
+ var L_actual = getColor(t, true).lab()[0];
28342
+ var L_ideal = L0 + ((L1 - L0) * t);
28343
+ var L_diff = L_actual - L_ideal;
28344
+ var t0 = 0;
28345
+ var t1 = 1;
28346
+ var max_iter = 20;
28347
+ while ((Math.abs(L_diff) > 1e-2) && (max_iter-- > 0)) {
28348
+ (function() {
28349
+ if (pol) { L_diff *= -1; }
28350
+ if (L_diff < 0) {
28351
+ t0 = t;
28352
+ t += (t1 - t) * 0.5;
28353
+ } else {
28354
+ t1 = t;
28355
+ t += (t0 - t) * 0.5;
28356
+ }
28357
+ L_actual = getColor(t, true).lab()[0];
28358
+ return L_diff = L_actual - L_ideal;
28359
+ })();
28360
+ }
28361
+ return t;
28362
+ };
28363
+ } else {
28364
+ tMapLightness = function (t) { return t; };
28365
+ }
28366
+ return f;
28367
+ };
28368
+
28369
+ f.padding = function(p) {
28370
+ if (p != null) {
28371
+ if (type$j(p) === 'number') {
28372
+ p = [p,p];
28373
+ }
28374
+ _padding = p;
28375
+ return f;
28376
+ } else {
28377
+ return _padding;
28378
+ }
28379
+ };
28380
+
28381
+ f.colors = function(numColors, out) {
28382
+ // If no arguments are given, return the original colors that were provided
28383
+ if (arguments.length < 2) { out = 'hex'; }
28384
+ var result = [];
28385
+
28386
+ if (arguments.length === 0) {
28387
+ result = _colors.slice(0);
28388
+
28389
+ } else if (numColors === 1) {
28390
+ result = [f(0.5)];
28391
+
28392
+ } else if (numColors > 1) {
28393
+ var dm = _domain[0];
28394
+ var dd = _domain[1] - dm;
28395
+ result = __range__(0, numColors, false).map(function (i) { return f( dm + ((i/(numColors-1)) * dd) ); });
28396
+
28397
+ } else { // returns all colors based on the defined classes
28398
+ colors = [];
28399
+ var samples = [];
28400
+ if (_classes && (_classes.length > 2)) {
28401
+ for (var i = 1, end = _classes.length, asc = 1 <= end; asc ? i < end : i > end; asc ? i++ : i--) {
28402
+ samples.push((_classes[i-1]+_classes[i])*0.5);
28403
+ }
28404
+ } else {
28405
+ samples = _domain;
28406
+ }
28407
+ result = samples.map(function (v) { return f(v); });
28408
+ }
28409
+
28410
+ if (chroma_1[out]) {
28411
+ result = result.map(function (c) { return c[out](); });
28412
+ }
28413
+ return result;
28414
+ };
28415
+
28416
+ f.cache = function(c) {
28417
+ if (c != null) {
28418
+ _useCache = c;
28419
+ return f;
28420
+ } else {
28421
+ return _useCache;
28422
+ }
28423
+ };
28424
+
28425
+ f.gamma = function(g) {
28426
+ if (g != null) {
28427
+ _gamma = g;
28428
+ return f;
28429
+ } else {
28430
+ return _gamma;
28431
+ }
28432
+ };
28433
+
28434
+ f.nodata = function(d) {
28435
+ if (d != null) {
28436
+ _nacol = chroma_1(d);
28437
+ return f;
28438
+ } else {
28439
+ return _nacol;
28440
+ }
28441
+ };
28442
+
28443
+ return f;
28444
+ };
28445
+
28446
+ function __range__(left, right, inclusive) {
28447
+ var range = [];
28448
+ var ascending = left < right;
28449
+ var end = !inclusive ? right : ascending ? right + 1 : right - 1;
28450
+ for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {
28451
+ range.push(i);
28452
+ }
28453
+ return range;
28454
+ }
28455
+
28456
+ //
28457
+ // interpolates between a set of colors uzing a bezier spline
28458
+ //
28459
+
28460
+ // @requires utils lab
28461
+
28462
+
28463
+
28464
+
28465
+ var bezier = function(colors) {
28466
+ var assign, assign$1, assign$2;
28467
+
28468
+ var I, lab0, lab1, lab2;
28469
+ colors = colors.map(function (c) { return new Color_1(c); });
28470
+ if (colors.length === 2) {
28471
+ // linear interpolation
28472
+ (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);
28473
+ I = function(t) {
28474
+ var lab = ([0, 1, 2].map(function (i) { return lab0[i] + (t * (lab1[i] - lab0[i])); }));
28475
+ return new Color_1(lab, 'lab');
28476
+ };
28477
+ } else if (colors.length === 3) {
28478
+ // quadratic bezier interpolation
28479
+ (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);
28480
+ I = function(t) {
28481
+ var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t) * lab0[i]) + (2 * (1-t) * t * lab1[i]) + (t * t * lab2[i]); }));
28482
+ return new Color_1(lab, 'lab');
28483
+ };
28484
+ } else if (colors.length === 4) {
28485
+ // cubic bezier interpolation
28486
+ var lab3;
28487
+ (assign$2 = colors.map(function (c) { return c.lab(); }), lab0 = assign$2[0], lab1 = assign$2[1], lab2 = assign$2[2], lab3 = assign$2[3]);
28488
+ I = function(t) {
28489
+ var lab = ([0, 1, 2].map(function (i) { return ((1-t)*(1-t)*(1-t) * lab0[i]) + (3 * (1-t) * (1-t) * t * lab1[i]) + (3 * (1-t) * t * t * lab2[i]) + (t*t*t * lab3[i]); }));
28490
+ return new Color_1(lab, 'lab');
28491
+ };
28492
+ } else if (colors.length === 5) {
28493
+ var I0 = bezier(colors.slice(0, 3));
28494
+ var I1 = bezier(colors.slice(2, 5));
28495
+ I = function(t) {
28496
+ if (t < 0.5) {
28497
+ return I0(t*2);
28498
+ } else {
28499
+ return I1((t-0.5)*2);
28500
+ }
28501
+ };
28502
+ }
28503
+ return I;
28504
+ };
28505
+
28506
+ var bezier_1 = function (colors) {
28507
+ var f = bezier(colors);
28508
+ f.scale = function () { return scale(f); };
28509
+ return f;
28510
+ };
28511
+
28512
+ /*
28513
+ * interpolates between a set of colors uzing a bezier spline
28514
+ * blend mode formulas taken from http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/
28515
+ */
28516
+
28517
+
28518
+
28519
+
28520
+ var blend = function (bottom, top, mode) {
28521
+ if (!blend[mode]) {
28522
+ throw new Error('unknown blend mode ' + mode);
28523
+ }
28524
+ return blend[mode](bottom, top);
28525
+ };
28526
+
28527
+ var blend_f = function (f) { return function (bottom,top) {
28528
+ var c0 = chroma_1(top).rgb();
28529
+ var c1 = chroma_1(bottom).rgb();
28530
+ return chroma_1.rgb(f(c0, c1));
28531
+ }; };
28532
+
28533
+ var each = function (f) { return function (c0, c1) {
28534
+ var out = [];
28535
+ out[0] = f(c0[0], c1[0]);
28536
+ out[1] = f(c0[1], c1[1]);
28537
+ out[2] = f(c0[2], c1[2]);
28538
+ return out;
28539
+ }; };
28540
+
28541
+ var normal = function (a) { return a; };
28542
+ var multiply = function (a,b) { return a * b / 255; };
28543
+ var darken$1 = function (a,b) { return a > b ? b : a; };
28544
+ var lighten = function (a,b) { return a > b ? a : b; };
28545
+ var screen = function (a,b) { return 255 * (1 - (1-a/255) * (1-b/255)); };
28546
+ var overlay = function (a,b) { return b < 128 ? 2 * a * b / 255 : 255 * (1 - 2 * (1 - a / 255 ) * ( 1 - b / 255 )); };
28547
+ var burn = function (a,b) { return 255 * (1 - (1 - b / 255) / (a/255)); };
28548
+ var dodge = function (a,b) {
28549
+ if (a === 255) { return 255; }
28550
+ a = 255 * (b / 255) / (1 - a / 255);
28551
+ return a > 255 ? 255 : a
28552
+ };
28553
+
28554
+ // # add = (a,b) ->
28555
+ // # if (a + b > 255) then 255 else a + b
28556
+
28557
+ blend.normal = blend_f(each(normal));
28558
+ blend.multiply = blend_f(each(multiply));
28559
+ blend.screen = blend_f(each(screen));
28560
+ blend.overlay = blend_f(each(overlay));
28561
+ blend.darken = blend_f(each(darken$1));
28562
+ blend.lighten = blend_f(each(lighten));
28563
+ blend.dodge = blend_f(each(dodge));
28564
+ blend.burn = blend_f(each(burn));
28565
+ // blend.add = blend_f(each(add));
28566
+
28567
+ var blend_1 = blend;
28568
+
28569
+ // cubehelix interpolation
28570
+ // based on D.A. Green "A colour scheme for the display of astronomical intensity images"
28571
+ // http://astron-soc.in/bulletin/11June/289392011.pdf
28572
+
28573
+ var type$k = utils.type;
28574
+ var clip_rgb$3 = utils.clip_rgb;
28575
+ var TWOPI$2 = utils.TWOPI;
28576
+ var pow$6 = Math.pow;
28577
+ var sin$2 = Math.sin;
28578
+ var cos$3 = Math.cos;
28579
+
28580
+
28581
+ var cubehelix = function(start, rotations, hue, gamma, lightness) {
28582
+ if ( start === void 0 ) start=300;
28583
+ if ( rotations === void 0 ) rotations=-1.5;
28584
+ if ( hue === void 0 ) hue=1;
28585
+ if ( gamma === void 0 ) gamma=1;
28586
+ if ( lightness === void 0 ) lightness=[0,1];
28587
+
28588
+ var dh = 0, dl;
28589
+ if (type$k(lightness) === 'array') {
28590
+ dl = lightness[1] - lightness[0];
28591
+ } else {
28592
+ dl = 0;
28593
+ lightness = [lightness, lightness];
28594
+ }
28595
+
28596
+ var f = function(fract) {
28597
+ var a = TWOPI$2 * (((start+120)/360) + (rotations * fract));
28598
+ var l = pow$6(lightness[0] + (dl * fract), gamma);
28599
+ var h = dh !== 0 ? hue[0] + (fract * dh) : hue;
28600
+ var amp = (h * l * (1-l)) / 2;
28601
+ var cos_a = cos$3(a);
28602
+ var sin_a = sin$2(a);
28603
+ var r = l + (amp * ((-0.14861 * cos_a) + (1.78277* sin_a)));
28604
+ var g = l + (amp * ((-0.29227 * cos_a) - (0.90649* sin_a)));
28605
+ var b = l + (amp * (+1.97294 * cos_a));
28606
+ return chroma_1(clip_rgb$3([r*255,g*255,b*255,1]));
28607
+ };
28608
+
28609
+ f.start = function(s) {
28610
+ if ((s == null)) { return start; }
28611
+ start = s;
28612
+ return f;
28613
+ };
28614
+
28615
+ f.rotations = function(r) {
28616
+ if ((r == null)) { return rotations; }
28617
+ rotations = r;
28618
+ return f;
28619
+ };
28620
+
28621
+ f.gamma = function(g) {
28622
+ if ((g == null)) { return gamma; }
28623
+ gamma = g;
28624
+ return f;
28625
+ };
28626
+
28627
+ f.hue = function(h) {
28628
+ if ((h == null)) { return hue; }
28629
+ hue = h;
28630
+ if (type$k(hue) === 'array') {
28631
+ dh = hue[1] - hue[0];
28632
+ if (dh === 0) { hue = hue[1]; }
28633
+ } else {
28634
+ dh = 0;
28635
+ }
28636
+ return f;
28637
+ };
28638
+
28639
+ f.lightness = function(h) {
28640
+ if ((h == null)) { return lightness; }
28641
+ if (type$k(h) === 'array') {
28642
+ lightness = h;
28643
+ dl = h[1] - h[0];
28644
+ } else {
28645
+ lightness = [h,h];
28646
+ dl = 0;
28647
+ }
28648
+ return f;
28649
+ };
28650
+
28651
+ f.scale = function () { return chroma_1.scale(f); };
28652
+
28653
+ f.hue(hue);
28654
+
28655
+ return f;
28656
+ };
28657
+
28658
+ var digits = '0123456789abcdef';
28659
+
28660
+ var floor$2 = Math.floor;
28661
+ var random = Math.random;
28662
+
28663
+ var random_1 = function () {
28664
+ var code = '#';
28665
+ for (var i=0; i<6; i++) {
28666
+ code += digits.charAt(floor$2(random() * 16));
28667
+ }
28668
+ return new Color_1(code, 'hex');
28669
+ };
28670
+
28671
+ var log$1 = Math.log;
28672
+ var pow$7 = Math.pow;
28673
+ var floor$3 = Math.floor;
28674
+ var abs = Math.abs;
28675
+
28676
+
28677
+ var analyze = function (data, key) {
28678
+ if ( key === void 0 ) key=null;
28679
+
28680
+ var r = {
28681
+ min: Number.MAX_VALUE,
28682
+ max: Number.MAX_VALUE*-1,
28683
+ sum: 0,
28684
+ values: [],
28685
+ count: 0
28686
+ };
28687
+ if (type(data) === 'object') {
28688
+ data = Object.values(data);
28689
+ }
28690
+ data.forEach(function (val) {
28691
+ if (key && type(val) === 'object') { val = val[key]; }
28692
+ if (val !== undefined && val !== null && !isNaN(val)) {
28693
+ r.values.push(val);
28694
+ r.sum += val;
28695
+ if (val < r.min) { r.min = val; }
28696
+ if (val > r.max) { r.max = val; }
28697
+ r.count += 1;
28698
+ }
28699
+ });
28700
+
28701
+ r.domain = [r.min, r.max];
28702
+
28703
+ r.limits = function (mode, num) { return limits(r, mode, num); };
28704
+
28705
+ return r;
28706
+ };
28707
+
28708
+
28709
+ var limits = function (data, mode, num) {
28710
+ if ( mode === void 0 ) mode='equal';
28711
+ if ( num === void 0 ) num=7;
28712
+
28713
+ if (type(data) == 'array') {
28714
+ data = analyze(data);
28715
+ }
28716
+ var min = data.min;
28717
+ var max = data.max;
28718
+ var values = data.values.sort(function (a,b) { return a-b; });
28719
+
28720
+ if (num === 1) { return [min,max]; }
28721
+
28722
+ var limits = [];
28723
+
28724
+ if (mode.substr(0,1) === 'c') { // continuous
28725
+ limits.push(min);
28726
+ limits.push(max);
28727
+ }
28728
+
28729
+ if (mode.substr(0,1) === 'e') { // equal interval
28730
+ limits.push(min);
28731
+ for (var i=1; i<num; i++) {
28732
+ limits.push(min+((i/num)*(max-min)));
28733
+ }
28734
+ limits.push(max);
28735
+ }
28736
+
28737
+ else if (mode.substr(0,1) === 'l') { // log scale
28738
+ if (min <= 0) {
28739
+ throw new Error('Logarithmic scales are only possible for values > 0');
28740
+ }
28741
+ var min_log = Math.LOG10E * log$1(min);
28742
+ var max_log = Math.LOG10E * log$1(max);
28743
+ limits.push(min);
28744
+ for (var i$1=1; i$1<num; i$1++) {
28745
+ limits.push(pow$7(10, min_log + ((i$1/num) * (max_log - min_log))));
28746
+ }
28747
+ limits.push(max);
28748
+ }
28749
+
28750
+ else if (mode.substr(0,1) === 'q') { // quantile scale
28751
+ limits.push(min);
28752
+ for (var i$2=1; i$2<num; i$2++) {
28753
+ var p = ((values.length-1) * i$2)/num;
28754
+ var pb = floor$3(p);
28755
+ if (pb === p) {
28756
+ limits.push(values[pb]);
28757
+ } else { // p > pb
28758
+ var pr = p - pb;
28759
+ limits.push((values[pb]*(1-pr)) + (values[pb+1]*pr));
28760
+ }
28761
+ }
28762
+ limits.push(max);
28763
+
28764
+ }
28765
+
28766
+ else if (mode.substr(0,1) === 'k') { // k-means clustering
28767
+ /*
28768
+ implementation based on
28769
+ http://code.google.com/p/figue/source/browse/trunk/figue.js#336
28770
+ simplified for 1-d input values
28771
+ */
28772
+ var cluster;
28773
+ var n = values.length;
28774
+ var assignments = new Array(n);
28775
+ var clusterSizes = new Array(num);
28776
+ var repeat = true;
28777
+ var nb_iters = 0;
28778
+ var centroids = null;
28779
+
28780
+ // get seed values
28781
+ centroids = [];
28782
+ centroids.push(min);
28783
+ for (var i$3=1; i$3<num; i$3++) {
28784
+ centroids.push(min + ((i$3/num) * (max-min)));
28785
+ }
28786
+ centroids.push(max);
28787
+
28788
+ while (repeat) {
28789
+ // assignment step
28790
+ for (var j=0; j<num; j++) {
28791
+ clusterSizes[j] = 0;
28792
+ }
28793
+ for (var i$4=0; i$4<n; i$4++) {
28794
+ var value = values[i$4];
28795
+ var mindist = Number.MAX_VALUE;
28796
+ var best = (void 0);
28797
+ for (var j$1=0; j$1<num; j$1++) {
28798
+ var dist = abs(centroids[j$1]-value);
28799
+ if (dist < mindist) {
28800
+ mindist = dist;
28801
+ best = j$1;
28802
+ }
28803
+ clusterSizes[best]++;
28804
+ assignments[i$4] = best;
28805
+ }
28806
+ }
28807
+
28808
+ // update centroids step
28809
+ var newCentroids = new Array(num);
28810
+ for (var j$2=0; j$2<num; j$2++) {
28811
+ newCentroids[j$2] = null;
28812
+ }
28813
+ for (var i$5=0; i$5<n; i$5++) {
28814
+ cluster = assignments[i$5];
28815
+ if (newCentroids[cluster] === null) {
28816
+ newCentroids[cluster] = values[i$5];
28817
+ } else {
28818
+ newCentroids[cluster] += values[i$5];
28819
+ }
28820
+ }
28821
+ for (var j$3=0; j$3<num; j$3++) {
28822
+ newCentroids[j$3] *= 1/clusterSizes[j$3];
28823
+ }
28824
+
28825
+ // check convergence
28826
+ repeat = false;
28827
+ for (var j$4=0; j$4<num; j$4++) {
28828
+ if (newCentroids[j$4] !== centroids[j$4]) {
28829
+ repeat = true;
28830
+ break;
28831
+ }
28832
+ }
28833
+
28834
+ centroids = newCentroids;
28835
+ nb_iters++;
28836
+
28837
+ if (nb_iters > 200) {
28838
+ repeat = false;
28839
+ }
28840
+ }
28841
+
28842
+ // finished k-means clustering
28843
+ // the next part is borrowed from gabrielflor.it
28844
+ var kClusters = {};
28845
+ for (var j$5=0; j$5<num; j$5++) {
28846
+ kClusters[j$5] = [];
28847
+ }
28848
+ for (var i$6=0; i$6<n; i$6++) {
28849
+ cluster = assignments[i$6];
28850
+ kClusters[cluster].push(values[i$6]);
28851
+ }
28852
+ var tmpKMeansBreaks = [];
28853
+ for (var j$6=0; j$6<num; j$6++) {
28854
+ tmpKMeansBreaks.push(kClusters[j$6][0]);
28855
+ tmpKMeansBreaks.push(kClusters[j$6][kClusters[j$6].length-1]);
28856
+ }
28857
+ tmpKMeansBreaks = tmpKMeansBreaks.sort(function (a,b){ return a-b; });
28858
+ limits.push(tmpKMeansBreaks[0]);
28859
+ for (var i$7=1; i$7 < tmpKMeansBreaks.length; i$7+= 2) {
28860
+ var v = tmpKMeansBreaks[i$7];
28861
+ if (!isNaN(v) && (limits.indexOf(v) === -1)) {
28862
+ limits.push(v);
28863
+ }
28864
+ }
28865
+ }
28866
+ return limits;
28867
+ };
28868
+
28869
+ var analyze_1 = {analyze: analyze, limits: limits};
28870
+
28871
+ var contrast = function (a, b) {
28872
+ // WCAG contrast ratio
28873
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef
28874
+ a = new Color_1(a);
28875
+ b = new Color_1(b);
28876
+ var l1 = a.luminance();
28877
+ var l2 = b.luminance();
28878
+ return l1 > l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);
28879
+ };
28880
+
28881
+ var sqrt$4 = Math.sqrt;
28882
+ var atan2$2 = Math.atan2;
28883
+ var abs$1 = Math.abs;
28884
+ var cos$4 = Math.cos;
28885
+ var PI$2 = Math.PI;
28886
+
28887
+ var deltaE = function(a, b, L, C) {
28888
+ if ( L === void 0 ) L=1;
28889
+ if ( C === void 0 ) C=1;
28890
+
28891
+ // Delta E (CMC)
28892
+ // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CMC.html
28893
+ a = new Color_1(a);
28894
+ b = new Color_1(b);
28895
+ var ref = Array.from(a.lab());
28896
+ var L1 = ref[0];
28897
+ var a1 = ref[1];
28898
+ var b1 = ref[2];
28899
+ var ref$1 = Array.from(b.lab());
28900
+ var L2 = ref$1[0];
28901
+ var a2 = ref$1[1];
28902
+ var b2 = ref$1[2];
28903
+ var c1 = sqrt$4((a1 * a1) + (b1 * b1));
28904
+ var c2 = sqrt$4((a2 * a2) + (b2 * b2));
28905
+ var sl = L1 < 16.0 ? 0.511 : (0.040975 * L1) / (1.0 + (0.01765 * L1));
28906
+ var sc = ((0.0638 * c1) / (1.0 + (0.0131 * c1))) + 0.638;
28907
+ var h1 = c1 < 0.000001 ? 0.0 : (atan2$2(b1, a1) * 180.0) / PI$2;
28908
+ while (h1 < 0) { h1 += 360; }
28909
+ while (h1 >= 360) { h1 -= 360; }
28910
+ var t = (h1 >= 164.0) && (h1 <= 345.0) ? (0.56 + abs$1(0.2 * cos$4((PI$2 * (h1 + 168.0)) / 180.0))) : (0.36 + abs$1(0.4 * cos$4((PI$2 * (h1 + 35.0)) / 180.0)));
28911
+ var c4 = c1 * c1 * c1 * c1;
28912
+ var f = sqrt$4(c4 / (c4 + 1900.0));
28913
+ var sh = sc * (((f * t) + 1.0) - f);
28914
+ var delL = L1 - L2;
28915
+ var delC = c1 - c2;
28916
+ var delA = a1 - a2;
28917
+ var delB = b1 - b2;
28918
+ var dH2 = ((delA * delA) + (delB * delB)) - (delC * delC);
28919
+ var v1 = delL / (L * sl);
28920
+ var v2 = delC / (C * sc);
28921
+ var v3 = sh;
28922
+ return sqrt$4((v1 * v1) + (v2 * v2) + (dH2 / (v3 * v3)));
28923
+ };
28924
+
28925
+ // simple Euclidean distance
28926
+ var distance = function(a, b, mode) {
28927
+ if ( mode === void 0 ) mode='lab';
28928
+
28929
+ // Delta E (CIE 1976)
28930
+ // see http://www.brucelindbloom.com/index.html?Equations.html
28931
+ a = new Color_1(a);
28932
+ b = new Color_1(b);
28933
+ var l1 = a.get(mode);
28934
+ var l2 = b.get(mode);
28935
+ var sum_sq = 0;
28936
+ for (var i in l1) {
28937
+ var d = (l1[i] || 0) - (l2[i] || 0);
28938
+ sum_sq += d*d;
28939
+ }
28940
+ return Math.sqrt(sum_sq);
28941
+ };
28942
+
28943
+ var valid = function () {
28944
+ var args = [], len = arguments.length;
28945
+ while ( len-- ) args[ len ] = arguments[ len ];
28946
+
28947
+ try {
28948
+ new (Function.prototype.bind.apply( Color_1, [ null ].concat( args) ));
28949
+ return true;
28950
+ } catch (e) {
28951
+ return false;
28952
+ }
28953
+ };
28954
+
28955
+ // some pre-defined color scales:
28956
+
28957
+
28958
+
28959
+
28960
+ var scales = {
28961
+ cool: function cool() { return scale([chroma_1.hsl(180,1,.9), chroma_1.hsl(250,.7,.4)]) },
28962
+ hot: function hot() { return scale(['#000','#f00','#ff0','#fff']).mode('rgb') }
28963
+ };
28964
+
28965
+ /**
28966
+ ColorBrewer colors for chroma.js
28967
+
28968
+ Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The
28969
+ Pennsylvania State University.
28970
+
28971
+ Licensed under the Apache License, Version 2.0 (the "License");
28972
+ you may not use this file except in compliance with the License.
28973
+ You may obtain a copy of the License at
28974
+ http://www.apache.org/licenses/LICENSE-2.0
28975
+
28976
+ Unless required by applicable law or agreed to in writing, software distributed
28977
+ under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
28978
+ CONDITIONS OF ANY KIND, either express or implied. See the License for the
28979
+ specific language governing permissions and limitations under the License.
28980
+ */
28981
+
28982
+ var colorbrewer = {
28983
+ // sequential
28984
+ OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],
28985
+ PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],
28986
+ BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],
28987
+ Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],
28988
+ BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],
28989
+ YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],
28990
+ YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],
28991
+ Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],
28992
+ RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],
28993
+ Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],
28994
+ YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],
28995
+ Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],
28996
+ GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],
28997
+ Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],
28998
+ YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],
28999
+ PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],
29000
+ Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],
29001
+ PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],
29002
+ Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],
29003
+
29004
+ // diverging
29005
+
29006
+ Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],
29007
+ RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],
29008
+ RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],
29009
+ PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],
29010
+ PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],
29011
+ RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],
29012
+ BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],
29013
+ RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],
29014
+ PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],
29015
+
29016
+ // qualitative
29017
+
29018
+ Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],
29019
+ Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],
29020
+ Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],
29021
+ Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],
29022
+ Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],
29023
+ Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],
29024
+ Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],
29025
+ Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'],
29026
+ };
29027
+
29028
+ // add lowercase aliases for case-insensitive matches
29029
+ for (var i$1 = 0, list$1 = Object.keys(colorbrewer); i$1 < list$1.length; i$1 += 1) {
29030
+ var key = list$1[i$1];
29031
+
29032
+ colorbrewer[key.toLowerCase()] = colorbrewer[key];
29033
+ }
29034
+
29035
+ var colorbrewer_1 = colorbrewer;
29036
+
29037
+ // feel free to comment out anything to rollup
29038
+ // a smaller chroma.js built
29039
+
29040
+ // io --> convert colors
29041
+
29042
+
29043
+
29044
+
29045
+
29046
+
29047
+
29048
+
29049
+
29050
+
29051
+
29052
+
29053
+
29054
+
29055
+
29056
+ // operators --> modify existing Colors
29057
+
29058
+
29059
+
29060
+
29061
+
29062
+
29063
+
29064
+
29065
+
29066
+
29067
+ // interpolators
29068
+
29069
+
29070
+
29071
+
29072
+
29073
+
29074
+
29075
+
29076
+
29077
+
29078
+ // generators -- > create new colors
29079
+ chroma_1.average = average;
29080
+ chroma_1.bezier = bezier_1;
29081
+ chroma_1.blend = blend_1;
29082
+ chroma_1.cubehelix = cubehelix;
29083
+ chroma_1.mix = chroma_1.interpolate = mix;
29084
+ chroma_1.random = random_1;
29085
+ chroma_1.scale = scale;
29086
+
29087
+ // other utility methods
29088
+ chroma_1.analyze = analyze_1.analyze;
29089
+ chroma_1.contrast = contrast;
29090
+ chroma_1.deltaE = deltaE;
29091
+ chroma_1.distance = distance;
29092
+ chroma_1.limits = analyze_1.limits;
29093
+ chroma_1.valid = valid;
29094
+
29095
+ // scale
29096
+ chroma_1.scales = scales;
29097
+
29098
+ // colors
29099
+ chroma_1.colors = w3cx11_1;
29100
+ chroma_1.brewer = colorbrewer_1;
29101
+
29102
+ var chroma_js = chroma_1;
29103
+
29104
+ return chroma_js;
29105
+
29106
+ })));
29107
+ });
29108
+
29109
+ function autoColorScaleCss(color, name = "primary") {
29110
+ if (!chroma.valid(color)) {
29111
+ return;
29112
+ }
29113
+ const colorScale = [50, 100, 200, 300, 400, 500, 600, 700, 800, 900, 950];
29114
+ const hex = chroma(color).hex();
29115
+ const scale = chroma
29116
+ .scale([
29117
+ chroma(hex).luminance(0.95),
29118
+ chroma(hex).luminance(0.84),
29119
+ chroma(hex).luminance(0.73),
29120
+ chroma(hex).luminance(0.62),
29121
+ chroma(hex).luminance(0.49),
29122
+ chroma(hex).luminance(0.35),
29123
+ chroma(hex).luminance(0.23),
29124
+ chroma(hex).luminance(0.15),
29125
+ chroma(hex).luminance(0.1),
29126
+ chroma(hex).luminance(0.05),
29127
+ chroma(hex).luminance(0.02),
29128
+ ])
29129
+ .colors(colorScale.length);
29130
+ return scale
29131
+ .map((color, index) => `--sl-color-${name}-${colorScale[index]}: ${chroma(color).hex()};`)
29132
+ .join("\n");
29133
+ }
29134
+
29135
+ /**
29136
+ *
29137
+ * Themes
29138
+ *
29139
+ * Export only valid CSS. Those will be injected into style tags.
29140
+ *
29141
+ * Useful links:
29142
+ * - https://brandcolors.net/
29143
+ * - Shoelace color generator: https://codepen.io/claviska/full/QWveRgL
29144
+ *
29145
+ */
29146
+ //
29147
+ const Default$b = `
29148
+ // No CSS
29149
+ `;
29150
+ const Orangey = `
29151
+ :root{
29152
+ ${autoColorScaleCss("orange")}
29153
+ }
29154
+ `;
29155
+ const Netflix = `
29156
+ :root{
29157
+ ${autoColorScaleCss("#e50914")}
29158
+ }
29159
+ `;
29160
+ const SaaSquatchCorporate = `
29161
+ :root{
29162
+ ${autoColorScaleCss("green")}
29163
+ --sl-font-sans: Arial;
29164
+ }
29165
+ `;
29166
+ const NYTimes = `
29167
+ :root{
29168
+ ${autoColorScaleCss("black")}
29169
+ --sl-font-sans: Georgia, 'Times New Roman', serif;
29170
+ }
29171
+ `;
29172
+
29173
+ const Themes = /*#__PURE__*/Object.freeze({
29174
+ __proto__: null,
29175
+ Default: Default$b,
29176
+ Orangey: Orangey,
29177
+ Netflix: Netflix,
29178
+ SaaSquatchCorporate: SaaSquatchCorporate,
29179
+ NYTimes: NYTimes
25762
29180
  });
25763
29181
 
25764
29182
  function deepFreeze(obj) {
@@ -27231,7 +30649,7 @@ const seenDeprecations = {};
27231
30649
  /**
27232
30650
  * @param {string} message
27233
30651
  */
27234
- const error$1 = (message) => {
30652
+ const error$2 = (message) => {
27235
30653
  console.error(message);
27236
30654
  };
27237
30655
 
@@ -27731,7 +31149,7 @@ const HLJS = function(hljs) {
27731
31149
 
27732
31150
  const language = getLanguage(languageName);
27733
31151
  if (!language) {
27734
- error$1(LANGUAGE_NOT_FOUND.replace("{}", languageName));
31152
+ error$2(LANGUAGE_NOT_FOUND.replace("{}", languageName));
27735
31153
  throw new Error('Unknown language: "' + languageName + '"');
27736
31154
  }
27737
31155
 
@@ -28067,10 +31485,10 @@ const HLJS = function(hljs) {
28067
31485
  let lang = null;
28068
31486
  try {
28069
31487
  lang = languageDefinition(hljs);
28070
- } catch (error$1$1) {
28071
- error$1("Language definition for '{}' could not be registered.".replace("{}", languageName));
31488
+ } catch (error$1) {
31489
+ error$2("Language definition for '{}' could not be registered.".replace("{}", languageName));
28072
31490
  // hard or soft error
28073
- if (!SAFE_MODE) { throw error$1$1; } else { error$1(error$1$1); }
31491
+ if (!SAFE_MODE) { throw error$1; } else { error$2(error$1); }
28074
31492
  // languages that have serious errors are replaced with essentially a
28075
31493
  // "plaintext" stand-in so that the code blocks will still get normal
28076
31494
  // css classes applied to them - and one bad language won't break the
@@ -28406,7 +31824,10 @@ const StencilStorybook = class {
28406
31824
  title: "Mint Components",
28407
31825
  addons: [CucumberAddon, ShadowViewAddon, HookStoryAddon],
28408
31826
  });
28409
- return (h(Host, { class: Style, onClick: {} }, children));
31827
+ const [selectedTheme, setSelected] = useState("Default");
31828
+ const themes = Object.keys(Themes);
31829
+ const theme = Themes[selectedTheme];
31830
+ return (h(Host, { class: Style, onClick: {} }, h("div", { style: { position: "absolute", top: "0", right: "0", zIndex: "999999" } }, "Branding:", h("select", { onChange: (e) => setSelected(e.target.value) }, themes.map(t => h("option", { selected: t === selectedTheme }, t)))), h("style", null, theme), children));
28410
31831
  }
28411
31832
  };
28412
31833