@saasquatch/mint-components 1.3.3-6 → 1.5.0-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (224) 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 +3 -3
  5. package/dist/cjs/mint-components.cjs.js +3 -3
  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 +3995 -358
  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 +13 -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-task-card → sqm-stencilbook}/Matrix.js +0 -0
  44. package/dist/collection/components/sqm-stencilbook/Resizer.js +26 -0
  45. package/dist/collection/components/sqm-stencilbook/Themes.js +38 -0
  46. package/dist/collection/components/sqm-stencilbook/sqm-stencilbook.js +42 -3
  47. package/dist/collection/components/sqm-task-card/SVGs.js +7 -2
  48. package/dist/collection/components/sqm-task-card/TaskCard.stories.js +142 -4
  49. package/dist/collection/components/sqm-task-card/progress-bar/SVGs.js +5 -4
  50. package/dist/collection/components/sqm-task-card/progress-bar/progress-bar-view.js +25 -6
  51. package/dist/collection/components/sqm-task-card/sqm-task-card-view.js +74 -47
  52. package/dist/collection/components/sqm-task-card/sqm-task-card.js +26 -1
  53. package/dist/esm/{ShadowViewAddon-2338f393.js → ShadowViewAddon-a3f510db.js} +1 -1
  54. package/dist/esm/{global-0e81c5e6.js → global-90da933f.js} +1 -1
  55. package/dist/esm/{index.module-9b5bb6a2.js → index.module-90d2c3ad.js} +1 -1
  56. package/dist/esm/loader.js +3 -3
  57. package/dist/esm/mint-components.js +3 -3
  58. package/dist/esm/{re-render-57ac6584.js → re-render-e06f2f7f.js} +1 -1
  59. package/dist/esm/sqm-asset-card.entry.js +1 -1
  60. package/dist/esm/sqm-big-stat.entry.js +2 -2
  61. package/dist/esm/sqm-divided-layout_30.entry.js +3995 -358
  62. package/dist/esm/sqm-graphql-client-provider.entry.js +1 -1
  63. package/dist/esm/{sqm-leaderboard-rank-view-3f0dc20e.js → sqm-leaderboard-rank-view-47844836.js} +2 -2
  64. package/dist/esm/sqm-leaderboard-rank.entry.js +3 -3
  65. package/dist/esm/sqm-leaderboard.entry.js +2 -2
  66. package/dist/esm/sqm-name-fields.entry.js +1 -1
  67. package/dist/esm/{sqm-navigation-sidebar-item-view-79b0748c.js → sqm-navigation-sidebar-item-view-f2304ad9.js} +1 -1
  68. package/dist/esm/sqm-navigation-sidebar-item.entry.js +2 -2
  69. package/dist/esm/sqm-popup-container.entry.js +1 -1
  70. package/dist/esm/{sqm-portal-email-verification-view-8f253fb7.js → sqm-portal-email-verification-view-8cefe480.js} +1 -1
  71. package/dist/esm/sqm-portal-email-verification.entry.js +3 -3
  72. package/dist/esm/{sqm-portal-footer-view-b8a2f15e.js → sqm-portal-footer-view-d9fe0bf8.js} +1 -1
  73. package/dist/esm/sqm-portal-footer.entry.js +3 -3
  74. package/dist/esm/sqm-portal-forgot-password.entry.js +1 -1
  75. package/dist/esm/sqm-portal-logout.entry.js +1 -1
  76. package/dist/esm/{sqm-portal-profile-view-831dea85.js → sqm-portal-profile-view-b67467b4.js} +1 -1
  77. package/dist/esm/sqm-portal-profile.entry.js +3 -3
  78. package/dist/esm/sqm-portal-protected-route.entry.js +1 -1
  79. package/dist/esm/sqm-portal-reset-password.entry.js +1 -1
  80. package/dist/esm/sqm-portal-verify-email.entry.js +1 -1
  81. package/dist/esm/sqm-referral-table-column.entry.js +2 -2
  82. package/dist/esm/sqm-referral-table-date-column.entry.js +2 -2
  83. package/dist/esm/sqm-referral-table-rewards-column.entry.js +2 -2
  84. package/dist/esm/sqm-referral-table-status-column.entry.js +2 -2
  85. package/dist/esm/sqm-referral-table-user-column.entry.js +2 -2
  86. package/dist/esm/sqm-share-code.entry.js +1 -1
  87. package/dist/esm/{useDemoBigStat-660c8672.js → useDemoBigStat-c3b955b7.js} +1 -1
  88. package/dist/esm-es5/{ShadowViewAddon-2338f393.js → ShadowViewAddon-a3f510db.js} +1 -1
  89. package/dist/esm-es5/{global-0e81c5e6.js → global-90da933f.js} +1 -1
  90. package/dist/esm-es5/{index.module-9b5bb6a2.js → index.module-90d2c3ad.js} +1 -1
  91. package/dist/esm-es5/loader.js +1 -1
  92. package/dist/esm-es5/mint-components.js +1 -1
  93. package/dist/esm-es5/{re-render-57ac6584.js → re-render-e06f2f7f.js} +1 -1
  94. package/dist/esm-es5/sqm-asset-card.entry.js +1 -1
  95. package/dist/esm-es5/sqm-big-stat.entry.js +1 -1
  96. package/dist/esm-es5/sqm-divided-layout_30.entry.js +58 -1
  97. package/dist/esm-es5/sqm-graphql-client-provider.entry.js +1 -1
  98. package/dist/esm-es5/{sqm-leaderboard-rank-view-3f0dc20e.js → sqm-leaderboard-rank-view-47844836.js} +1 -1
  99. package/dist/esm-es5/sqm-leaderboard-rank.entry.js +1 -1
  100. package/dist/esm-es5/sqm-leaderboard.entry.js +1 -1
  101. package/dist/esm-es5/sqm-name-fields.entry.js +1 -1
  102. package/dist/esm-es5/{sqm-navigation-sidebar-item-view-79b0748c.js → sqm-navigation-sidebar-item-view-f2304ad9.js} +1 -1
  103. package/dist/esm-es5/sqm-navigation-sidebar-item.entry.js +1 -1
  104. package/dist/esm-es5/sqm-popup-container.entry.js +1 -1
  105. package/dist/esm-es5/{sqm-portal-email-verification-view-8f253fb7.js → sqm-portal-email-verification-view-8cefe480.js} +1 -1
  106. package/dist/esm-es5/sqm-portal-email-verification.entry.js +1 -1
  107. package/dist/esm-es5/{sqm-portal-footer-view-b8a2f15e.js → sqm-portal-footer-view-d9fe0bf8.js} +1 -1
  108. package/dist/esm-es5/sqm-portal-footer.entry.js +1 -1
  109. package/dist/esm-es5/sqm-portal-forgot-password.entry.js +1 -1
  110. package/dist/esm-es5/sqm-portal-logout.entry.js +1 -1
  111. package/dist/esm-es5/{sqm-portal-profile-view-831dea85.js → sqm-portal-profile-view-b67467b4.js} +1 -1
  112. package/dist/esm-es5/sqm-portal-profile.entry.js +1 -1
  113. package/dist/esm-es5/sqm-portal-protected-route.entry.js +1 -1
  114. package/dist/esm-es5/sqm-portal-reset-password.entry.js +1 -1
  115. package/dist/esm-es5/sqm-portal-verify-email.entry.js +1 -1
  116. package/dist/esm-es5/sqm-referral-table-column.entry.js +1 -1
  117. package/dist/esm-es5/sqm-referral-table-date-column.entry.js +1 -1
  118. package/dist/esm-es5/sqm-referral-table-rewards-column.entry.js +1 -1
  119. package/dist/esm-es5/sqm-referral-table-status-column.entry.js +1 -1
  120. package/dist/esm-es5/sqm-referral-table-user-column.entry.js +1 -1
  121. package/dist/esm-es5/sqm-share-code.entry.js +1 -1
  122. package/dist/esm-es5/{useDemoBigStat-660c8672.js → useDemoBigStat-c3b955b7.js} +1 -1
  123. package/dist/mint-components/assets/placeholder.png +0 -0
  124. package/dist/mint-components/mint-components.esm.js +1 -1
  125. package/dist/mint-components/mint-components.js +1 -1
  126. package/dist/mint-components/{p-be615f03.system.js → p-07c924fa.system.js} +1 -1
  127. package/dist/mint-components/{p-295b306a.js → p-0eb3e89c.js} +1 -1
  128. package/dist/mint-components/p-160bd62f.entry.js +1 -0
  129. package/dist/mint-components/{p-58bf2a30.system.js → p-16f5a7cb.system.js} +1 -1
  130. package/dist/mint-components/{p-55f029cd.system.entry.js → p-1a09e4e1.system.entry.js} +1 -1
  131. package/dist/mint-components/p-1c8b0290.entry.js +1 -0
  132. package/dist/mint-components/{p-b893904c.system.entry.js → p-1dcdca58.system.entry.js} +1 -1
  133. package/dist/mint-components/p-20d41ab1.entry.js +1 -0
  134. package/dist/mint-components/{p-a93149f4.entry.js → p-221a4097.entry.js} +1 -1
  135. package/dist/mint-components/{p-0a882bab.system.entry.js → p-223b42bd.system.entry.js} +1 -1
  136. package/dist/mint-components/{p-27bb0aa9.js → p-224504ad.js} +1 -1
  137. package/dist/mint-components/{p-7062ab8e.system.entry.js → p-24b3c6f0.system.entry.js} +1 -1
  138. package/dist/mint-components/{p-3404b8d2.system.entry.js → p-24c9a599.system.entry.js} +1 -1
  139. package/dist/mint-components/{p-aee2a2b9.entry.js → p-29fab29b.entry.js} +1 -1
  140. package/dist/mint-components/{p-ad1c6eb8.system.entry.js → p-304e6c82.system.entry.js} +1 -1
  141. package/dist/mint-components/{p-8f5b80f2.entry.js → p-3397167c.entry.js} +1 -1
  142. package/dist/mint-components/{p-62102076.entry.js → p-33c5ffb7.entry.js} +1 -1
  143. package/dist/mint-components/{p-98e29140.system.entry.js → p-396bf448.system.entry.js} +1 -1
  144. package/dist/mint-components/{p-69902f7c.system.js → p-3b97aed8.system.js} +1 -1
  145. package/dist/mint-components/{p-1ec1dcb3.system.js → p-3ce2fb83.system.js} +1 -1
  146. package/dist/mint-components/p-3d856985.entry.js +1 -0
  147. package/dist/mint-components/{p-1dc2793a.system.entry.js → p-4052b948.system.entry.js} +1 -1
  148. package/dist/mint-components/{p-46cb29e2.system.entry.js → p-412a9226.system.entry.js} +1 -1
  149. package/dist/mint-components/{p-75b143ac.system.entry.js → p-44d0fc80.system.entry.js} +1 -1
  150. package/dist/mint-components/p-45c752a0.entry.js +1 -0
  151. package/dist/mint-components/{p-b6107771.js → p-46a4269a.js} +1 -1
  152. package/dist/mint-components/{p-16b0b00b.entry.js → p-52802c88.entry.js} +2 -2
  153. package/dist/mint-components/p-5480e4ee.entry.js +1 -0
  154. package/dist/mint-components/p-55508395.system.entry.js +1 -0
  155. package/dist/mint-components/{p-a59e65f2.js → p-563253e8.js} +1 -1
  156. package/dist/mint-components/{p-58fb3d02.system.js → p-60855d33.system.js} +1 -1
  157. package/dist/mint-components/{p-0e49a93f.system.entry.js → p-67ae18d1.system.entry.js} +1 -1
  158. package/dist/mint-components/{p-8bfe1f7d.js → p-6882070c.js} +1 -1
  159. package/dist/mint-components/{p-cafc22bf.system.entry.js → p-69bcf4fa.system.entry.js} +1 -1
  160. package/dist/mint-components/{p-1dc2e37a.system.entry.js → p-6bf0a4d9.system.entry.js} +1 -1
  161. package/dist/mint-components/{p-b9edc48d.system.entry.js → p-6e245fa3.system.entry.js} +1 -1
  162. package/dist/mint-components/{p-77f9b4af.entry.js → p-723ebe45.entry.js} +1 -1
  163. package/dist/mint-components/{p-e53399e5.system.entry.js → p-73148868.system.entry.js} +1 -1
  164. package/dist/mint-components/p-8435a22d.entry.js +1 -0
  165. package/dist/mint-components/p-883a32e7.entry.js +1 -0
  166. package/dist/mint-components/p-925ccb31.system.entry.js +58 -0
  167. package/dist/mint-components/{p-7ee8a7ed.system.js → p-9c554ca0.system.js} +1 -1
  168. package/dist/mint-components/{p-75ae6fc0.entry.js → p-9d6dbb2d.entry.js} +1 -1
  169. package/dist/mint-components/p-9e4fee30.system.entry.js +1 -0
  170. package/dist/mint-components/{p-101fafa3.js → p-a2c3cff3.js} +1 -1
  171. package/dist/mint-components/{p-6acfe4a0.entry.js → p-a4c2c7ed.entry.js} +1 -1
  172. package/dist/mint-components/{p-f3ea7918.system.js → p-a6094ff9.system.js} +1 -1
  173. package/dist/mint-components/{p-25021e09.entry.js → p-ade44a4e.entry.js} +1 -1
  174. package/dist/mint-components/{p-be62004c.entry.js → p-b1bb07db.entry.js} +1 -1
  175. package/dist/mint-components/{p-d4fe6a69.system.js → p-b608f7a4.system.js} +1 -1
  176. package/dist/mint-components/{p-503192e9.entry.js → p-b8bd2607.entry.js} +1 -1
  177. package/dist/mint-components/{p-17e6fc02.system.entry.js → p-be2738b0.system.entry.js} +1 -1
  178. package/dist/mint-components/{p-b2cb66f5.system.js → p-c6114bfe.system.js} +1 -1
  179. package/dist/mint-components/{p-d5a00e40.system.entry.js → p-c79c608d.system.entry.js} +1 -1
  180. package/dist/mint-components/{p-1dd1105d.system.entry.js → p-cca9026f.system.entry.js} +1 -1
  181. package/dist/mint-components/p-cd410a05.entry.js +9 -0
  182. package/dist/mint-components/p-cdeae699.system.js +1 -0
  183. package/dist/mint-components/{p-232dddcc.system.entry.js → p-d174d0bc.system.entry.js} +1 -1
  184. package/dist/mint-components/{p-bafc60df.js → p-d21e0dbd.js} +1 -1
  185. package/dist/mint-components/{p-d5b84d6b.js → p-d35b0366.js} +1 -1
  186. package/dist/mint-components/{p-24d13567.js → p-db2e4c42.js} +1 -1
  187. package/dist/mint-components/{p-35103a1b.system.entry.js → p-dc603d08.system.entry.js} +1 -1
  188. package/dist/mint-components/{p-8a9966fc.system.js → p-e7f633b9.system.js} +1 -1
  189. package/dist/mint-components/p-f17050de.entry.js +1 -0
  190. package/dist/mint-components/{p-441119ee.js → p-f90486ca.js} +15 -15
  191. package/dist/mint-components/p-fce1dbf6.entry.js +1 -0
  192. package/dist/mint-components/p-fdb484a0.entry.js +392 -0
  193. package/dist/types/components/sqm-reward-exchange-list/RewardExchangeList.stories.d.ts +9 -3
  194. package/dist/types/components/sqm-reward-exchange-list/RewardExchangeListData.d.ts +158 -36
  195. package/dist/types/components/sqm-reward-exchange-list/SVGs.d.ts +1 -0
  196. package/dist/types/components/sqm-reward-exchange-list/useRewardExchangeList.d.ts +0 -1
  197. package/dist/types/components/sqm-stencilbook/AutoColor.d.ts +1 -0
  198. package/dist/types/components/{sqm-task-card → sqm-stencilbook}/Matrix.d.ts +0 -0
  199. package/dist/types/components/sqm-stencilbook/Resizer.d.ts +3 -0
  200. package/dist/types/components/sqm-stencilbook/Themes.d.ts +16 -0
  201. package/dist/types/components/sqm-task-card/SVGs.d.ts +1 -0
  202. package/dist/types/components/sqm-task-card/TaskCard.stories.d.ts +4 -1
  203. package/dist/types/components/sqm-task-card/progress-bar/progress-bar-view.d.ts +1 -0
  204. package/dist/types/components/sqm-task-card/sqm-task-card-view.d.ts +1 -0
  205. package/dist/types/components/sqm-task-card/sqm-task-card.d.ts +5 -1
  206. package/dist/types/components.d.ts +8 -0
  207. package/grapesjs/grapesjs.js +1 -1
  208. package/package.json +4 -2
  209. package/dist/mint-components/p-024cc1be.system.entry.js +0 -1
  210. package/dist/mint-components/p-22d56623.entry.js +0 -9
  211. package/dist/mint-components/p-3098bb1b.system.entry.js +0 -1
  212. package/dist/mint-components/p-35ba4a8b.entry.js +0 -1
  213. package/dist/mint-components/p-51277d8e.system.entry.js +0 -1
  214. package/dist/mint-components/p-623e7f8c.entry.js +0 -335
  215. package/dist/mint-components/p-6410316b.entry.js +0 -1
  216. package/dist/mint-components/p-6cbb3a00.entry.js +0 -1
  217. package/dist/mint-components/p-853bd4bd.entry.js +0 -1
  218. package/dist/mint-components/p-85728f98.entry.js +0 -1
  219. package/dist/mint-components/p-8ec40f9a.entry.js +0 -1
  220. package/dist/mint-components/p-aa39d9c0.entry.js +0 -1
  221. package/dist/mint-components/p-dea06c92.entry.js +0 -1
  222. package/dist/mint-components/p-eb5aae94.entry.js +0 -1
  223. package/dist/mint-components/p-f7b80ac0.entry.js +0 -1
  224. package/dist/mint-components/p-f7d7e44d.system.js +0 -1
@@ -4,9 +4,9 @@ Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
5
  const index = require('./index-b0129cd6.js');
6
6
  const _extends = require('./extends-0302d27d.js');
7
- const global = require('./global-b957dd98.js');
7
+ const global = require('./global-6223fe8f.js');
8
8
  const useCallback = require('./use-callback-fadb2643.js');
9
- const index_module = require('./index.module-85eb6b4d.js');
9
+ const index_module = require('./index.module-7dd4b981.js');
10
10
  const jsonpointer = require('./jsonpointer-11327262.js');
11
11
  const jssPresetDefault_esm = require('./jss-preset-default.esm-6304d24f.js');
12
12
  const utils = require('./utils-95e5317c.js');
@@ -15,21 +15,21 @@ const mixins = require('./mixins-7b7c59fe.js');
15
15
  const sqmPortalContainerView = require('./sqm-portal-container-view-d144735a.js');
16
16
  const sqmPortalSectionView = require('./sqm-portal-section-view-3b008930.js');
17
17
  const sqmTextSpanView = require('./sqm-text-span-view-b5ae787b.js');
18
- const sqmLeaderboardRankView = require('./sqm-leaderboard-rank-view-9114d9ad.js');
19
- const reRender = require('./re-render-59955561.js');
20
- const useDemoBigStat = require('./useDemoBigStat-9193e8c5.js');
18
+ const sqmLeaderboardRankView = require('./sqm-leaderboard-rank-view-7dd44d62.js');
19
+ const reRender = require('./re-render-6111d4bd.js');
20
+ const useDemoBigStat = require('./useDemoBigStat-2786227e.js');
21
21
  const sqmShareLinkView = require('./sqm-share-link-view-a935d07e.js');
22
- const ShadowViewAddon = require('./ShadowViewAddon-d6a442a9.js');
22
+ const ShadowViewAddon = require('./ShadowViewAddon-a85b8c8d.js');
23
23
  const sqmNavigationSidebarView = require('./sqm-navigation-sidebar-view-d06e1885.js');
24
- const sqmNavigationSidebarItemView = require('./sqm-navigation-sidebar-item-view-b565a10a.js');
24
+ const sqmNavigationSidebarItemView = require('./sqm-navigation-sidebar-item-view-6c7f78e6.js');
25
25
  const sqmStatContainerView = require('./sqm-stat-container-view-ee7b00ff.js');
26
- const sqmPortalProfileView = require('./sqm-portal-profile-view-c3b889d4.js');
26
+ const sqmPortalProfileView = require('./sqm-portal-profile-view-14b41436.js');
27
27
  const sqmPortalForgotPasswordView = require('./sqm-portal-forgot-password-view-1704d285.js');
28
- const sqmPortalEmailVerificationView = require('./sqm-portal-email-verification-view-bd40f7eb.js');
28
+ const sqmPortalEmailVerificationView = require('./sqm-portal-email-verification-view-08d1848c.js');
29
29
  const sqmPortalResetPasswordView = require('./sqm-portal-reset-password-view-4d78fd6d.js');
30
30
  const sqmPortalVerifyEmailView = require('./sqm-portal-verify-email-view-b595e302.js');
31
31
  const sqmAssetCardView = require('./sqm-asset-card-view-07f86880.js');
32
- const sqmPortalFooterView = require('./sqm-portal-footer-view-b60e17c8.js');
32
+ const sqmPortalFooterView = require('./sqm-portal-footer-view-69c73802.js');
33
33
  const sqmHeroView = require('./sqm-hero-view-bb3d00a1.js');
34
34
  const sqmNameFieldsView = require('./sqm-name-fields-view-24614ac7.js');
35
35
 
@@ -14921,51 +14921,69 @@ function useRewardExchangeList(props) {
14921
14921
  };
14922
14922
  }
14923
14923
 
14924
- const ExchangeArrows = () => (index.h("svg", { width: "30", height: "30", viewBox: "0 0 30 30", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14925
- index.h("circle", { cx: "15", cy: "15", r: "15", fill: "white" }),
14926
- index.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" })));
14927
- const CheckMark = () => (index.h("svg", { xmlns: "http://www.w3.org/2000/svg", width: "10", height: "7", viewBox: "0 0 10 7", fill: "none" },
14928
- index.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" })));
14929
-
14930
- function Dot({ active, completed, incomplete, }) {
14924
+ const ExchangeArrows = () => (index.h("svg", { width: 19, height: 15, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14925
+ index.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" })));
14926
+ const CheckMark = () => (index.h("svg", { width: 12, height: 10, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14927
+ index.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" })));
14928
+ const Gift = () => (index.h("svg", { width: 156, height: 157, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
14929
+ index.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" }),
14930
+ index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M37.18 73.862v7.966h89.663v-7.966H37.18Z", fill: "#E9BB30" }),
14931
+ index.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" }),
14932
+ index.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" }),
14933
+ index.h("path", { d: "M75.086 74.224h13.85v7.604h-13.85v-7.604Z", fill: "#DD4747" }),
14934
+ index.h("g", { filter: "url(#a)" },
14935
+ index.h("ellipse", { cx: 82.008, cy: 141.207, rx: 36.813, ry: 5.793, fill: "#E0DDDD", "fill-opacity": 0.8 })),
14936
+ index.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" }),
14937
+ index.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" }),
14938
+ index.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" }),
14939
+ index.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" }),
14940
+ index.h("defs", null,
14941
+ index.h("filter", { id: "a", x: 35.195, y: 125.414, width: 93.625, height: 31.586, filterUnits: "userSpaceOnUse", "color-interpolation-filters": "s-rGB" },
14942
+ index.h("feFlood", { "flood-opacity": 0, result: "BackgroundImageFix" }),
14943
+ index.h("feBlend", { in: "SourceGraphic", in2: "BackgroundImageFix", result: "shape" }),
14944
+ index.h("feGaussianBlur", { stdDeviation: 5, result: "effect1_foregroundBlur_653_17907" })))));
14945
+
14946
+ function Dot({ active, completed, incomplete, stage, }) {
14931
14947
  return (index.h("div", { style: {
14932
- flex: "0 0 0",
14933
- content: "''",
14934
- height: "4px",
14935
- borderRadius: "4px",
14936
- background: incomplete ? "#E5E5E5" : "#9E9E9E",
14937
- position: "relative",
14938
- bottom: "0",
14939
- left: "0",
14940
14948
  display: "flex",
14941
- justifyContent: "center",
14942
- columnGap: "50px",
14943
- marginRight: "-2px",
14944
- boxSizing: "content-box",
14945
14949
  } },
14946
14950
  index.h("div", { style: {
14947
- backgroundColor: completed ? "#9E9E9E" : "#FFF",
14951
+ backgroundColor: completed
14952
+ ? "var(--sl-color-success-500)"
14953
+ : incomplete
14954
+ ? "var(--sl-color-neutral-200)"
14955
+ : "var(--sl-color-neutral-0)",
14948
14956
  border: active
14949
- ? "3px solid #9E9E9E"
14957
+ ? "1px solid var(--sl-color-success-500)"
14950
14958
  : incomplete
14951
- ? "3px solid #E5E5E5"
14952
- : "3px solid #9E9E9E",
14959
+ ? "1px solid var(--sl-color-neutral-200)"
14960
+ : "1px solid var(--sl-color-success-500)",
14953
14961
  borderRadius: "50%",
14954
- width: "10px",
14955
- height: "10px",
14956
- margin: "-6px auto 0px",
14962
+ width: "23px",
14963
+ height: "23px",
14964
+ margin: "-11px",
14957
14965
  zIndex: "1",
14958
14966
  boxSizing: "content-box",
14959
- } }, completed && (index.h("div", { style: { top: "-6px", position: "relative" } },
14960
- index.h(CheckMark, null))))));
14967
+ } }, completed ? (index.h("div", { style: { top: "-10.5%", left: "23.5%", position: "relative" } },
14968
+ index.h(CheckMark, null))) : (index.h("div", { style: {
14969
+ color: active
14970
+ ? "var(--sl-color-success-500)"
14971
+ : "var(--sl-color-neutral-50)",
14972
+ width: "23px",
14973
+ lineHeight: "24px",
14974
+ textAlign: "center",
14975
+ position: "relative",
14976
+ } }, stage + 1)))));
14961
14977
  }
14962
- function ProgressLine({ incomplete = false, active = false }) {
14978
+ function ProgressLine({ incomplete = false, active = false, invisible = false, }) {
14963
14979
  return (index.h("div", { style: {
14964
14980
  content: "''",
14965
14981
  flex: "0.5 0.5 0",
14966
14982
  height: "4px",
14967
14983
  borderRadius: "4px",
14968
- background: incomplete || active ? "#E5E5E5" : "#9E9E9E",
14984
+ background: incomplete || active
14985
+ ? "var(--sl-color-neutral-200)"
14986
+ : "var(--sl-color-success-500)",
14969
14987
  position: "relative",
14970
14988
  bottom: "0",
14971
14989
  left: "0",
@@ -14974,17 +14992,18 @@ function ProgressLine({ incomplete = false, active = false }) {
14974
14992
  columnGap: "50px",
14975
14993
  marginRight: "-2px",
14976
14994
  boxSizing: "content-box",
14995
+ opacity: invisible ? "0" : "1",
14977
14996
  } }));
14978
14997
  }
14979
- function Progress({ active, completed, incomplete }) {
14998
+ function Progress({ active, completed, incomplete, stage }) {
14980
14999
  return [
14981
- index.h(ProgressLine, { incomplete: incomplete }),
14982
- index.h(Dot, { active: active, completed: completed, incomplete: incomplete }),
14983
- index.h(ProgressLine, { incomplete: incomplete, active: active }),
15000
+ index.h(ProgressLine, { incomplete: incomplete, invisible: stage === 0 }),
15001
+ index.h(Dot, { active: active, completed: completed, incomplete: incomplete, stage: stage }),
15002
+ index.h(ProgressLine, { incomplete: incomplete, active: active, invisible: stage === 2 }),
14984
15003
  ];
14985
15004
  }
14986
15005
  function ProgressBar({ stageCount, currentStage, }) {
14987
- return (index.h("div", { style: { display: "flex", columnGap: "-2px" } }, Array.from(Array(stageCount).keys()).map((stage) => (index.h(Progress, { active: currentStage === stage, completed: currentStage > stage, incomplete: currentStage < stage })))));
15006
+ return (index.h("div", { style: { display: "flex", columnGap: "-2px" } }, Array.from(Array(stageCount).keys()).map((stage) => (index.h(Progress, { active: currentStage === stage, completed: currentStage > stage, incomplete: currentStage < stage, stage: stage })))));
14988
15007
  }
14989
15008
 
14990
15009
  const stageList = ["chooseReward", "chooseAmount", "confirmation", "success"];
@@ -15014,7 +15033,6 @@ function RewardExchangeView(props) {
15014
15033
  "&::part(base)": {
15015
15034
  boxShadow: "none",
15016
15035
  width: "100%",
15017
- // maxWidth: "350px",
15018
15036
  display: "flex",
15019
15037
  margin: "0 auto",
15020
15038
  },
@@ -15023,35 +15041,6 @@ function RewardExchangeView(props) {
15023
15041
  display: "flex",
15024
15042
  width: "100%",
15025
15043
  },
15026
- "& .text-area": {
15027
- textAlign: "left",
15028
- padding: "8px",
15029
- },
15030
- "& .title": {
15031
- fontSize: "var(--sl-font-size-medium)",
15032
- fontWeight: "var(--sl-font-weight-semibold)",
15033
- },
15034
- "& .amount": {
15035
- fontSize: "var(--sl-font-size-small)",
15036
- },
15037
- "& .error": {
15038
- fontSize: "var(--sl-font-size-small)",
15039
- color: "var(--sl-color-warning-500)",
15040
- },
15041
- "& .selected-outline": {
15042
- width: "18px",
15043
- height: "18px",
15044
- minWidth: "18px",
15045
- borderRadius: "50%",
15046
- background: "var(--sl-color-primary-500)",
15047
- position: "relative",
15048
- margin: "-9px",
15049
- left: "100%",
15050
- },
15051
- "& .selected-checkmark": {
15052
- position: "relative",
15053
- top: "-6px",
15054
- },
15055
15044
  },
15056
15045
  Drawer: {
15057
15046
  "&::part(base)": {
@@ -15069,14 +15058,14 @@ function RewardExchangeView(props) {
15069
15058
  FullImage: {
15070
15059
  objectFit: "contain",
15071
15060
  maxWidth: "100%",
15072
- height: "150px",
15061
+ height: "250px",
15073
15062
  display: "flex",
15074
15063
  margin: "0 auto",
15075
15064
  },
15076
15065
  PreviewImage: {
15077
15066
  objectFit: "contain",
15078
15067
  width: "120px",
15079
- height: "120px",
15068
+ height: "118px",
15080
15069
  flex: 0.33,
15081
15070
  },
15082
15071
  InputBox: {
@@ -15103,8 +15092,10 @@ function RewardExchangeView(props) {
15103
15092
  cursor: "pointer",
15104
15093
  },
15105
15094
  ProgressBar: {
15106
- fontSize: "80%",
15107
- marginBottom: "20px",
15095
+ maxWidth: "350px",
15096
+ width: "100%",
15097
+ margin: "auto",
15098
+ marginBottom: "var(--sl-spacing-xxx-large)",
15108
15099
  "& .text-area": {
15109
15100
  marginTop: "5px",
15110
15101
  display: "flex",
@@ -15113,16 +15104,133 @@ function RewardExchangeView(props) {
15113
15104
  whiteSpace: "nowrap",
15114
15105
  marginBottom: "6px",
15115
15106
  "& .text": {
15107
+ marginBottom: "var(--sl-spacing-x-small)",
15116
15108
  flex: "1 1 0",
15117
15109
  },
15118
15110
  "& .text.subdued": {
15119
- color: "#BDBDBD",
15111
+ color: "var(--sl-color-neutral-200)",
15120
15112
  },
15121
15113
  },
15122
15114
  },
15123
15115
  KutayCard: {
15116
+ display: "flex",
15117
+ userSelect: "none",
15118
+ height: "120px",
15124
15119
  "&::part(base)": {
15125
15120
  boxShadow: "none",
15121
+ width: "100%",
15122
+ },
15123
+ "&::part(body)": {
15124
+ display: "flex",
15125
+ padding: 0,
15126
+ },
15127
+ "& .selected-outline": {
15128
+ width: "18px",
15129
+ height: "18px",
15130
+ minWidth: "18px",
15131
+ borderRadius: "50%",
15132
+ background: "var(--sl-color-primary-500)",
15133
+ position: "relative",
15134
+ margin: "-9px",
15135
+ left: "100%",
15136
+ },
15137
+ "& .selected-checkmark": {
15138
+ position: "relative",
15139
+ left: "12%",
15140
+ top: "-29%",
15141
+ transform: "scale(0.8)",
15142
+ },
15143
+ },
15144
+ Square: {
15145
+ width: "120px",
15146
+ height: "118px",
15147
+ borderRadius: "3px 0 0 3px",
15148
+ "& .image": {
15149
+ width: "100%",
15150
+ height: "100%",
15151
+ objectFit: "contain",
15152
+ borderRadius: "inherit",
15153
+ },
15154
+ "& .image.subdued": {
15155
+ filter: "brightness(0.95)",
15156
+ opacity: "0.5",
15157
+ },
15158
+ },
15159
+ Image: {
15160
+ "& .image": {
15161
+ objectFit: "contain",
15162
+ width: "120px",
15163
+ height: "118px",
15164
+ flex: 0.33,
15165
+ },
15166
+ "& .image.black": {
15167
+ filter: "brightness(20%)",
15168
+ },
15169
+ },
15170
+ TextArea: {
15171
+ textAlign: "left",
15172
+ padding: "12px",
15173
+ "& .title": {
15174
+ fontSize: "16px",
15175
+ lineHeight: "20px",
15176
+ fontWeight: "600",
15177
+ color: "var(--sl-color-neutral-1000)",
15178
+ },
15179
+ "& .amount": {
15180
+ fontSize: "14px",
15181
+ lineHeight: "18px",
15182
+ marginTop: "8px",
15183
+ color: "var(--sl-color-neutral-500)",
15184
+ },
15185
+ "& .error": {
15186
+ fontSize: "14px",
15187
+ lineHeight: "18px",
15188
+ marginTop: "8px",
15189
+ fontWeight: "600",
15190
+ color: "var(--sl-color-warning-500)",
15191
+ },
15192
+ },
15193
+ ChooseAmount: {
15194
+ margin: "var(--sl-spacing-medium) 0",
15195
+ "& .title": {
15196
+ //fontSize: "var(--sl-font-size-large)",
15197
+ fontSize: "113%",
15198
+ fontWeight: "var(--sl-font-weight-semibold)",
15199
+ color: "var(--sl-color-neutral-1000)",
15200
+ },
15201
+ "& .points": {
15202
+ //fontSize: "var(--sl-font-size-large)",
15203
+ fontSize: "113%",
15204
+ fontWeight: "var(--sl-font-weight-semibold)",
15205
+ color: "var(--sl-color-sky-500)",
15206
+ },
15207
+ "& .description": {
15208
+ fontSize: "var(--sl-font-size-medium)",
15209
+ fontWeight: "var(--sl-font-weight-normal)",
15210
+ color: "var(--sl-color-neutral-500)",
15211
+ margin: "var(--sl-spacing-medium) 0",
15212
+ lineHeight: "var(--sl-line-height-dense)",
15213
+ marginTop: "var(--sl-spacing-xx-small)",
15214
+ },
15215
+ "& .space": {
15216
+ marginBottom: "var(--sl-spacing-xxx-large)",
15217
+ },
15218
+ },
15219
+ Success: {
15220
+ textAlign: "center",
15221
+ "& .title": {
15222
+ fontSize: "var(--sl-font-size-large)",
15223
+ fontWeight: "var(--sl-font-weight-semibold)",
15224
+ color: "var(--sl-color-neutral-1000)",
15225
+ },
15226
+ "& .description": {
15227
+ color: "var(--sl-color-neutral-400)",
15228
+ width: "100%",
15229
+ maxWidth: "350px",
15230
+ margin: "0 auto",
15231
+ lineHeight: "var(--sl-line-height-dense)",
15232
+ marginBottom: "var(--sl-spacing-xxx-large)",
15233
+ marginTop: "var(--sl-spacing-xx-small)",
15126
15234
  },
15127
15235
  },
15128
15236
  KutayButton: {
@@ -15155,6 +15263,9 @@ function RewardExchangeView(props) {
15155
15263
  "& .continue.right": {
15156
15264
  marginLeft: "auto",
15157
15265
  },
15266
+ "& .continue.center": {
15267
+ margin: "0 auto",
15268
+ },
15158
15269
  },
15159
15270
  };
15160
15271
  // JSS config
@@ -15190,7 +15301,7 @@ function RewardExchangeView(props) {
15190
15301
  id: "unavailableCode",
15191
15302
  defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15192
15303
  }, {
15193
- unavailableReason: step.unavailableReason || step.unavailableReasonCode,
15304
+ unavailableReason: step.unavailableReasonCode,
15194
15305
  }))))));
15195
15306
  })));
15196
15307
  }
@@ -15218,51 +15329,70 @@ function RewardExchangeView(props) {
15218
15329
  ? item.prettySourceValue
15219
15330
  : `${item.sourceMinValue} to ${item.prettySourceMaxValue}`;
15220
15331
  return (index.h("div", { key: item.key, class: item.available ? sheet.classes.CardContainer : "", style: style },
15221
- index.h("sl-card", { class: sheet.classes.Base, onClick: () => item.available &&
15332
+ index.h("sl-card", { class: sheet.classes.KutayCard, style: {
15333
+ cursor: item.unavailableReasonCode
15334
+ ? "not-allowed"
15335
+ : "pointer",
15336
+ }, onClick: () => item.available &&
15222
15337
  callbacks.setExchangeState({ selectedItem: item }) },
15223
15338
  item.key === (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.key) && (index.h("div", { class: "selected-outline" },
15224
15339
  index.h("div", { class: "selected-checkmark" },
15225
15340
  index.h(CheckMark, null)))),
15226
- // item?.imageUrl &&
15227
- index.h("img", { class: sheet.classes.PreviewImage, src: (item === null || item === void 0 ? void 0 : item.imageUrl) || index.getAssetPath("./assets/Reward-icon.png") }),
15228
- index.h("div", { class: "text-area" },
15229
- index.h("div", { class: "title" }, item.description),
15230
- index.h("div", { class: "amount" }, amount),
15231
- item.unavailableReasonCode && (index.h("div", { class: "error" }, global.intl.formatMessage({
15232
- id: "unavailableCode",
15233
- defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15234
- }, {
15235
- unavailableReason: item.unavailableReason ||
15236
- item.unavailableReasonCode,
15237
- })))))));
15341
+ index.h("div", { style: {
15342
+ display: "flex",
15343
+ width: "100%",
15344
+ borderRadius: "3px",
15345
+ background: item.unavailableReasonCode
15346
+ ? "rgba(0, 0, 0, 0.05)"
15347
+ : "rgba(0, 0, 0, 0)",
15348
+ } },
15349
+ index.h("div", { class: sheet.classes.Square },
15350
+ index.h("img", { class: item.unavailableReasonCode ? "image subdued" : "image", src: (item === null || item === void 0 ? void 0 : item.imageUrl) ||
15351
+ index.getAssetPath("./assets/placeholder.png") })),
15352
+ index.h("div", { class: sheet.classes.TextArea, style: {
15353
+ opacity: item.unavailableReasonCode ? "0.5" : "1",
15354
+ } },
15355
+ index.h("div", { class: "title" }, item.name),
15356
+ index.h("div", { class: "amount" }, amount),
15357
+ item.unavailableReasonCode && (index.h("div", { class: "error" }, global.intl.formatMessage({
15358
+ id: "unavailableCode",
15359
+ defaultMessage: (_b = (_a = states.content) === null || _a === void 0 ? void 0 : _a.text) === null || _b === void 0 ? void 0 : _b.notAvailableError,
15360
+ }, {
15361
+ unavailableReason: item.unavailableReason ||
15362
+ item.unavailableReasonCode,
15363
+ }))))))));
15238
15364
  })),
15239
15365
  index.h("div", { class: sheet.classes.KutayButton },
15240
15366
  index.h("sl-button", { class: "continue right", size: "large", onClick: () => callbacks.setStage("chooseAmount"), disabled: !states.selectedItem }, "Continue")),
15241
15367
  ];
15242
15368
  }
15243
15369
  function chooseAmount() {
15244
- var _a;
15370
+ var _a, _b, _c;
15245
15371
  const input = getInput();
15246
15372
  const isDisabled = ((_a = states.selectedItem) === null || _a === void 0 ? void 0 : _a.ruleType) === "FIXED_GLOBAL_REWARD"
15247
15373
  ? false
15248
15374
  : input && !states.amount;
15249
15375
  return (index.h("div", null,
15250
- index.h("div", null,
15251
- //selectedItem?.imageUrl &&
15252
- index.h("img", { class: sheet.classes.FullImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15253
- index.getAssetPath("./assets/Reward-icon.png") })),
15254
- index.h("b", null, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description),
15255
- index.h("div", { class: sheet.classes.InputBox }, input),
15376
+ index.h("div", null, index.h("img", { class: sheet.classes.FullImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15377
+ index.getAssetPath("./assets/placeholder.png") })),
15378
+ index.h("div", { class: sheet.classes.ChooseAmount },
15379
+ index.h("div", { class: "title" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name),
15380
+ ((_b = states.selectedItem) === null || _b === void 0 ? void 0 : _b.ruleType) === "FIXED_GLOBAL_REWARD" ? (index.h("div", { class: "points" }, input)) : (index.h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description)),
15381
+ ((_c = states.selectedItem) === null || _c === void 0 ? void 0 : _c.ruleType) === "FIXED_GLOBAL_REWARD" ? (index.h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description)) : (index.h("div", { class: "points" }, input)),
15382
+ index.h("div", { class: "space" })),
15256
15383
  index.h("div", { class: sheet.classes.KutayButton },
15257
15384
  index.h("sl-button", { class: "cancel", size: "large", type: "text", onClick: () => callbacks.resetState() }, "Cancel"),
15258
15385
  index.h("sl-button", { class: "continue", size: "large", onClick: () => callbacks.setStage("confirmation"), disabled: isDisabled }, "Continue to confirmation"))));
15259
15386
  }
15260
15387
  function confirmation() {
15261
15388
  return (index.h("div", null,
15262
- index.h("h2", null, "Confirm and redeem"),
15263
- index.h("div", { style: { textAlign: "center" } },
15389
+ index.h("h2", { style: { margin: "20px 0" } }, "Confirm and redeem"),
15390
+ index.h("div", { style: {
15391
+ textAlign: "center",
15392
+ marginBottom: "var(--sl-spacing-xxx-large)",
15393
+ } },
15264
15394
  index.h("p", null,
15265
- index.h("b", null, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettySourceValue) || (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.prettySourceValue))),
15395
+ index.h("span", { style: { fontSize: "18px" } }, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettySourceValue) || (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.prettySourceValue))),
15266
15396
  index.h("p", null,
15267
15397
  index.h(ExchangeArrows, null)),
15268
15398
  index.h("div", { class: sheet.classes.CardContainer, style: {
@@ -15271,20 +15401,27 @@ function RewardExchangeView(props) {
15271
15401
  flex: "1",
15272
15402
  minWidth: "100%",
15273
15403
  } },
15274
- index.h("sl-card", { class: sheet.classes.Base },
15275
- index.h("img", { class: sheet.classes.PreviewImage, src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15276
- index.getAssetPath("./assets/Reward-icon.png") }),
15277
- index.h("p", { style: { marginBottom: "0", flex: "1" } }, selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue)))),
15404
+ index.h("sl-card", { style: { width: "auto", maxWidth: "350px", margin: "auto" }, class: sheet.classes.KutayCard },
15405
+ index.h("div", { class: sheet.classes.Square },
15406
+ index.h("img", { class: "image", src: (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.imageUrl) ||
15407
+ index.getAssetPath("./assets/placeholder.png") })),
15408
+ index.h("div", { class: sheet.classes.TextArea, style: {
15409
+ lineHeight: "18px",
15410
+ alignSelf: "center",
15411
+ } }, (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue) ? (selectedStep === null || selectedStep === void 0 ? void 0 : selectedStep.prettyDestinationValue) +
15412
+ " " + (selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name)
15413
+ : selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.name)))),
15278
15414
  index.h("div", { class: sheet.classes.KutayButton },
15279
15415
  index.h("sl-button", { class: "cancel", type: "text", size: "large", onClick: () => callbacks.setStage("chooseAmount") }, "Back"),
15280
15416
  index.h("sl-button", { class: "continue", size: "large", onClick: callbacks.exchangeReward }, "Redeem"))));
15281
15417
  }
15282
15418
  function success() {
15283
- return (index.h("div", { style: { textAlign: "center" } },
15284
- index.h("img", { class: sheet.classes.FullImage, src: index.getAssetPath("./assets/Reward-icon.png") }),
15285
- index.h("p", { style: { color: "forestgreen" } }, "Reward Redeemed"),
15286
- (data === null || data === void 0 ? void 0 : data.fuelTankCode) && index.h("pre", null, data === null || data === void 0 ? void 0 : data.fuelTankCode),
15287
- index.h("sl-button", { class: "continue", type: "primary", size: "large", onClick: () => callbacks.resetState(true) }, "Done")));
15419
+ return (index.h("div", { class: sheet.classes.Success },
15420
+ index.h(Gift, null),
15421
+ index.h("div", { class: "title" }, "Reward Redeemed"),
15422
+ index.h("div", { class: "description" }, selectedItem === null || selectedItem === void 0 ? void 0 : selectedItem.description),
15423
+ index.h("div", { class: sheet.classes.KutayButton },
15424
+ index.h("sl-button", { class: "continue center", type: "primary", size: "large", onClick: () => callbacks.resetState(true) }, "Done"))));
15288
15425
  }
15289
15426
  const stages = {
15290
15427
  chooseReward: () => chooseReward(),
@@ -15297,7 +15434,7 @@ function RewardExchangeView(props) {
15297
15434
  const stageNumber = stageList.indexOf(states.redeemStage);
15298
15435
  return (index.h("div", { class: sheet.classes.ProgressBar },
15299
15436
  index.h("div", { class: "text-area" }, Object.keys(stageProgressList).map((stage) => {
15300
- if (stage === states.redeemStage) {
15437
+ if (stageList.indexOf(stage) <= stageNumber) {
15301
15438
  return index.h("span", { class: "text" }, stageProgressList[stage]);
15302
15439
  }
15303
15440
  else {
@@ -15306,25 +15443,16 @@ function RewardExchangeView(props) {
15306
15443
  })),
15307
15444
  index.h(ProgressBar, { stageCount: 3, currentStage: stageNumber })));
15308
15445
  }
15309
- // const BackButton = () => {
15310
- // if (states.redeemStage === "success") return "";
15311
- // let previousStage: Stages = "";
15312
- // if (states.redeemStage === "confirmation") {
15313
- // previousStage = "chooseAmount";
15314
- // } else if (states.redeemStage === "chooseAmount") {
15315
- // previousStage = "chooseReward";
15316
- // }
15317
- // return (
15318
- // <div slot="label">
15319
- // <a
15320
- // style={{ cursor: "pointer", fontSize: "80%", color: "#858585" }}
15321
- // onClick={() => callbacks.setStage(previousStage)}
15322
- // >
15323
- // <LeftArrow /> Back
15324
- // </a>
15325
- // </div>
15326
- // );
15327
- // };
15446
+ function loading() {
15447
+ return (index.h("div", { style: {
15448
+ display: "flex",
15449
+ height: "400px",
15450
+ alignItems: "center",
15451
+ justifyContent: "center",
15452
+ } },
15453
+ index.h("div", { style: { transform: "scale(5)" } },
15454
+ index.h("sl-spinner", null))));
15455
+ }
15328
15456
  function errorMessage() {
15329
15457
  return (index.h("sl-alert", { type: "danger", open: true },
15330
15458
  index.h("sl-icon", { slot: "icon", name: "exclamation-octagon" }),
@@ -15334,6 +15462,7 @@ function RewardExchangeView(props) {
15334
15462
  index.h("style", { type: "text/css" }, styleString),
15335
15463
  index.h("div", null,
15336
15464
  stageMap(),
15465
+ states.loading && loading(),
15337
15466
  states.exchangeError && errorMessage(),
15338
15467
  currentStage && currentStage())));
15339
15468
  }
@@ -21139,8 +21268,13 @@ function cartesian(...args) {
21139
21268
  }
21140
21269
 
21141
21270
  const checkmark_circle = () => {
21142
- return (index.h("svg", { xmlns: "http://www.w3.org/2000/svg", width: "18", height: "18", viewBox: "0 0 18 18" },
21143
- index.h("path", { fill: "currentColor", "fill-rule": "evenodd", d: "M1.636 9a7.364 7.364 0 1114.728 0A7.364 7.364 0 011.636 9zM9 0a9 9 0 100 18A9 9 0 009 0zm5.192 6.266a.982.982 0 00-1.548-1.208l-4.787 6.137-2.58-2.58a.982.982 0 00-1.39 1.388l3.367 3.366a.982.982 0 001.468-.09l5.47-7.013z", "clip-rule": "evenodd" })));
21271
+ return (index.h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
21272
+ index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M1.81818 10C1.81818 5.48131 5.48131 1.81818 10 1.81818C14.5187 1.81818 18.1818 5.48131 18.1818 10C18.1818 14.5187 14.5187 18.1818 10 18.1818C5.48131 18.1818 1.81818 14.5187 1.81818 10ZM10 0C4.47715 0 0 4.47715 0 10C0 15.5228 4.47715 20 10 20C15.5228 20 20 15.5228 20 10C20 4.47715 15.5228 0 10 0ZM15.7692 6.96189C16.1398 6.48683 16.0551 5.80132 15.58 5.43077C15.1049 5.06022 14.4194 5.14495 14.0489 5.62001L8.72994 12.4391L5.86229 9.5715C5.43627 9.14548 4.74554 9.14548 4.31952 9.5715C3.89349 9.99752 3.89349 10.6882 4.31952 11.1143L8.05976 14.8545C8.28083 15.0756 8.58613 15.1912 8.89818 15.172C9.21023 15.1528 9.49905 15.0006 9.69133 14.7541L15.7692 6.96189Z", fill: "currentColor" })));
21273
+ };
21274
+ const checkmark_filled = () => {
21275
+ return (index.h("svg", { width: "20", height: "20", viewBox: "0 0 20 20", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
21276
+ index.h("circle", { cx: "10", cy: "10", r: "10", fill: "currentColor" }),
21277
+ index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M14.65 6.19231C15.0459 6.5011 15.1165 7.07236 14.8077 7.46825L9.74277 13.9617C9.58254 14.1672 9.34186 14.294 9.08182 14.31C8.82178 14.326 8.56736 14.2297 8.38314 14.0454L5.26627 10.9286C4.91124 10.5735 4.91124 9.99794 5.26627 9.64292C5.62129 9.2879 6.19689 9.2879 6.55191 9.64292L8.94162 12.0326L13.3741 6.35001C13.6828 5.95412 14.2541 5.88352 14.65 6.19231Z", fill: "white" })));
21144
21278
  };
21145
21279
  const arrow_left_right = () => {
21146
21280
  return (index.h("svg", { width: 11, height: 12, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
@@ -21148,21 +21282,21 @@ const arrow_left_right = () => {
21148
21282
  };
21149
21283
 
21150
21284
  const gift = () => {
21151
- return (index.h("svg", { width: 16, height: 16, fill: "none", xmlns: "http://www.w3.org/2000/svg" },
21152
- index.h("path", { d: "M15 5H9v11h4.5a1 1 0 001-1V9h.5a1 1 0 001-1V6a1 1 0 00-1-1zM1.5 9v6a1 1 0 001 1H7V5H1a1 1 0 00-1 1v2a1 1 0 001 1h.5z", fill: "var(--sl-color-primary-200)" }),
21153
- index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M1.5 9v1h13V9h-13z", fill: "var(--sl-color-primary-300)" }),
21154
- index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M14 2.71c0 .886-1.33 2.227-2 2.29H9v11H7.002V5H4.588C3.212 4.702 2 3.645 2 2.52 2 1.426 2.476.558 3.342.183 4.169-.176 5.125.02 5.88.545c.927.643 1.447 1.851 1.919 2.947l.123.286.12-.272C8.51 2.45 9.045 1.243 9.94.596c.793-.573 1.801-.79 2.672-.397.9.405 1.388 1.336 1.388 2.51zM10.612 1.5c.48-.347 1.056-.41 1.548 0 .428.357.45.525.506.93l.01.07c0 .599-.516 1.5-1.032 1.5-.366 0-.653-.003-.922-.006-.49-.005-.92-.01-1.657.006.14-.272.252-.533.36-.782.285-.667.534-1.246 1.187-1.718zm-5.673 0c-.233-.161-.766-.09-.987.006-.183.08-.456.32-.456 1.015 0 .674 1.092 1.257 1.092 1.257S5.454 4 7.002 4c-.527-1.305-1.273-1.951-2.063-2.5z", fill: "var(--sl-color-primary-600)" })));
21285
+ return (index.h("svg", { width: "16", height: "16", viewBox: "0 0 16 16", fill: "none", xmlns: "http://www.w3.org/2000/svg" },
21286
+ index.h("path", { d: "M15 5H12.4508H9V16H13.5C14.0523 16 14.5 15.5523 14.5 15V9H15C15.5523 9 16 8.55228 16 8V6C16 5.44772 15.5523 5 15 5Z", fill: "#F2C94C" }),
21287
+ index.h("path", { d: "M1.5 9V15C1.5 15.5523 1.94772 16 2.5 16H7V5H4.64242H1C0.447715 5 0 5.44772 0 6V8C0 8.55228 0.447715 9 1 9H1.5Z", fill: "#F2C94C" }),
21288
+ index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M1.5 9V10H14.5V9H1.5Z", fill: "#BE9720" }),
21289
+ index.h("path", { "fill-rule": "evenodd", "clip-rule": "evenodd", d: "M14 2.70949C14 3.59565 12.6694 4.93746 12 5H9V16H7.00179V5H4.58792C3.21247 4.70182 2 3.64537 2 2.52072C2 1.42474 2.47603 0.556701 3.34184 0.182041C4.16921 -0.175986 5.12452 0.0203328 5.87976 0.544666C6.80676 1.18825 7.32679 2.3963 7.79856 3.49226C7.83996 3.58845 7.88099 3.68378 7.9219 3.77778C7.96173 3.68865 8.00186 3.59793 8.0425 3.50608C8.50995 2.44948 9.04359 1.24325 9.9404 0.59563C10.7332 0.0231438 11.741 -0.193157 12.6121 0.198945C13.5129 0.604397 14 1.53453 14 2.70949ZM10.6123 1.5C11.0928 1.15305 11.668 1.09012 12.1597 1.5C12.5879 1.85694 12.6108 2.02497 12.6658 2.42926L12.6755 2.5C12.6755 3.09851 12.1597 4 11.6439 4C11.2785 4 10.9914 3.99691 10.7224 3.99402C10.2319 3.98875 9.80131 3.98412 9.06496 4C9.20533 3.72786 9.31743 3.46669 9.42434 3.21761C9.71026 2.55143 9.95907 1.97176 10.6123 1.5ZM4.93861 1.5C4.70607 1.33855 4.17281 1.4106 3.95166 1.5063C3.76894 1.58537 3.49602 1.82658 3.49602 2.52072C3.49602 3.19524 4.58792 3.77778 4.58792 3.77778C4.58792 3.77778 5.45441 4 7.00179 4C6.47506 2.69451 5.7289 2.04867 4.93861 1.5Z", fill: "#EB5757" })));
21155
21290
  };
21156
21291
 
21157
21292
  function ProgressBarView(props) {
21158
- const { progress = 0, goal = 1, steps = false, progressBarUnit = "", repeatable = false, expired = false, } = props;
21159
- console.log("progress bar props", props);
21293
+ const { progress = 0, goal = 1, steps = false, progressBarUnit = "", repeatable = false, expired = false, finite = 0, } = props;
21294
+ // console.log("progress bar props", props);
21160
21295
  const gift1 = gift();
21161
21296
  const gift2 = gift();
21162
21297
  const gift3 = gift();
21163
21298
  var items = [];
21164
21299
  var columns = "";
21165
- var repetitions = Math.floor(progress / goal);
21166
21300
  if (repeatable) {
21167
21301
  if (steps) {
21168
21302
  addStepsRepeatable();
@@ -21183,12 +21317,12 @@ function ProgressBarView(props) {
21183
21317
  const style = {
21184
21318
  ProgressBar: {
21185
21319
  "& .progress-bar": {
21186
- height: "15px",
21320
+ height: "0",
21187
21321
  marginTop: steps
21188
21322
  ? "var(--sl-spacing-medium)"
21189
21323
  : "var(--sl-spacing-large)",
21190
21324
  filter: expired ? "grayscale(1)" : "",
21191
- marginBottom: "var(--sl-spacing-xx-large)",
21325
+ marginBottom: "var(--sl-spacing-xxx-large)",
21192
21326
  marginRight: "var(--sl-spacing-x-small)",
21193
21327
  fontSize: "var(--sl-font-size-x-small)",
21194
21328
  display: "grid",
@@ -21293,7 +21427,10 @@ function ProgressBarView(props) {
21293
21427
  const styleString = sheet.toString();
21294
21428
  return (index.h("div", { class: sheet.classes.ProgressBar },
21295
21429
  index.h("style", { type: "text/css" }, styleString),
21296
- index.h("div", { class: repetitions > 1 ? "progress-bar repeatable-steps" : "progress-bar" }, items)));
21430
+ index.h("div", { class: (!Boolean(finite) && progress >= 2 * goal) ||
21431
+ (Boolean(finite) && progress > 2 * goal)
21432
+ ? "progress-bar repeatable-steps"
21433
+ : "progress-bar" }, items)));
21297
21434
  function clamp(x, min, max) {
21298
21435
  return Math.min(Math.max(x, min), max);
21299
21436
  }
@@ -21366,6 +21503,23 @@ function ProgressBarView(props) {
21366
21503
  items.push(index.h("div", { class: "progress bg" }, progressBarUnit + goal * 2));
21367
21504
  items.push(index.h("div", { class: "gift bw" }, gift2));
21368
21505
  }
21506
+ // finite repetition hit
21507
+ else if (finite && repetitions >= finite) {
21508
+ if (repetitions > 2) {
21509
+ items.push(index.h("div", { class: "progress bg" }, progressBarUnit + goal * (finite - 2)));
21510
+ items.push(index.h("div", { class: "gift start" }, gift1));
21511
+ columns = "0fr 0fr 0.5fr 0fr 0fr 0.5fr 0fr 0fr";
21512
+ }
21513
+ else {
21514
+ columns = "0.5fr 0fr 0fr 0.5fr 0fr 0fr";
21515
+ }
21516
+ items.push(index.h("div", { class: "filled" }));
21517
+ items.push(index.h("div", { class: "progress bg" }, progressBarUnit + goal * (finite - 1)));
21518
+ items.push(index.h("div", { class: "gift" }, gift2));
21519
+ items.push(index.h("div", { class: "filled" }));
21520
+ items.push(index.h("div", { class: "progress bg" }, progressBarUnit + goal * finite));
21521
+ items.push(index.h("div", { class: "gift" }, gift3));
21522
+ }
21369
21523
  // multiple repetitions
21370
21524
  else {
21371
21525
  columns =
@@ -21466,29 +21620,27 @@ function ProgressBarView(props) {
21466
21620
  }
21467
21621
 
21468
21622
  function TaskCardView(props) {
21469
- console.log({ props });
21623
+ // console.log({ props });
21470
21624
  const checkmark_circle$1 = checkmark_circle();
21625
+ const checkmark_filled$1 = checkmark_filled();
21471
21626
  const arrow_left_right$1 = arrow_left_right();
21472
21627
  const style = {
21473
21628
  HostBlock: mixins.HostBlock,
21474
21629
  TaskCard: {
21475
- "& .main > div": {
21476
- margin: "var(--sl-spacing-medium)",
21477
- },
21478
21630
  "& .main": {
21479
21631
  position: "relative",
21480
21632
  boxSizing: "border-box",
21481
21633
  minWidth: "347px",
21482
21634
  background: "var(--sl-color-neutral-0)",
21483
- border: "1px solid var(--sl-color-neutral-300)",
21484
- borderRadius: "var(--sl-border-radius-medium)",
21635
+ border: "1px solid var(--sl-color-neutral-200)",
21636
+ borderRadius: "var(--sl-border-radius-large)",
21485
21637
  fontSize: "var(--sl-font-size-small)",
21486
21638
  lineHeight: "var(--sl-line-height-dense)",
21487
21639
  color: "var(--sl-color-neutral-600)",
21488
21640
  },
21489
21641
  "& .main.complete": {
21490
- background: "var(--sl-color-success-50)",
21491
- borderColor: "var(--sl-color-success-700)",
21642
+ background: "var(--sl-color-primary-50)",
21643
+ borderColor: "var(--sl-color-primary-500)",
21492
21644
  },
21493
21645
  "& .main.expired": {
21494
21646
  color: "var(--sl-color-neutral-400)",
@@ -21497,17 +21649,30 @@ function TaskCardView(props) {
21497
21649
  "& .title": {
21498
21650
  fontSize: "var(--sl-font-size-small)",
21499
21651
  fontWeight: "var(--sl-font-weight-semibold)",
21652
+ color: "var(--sl-color-neutral-950)",
21500
21653
  },
21501
- "& .black": {
21502
- color: "var(--sl-color-neutral-1000)",
21654
+ "& .container": {
21655
+ margin: "var(--sl-spacing-medium)",
21656
+ },
21657
+ "& .container.subdued": {
21658
+ opacity: "0.66",
21659
+ },
21660
+ "& .container > div": {
21661
+ margin: "var(--sl-spacing-medium) 0",
21503
21662
  },
21504
21663
  },
21664
+ Expired: {
21665
+ margin: "var(--sl-spacing-medium)",
21666
+ marginBottom: "calc(var(--sl-spacing-x-small)*-1)",
21667
+ color: "var(--sl-color-warning-500)",
21668
+ fontWeight: "var(--sl-font-weight-semibold)",
21669
+ },
21505
21670
  Header: {
21506
21671
  display: "flex",
21507
21672
  "& .icon": {
21508
21673
  alignSelf: "center",
21509
21674
  lineHeight: "0",
21510
- color: "var(--sl-color-success-700)",
21675
+ color: "var(--sl-color-primary-400)",
21511
21676
  fontSize: "var(--sl-font-size-large)",
21512
21677
  marginRight: "var(--sl-spacing-x-small)",
21513
21678
  },
@@ -21515,6 +21680,7 @@ function TaskCardView(props) {
21515
21680
  alignSelf: "center",
21516
21681
  fontSize: "var(--sl-font-size-x-large)",
21517
21682
  fontWeight: "var(--sl-font-weight-semibold)",
21683
+ color: "var(--sl-color-neutral-950)",
21518
21684
  lineHeight: "100%",
21519
21685
  marginRight: "var(--sl-spacing-xx-small)",
21520
21686
  },
@@ -21522,6 +21688,7 @@ function TaskCardView(props) {
21522
21688
  alignSelf: "end",
21523
21689
  textTransform: "uppercase",
21524
21690
  fontSize: "var(--sl-font-size-x-small)",
21691
+ color: "var(--sl-color-neutral-950)",
21525
21692
  lineHeight: "var(--sl-font-size-medium)",
21526
21693
  marginRight: "var(--sl-spacing-xx-small)",
21527
21694
  },
@@ -21530,9 +21697,6 @@ function TaskCardView(props) {
21530
21697
  fontWeight: "var(--sl-font-weight-semibold)",
21531
21698
  marginBottom: "var(--sl-spacing-xx-small)",
21532
21699
  },
21533
- "& .black": {
21534
- color: "var(--sl-color-neutral-1000)",
21535
- },
21536
21700
  "& .neutral": {
21537
21701
  color: "var(--sl-color-neutral-400)",
21538
21702
  },
@@ -21542,6 +21706,7 @@ function TaskCardView(props) {
21542
21706
  "& .icon": {
21543
21707
  fontSize: "var(--sl-font-size-xx-small)",
21544
21708
  marginRight: "var(--sl-spacing-xx-small)",
21709
+ verticalAlign: "bottom",
21545
21710
  },
21546
21711
  "& .text": {
21547
21712
  marginTop: "auto",
@@ -21549,7 +21714,7 @@ function TaskCardView(props) {
21549
21714
  fontSize: "var(--sl-font-size-x-small)",
21550
21715
  },
21551
21716
  "& .success": {
21552
- color: "var(--sl-color-success-600)",
21717
+ color: "var(--sl-color-primary-500)",
21553
21718
  fontWeight: "var(--sl-font-weight-semibold)",
21554
21719
  },
21555
21720
  "& .action": {
@@ -21560,6 +21725,10 @@ function TaskCardView(props) {
21560
21725
  borderRadius: "var(--sl-border-radius-medium)",
21561
21726
  },
21562
21727
  "&.disabled::part(base)": {
21728
+ border: "1px solid var(--sl-color-primary-400)",
21729
+ background: "var(--sl-color-primary-400)",
21730
+ },
21731
+ "&.neutral::part(base)": {
21563
21732
  border: "1px solid var(--sl-color-neutral-400)",
21564
21733
  background: "var(--sl-color-neutral-400)",
21565
21734
  },
@@ -21579,8 +21748,11 @@ function TaskCardView(props) {
21579
21748
  const dateStart = props.showExpiry && luxon.DateTime.fromISO(props.rewardDuration.split("/")[0]);
21580
21749
  const dateEnd = props.showExpiry && luxon.DateTime.fromISO(props.rewardDuration.split("/")[1]);
21581
21750
  const dateToday = luxon.DateTime.now();
21582
- const taskComplete = showComplete && props.repeatable === false;
21583
- const taskUnavailable = props.showExpiry && (dateEnd < dateToday || dateToday < dateStart);
21751
+ const taskComplete = (showComplete && props.repeatable === false) ||
21752
+ (props.finite && props.progress >= props.finite * props.goal);
21753
+ const taskEnded = props.showExpiry && dateEnd <= dateToday;
21754
+ const taskNotStarted = props.showExpiry && dateToday <= dateStart;
21755
+ const taskUnavailable = taskEnded || taskNotStarted;
21584
21756
  return (index.h("div", { class: sheet.classes.TaskCard },
21585
21757
  index.h("div", { class: taskUnavailable
21586
21758
  ? "main expired"
@@ -21588,34 +21760,43 @@ function TaskCardView(props) {
21588
21760
  ? "main complete"
21589
21761
  : "main" },
21590
21762
  index.h("style", { type: "text/css" }, styleString),
21591
- index.h("div", { class: sheet.classes.Header }, props.loading ? (index.h("sl-skeleton", { style: { width: "22%", margin: "0", height: "12px" } })) : (index.h("div", null,
21592
- taskUnavailable && (index.h("div", { class: "end" }, "Available " +
21593
- dateStart.toLocaleString(luxon.DateTime.DATE_MED).split(",")[0] +
21594
- " - " +
21595
- dateEnd.toLocaleString(luxon.DateTime.DATE_MED).split(",")[0])),
21596
- showComplete && (index.h("span", { class: taskUnavailable ? "icon neutral" : "icon" }, checkmark_circle$1)),
21597
- index.h("span", { class: taskUnavailable ? "value" : "value black" }, props.rewardAmount),
21598
- index.h("span", { class: "text" }, props.rewardUnit)))),
21599
- props.loading ? (index.h("sl-skeleton", { style: { width: "42%", margin: "0 16px", height: "12px" } })) : (index.h("div", { class: taskUnavailable ? "title" : "title black" }, props.cardTitle)),
21600
- props.loading ? (index.h("sl-skeleton", { style: { margin: "12px 16px", height: "12px" } })) : (index.h(Details, Object.assign({}, props))),
21601
- props.showProgressBar && props.loading ? (index.h("sl-skeleton", { style: { margin: "0 16px", height: "12px" } })) : (props.showProgressBar && (index.h(ProgressBarView, Object.assign({}, props, { complete: taskComplete, expired: taskUnavailable })))),
21602
- index.h("div", { class: sheet.classes.Footer }, props.loading ? (index.h("sl-skeleton", { style: { width: "25%", marginLeft: "auto", height: "12px" } })) : (index.h("div", { style: { display: "contents" } },
21603
- index.h("span", { class: "text" },
21604
- props.repeatable && (index.h("div", null,
21605
- index.h("span", { class: repetitions > 0
21606
- ? taskUnavailable
21607
- ? "icon neutral"
21608
- : "icon success"
21609
- : "icon" }, arrow_left_right$1),
21610
- index.h("span", { class: repetitions > 0
21611
- ? taskUnavailable
21612
- ? "neutral"
21613
- : "success"
21614
- : "" }, "Completed " + repetitions + " times"))),
21615
- props.showExpiry && !taskUnavailable && (index.h("span", null, "Ends " + dateEnd.toLocaleString(luxon.DateTime.DATE_FULL)))),
21616
- index.h("sl-button", { class: taskComplete || taskUnavailable ? "action disabled" : "action", type: "primary", size: "small", onClick: () => props.openNewTab
21617
- ? window.open(props.buttonLink)
21618
- : window.open(props.buttonLink, "_self"), disabled: taskComplete || taskUnavailable }, props.buttonText)))))));
21763
+ taskUnavailable && (index.h("div", { class: sheet.classes.Expired }, taskEnded
21764
+ ? "Ended " + dateEnd.toLocaleString(luxon.DateTime.DATE_MED)
21765
+ : "Starts " + dateStart.toLocaleString(luxon.DateTime.DATE_MED))),
21766
+ index.h("div", { class: taskComplete || taskUnavailable ? "container subdued" : "container" },
21767
+ index.h("div", { class: sheet.classes.Header }, props.loading ? (index.h("sl-skeleton", { style: { width: "22%", margin: "0" } })) : (index.h("div", null,
21768
+ showComplete && (index.h("span", { class: taskUnavailable ? "icon neutral" : "icon" }, taskComplete ? checkmark_filled$1 : checkmark_circle$1)),
21769
+ index.h("span", { class: taskUnavailable ? "value black" : "value black" }, props.rewardAmount),
21770
+ index.h("span", { class: "text" }, props.rewardUnit)))),
21771
+ props.loading ? (index.h("sl-skeleton", { style: { width: "42%", margin: "var(--sl-spacing-medium) 0" } })) : (index.h("div", { class: taskUnavailable ? "title black" : "title black" }, props.cardTitle)),
21772
+ props.loading ? (index.h("sl-skeleton", { style: { margin: "var(--sl-spacing-medium) 0" } })) : (index.h(Details, Object.assign({}, props))),
21773
+ props.showProgressBar && props.loading ? (index.h("sl-skeleton", { style: { margin: "var(--sl-spacing-medium) 0" } })) : (props.showProgressBar && (index.h(ProgressBarView, Object.assign({}, props, { complete: taskComplete, expired: taskUnavailable })))),
21774
+ index.h("div", { class: sheet.classes.Footer }, props.loading ? (index.h("sl-skeleton", { style: { width: "25%", marginLeft: "auto" } })) : (index.h("div", { style: { display: "contents" } },
21775
+ index.h("span", { class: "text" },
21776
+ props.repeatable && (index.h("div", null,
21777
+ index.h("span", { class: repetitions > 0
21778
+ ? taskUnavailable
21779
+ ? "icon neutral"
21780
+ : "icon success"
21781
+ : "icon" }, arrow_left_right$1),
21782
+ index.h("span", { class: repetitions > 0
21783
+ ? taskUnavailable
21784
+ ? "neutral"
21785
+ : "success"
21786
+ : "" }, "Completed " +
21787
+ (props.finite
21788
+ ? Math.min(repetitions, props.finite)
21789
+ : repetitions) +
21790
+ (props.finite ? "/" + props.finite : "") +
21791
+ " times"))),
21792
+ props.showExpiry && !taskUnavailable && (index.h("span", null, "Ends " + dateEnd.toLocaleString(luxon.DateTime.DATE_FULL)))),
21793
+ index.h("sl-button", { class: taskUnavailable
21794
+ ? "action neutral"
21795
+ : taskComplete
21796
+ ? "action disabled"
21797
+ : "action", type: "primary", size: "small", onClick: () => props.openNewTab
21798
+ ? window.open(props.buttonLink)
21799
+ : window.open(props.buttonLink, "_parent"), disabled: taskComplete || taskUnavailable }, props.buttonText))))))));
21619
21800
  }
21620
21801
  function Details(props) {
21621
21802
  const style = {
@@ -21642,10 +21823,10 @@ function Details(props) {
21642
21823
  transition: "all var(--sl-transition-medium) ease",
21643
21824
  maxHeight: "300px",
21644
21825
  marginBottom: props.steps
21645
- ? "var(--sl-spacing-large)"
21826
+ ? "var(--sl-spacing-x-large)"
21646
21827
  : props.showProgressBar
21647
21828
  ? "var(--sl-spacing-xx-large)"
21648
- : "var(--sl-spacing-large)",
21829
+ : "var(--sl-spacing-x-large)",
21649
21830
  },
21650
21831
  "& .summary": {
21651
21832
  display: "block",
@@ -21674,6 +21855,32 @@ const scenarioTaskCard = "@author:derek\r\n@owner:\r\nFeature: Task Card\r\n\r\n
21674
21855
 
21675
21856
  const scenarioProgressBar = "@author:\r\n@owner:\r\nFeature: Task Card Progress Bar\r\n\r\n\tScenario Outline: Progress Bar\r\n\r\n\t\tGiven a Task Card component\r\n\t\tAnd progress is <progress>\r\n\t\tAnd goal is <goal>\r\n\t\tThen I have <progressBar>\r\n\t\tAnd <progressBar> shows <progress> with <unit> above\r\n\t\tAnd gift icon has <color>\r\n\t\tAnd gift icon shows <goal> with <unit> below\r\n\r\n\t\tExamples:\r\n\t\t\t| progress | goal | progressBar | unit | color |\r\n\t\t\t| -100 | 500 | ●――――――――――――――――――🎁 | $ | no |\r\n\t\t\t| 0 | 500 | ●――――――――――――――――――🎁 | $ | no |\r\n\t\t\t| 250 | 500 | ―――――――――●―――――――――🎁 | $ | no |\r\n\t\t\t| 500 | 500 | ―――――――――――――――――――🎁 | $ | yes |\r\n\t\t\t| 1000 | 500 | ―――――――――――――――――――🎁 | $ | yes |\r\n\r\n\tScenario Outline: Progress Bar Steps\r\n\r\n\t\tGiven a Task Card component\r\n\t\tAnd progress is <progress>\r\n\t\tAnd goal is <goal>\r\n\t\tAnd steps is enabled\r\n\t\tThen I have <progressBar>\r\n\t\tAnd <progressBar> has incrementing steps from 1 to <goal>\r\n\t\tAnd gift icon has <color>\r\n\t\tAnd gift icon shows <goal> below\r\n\r\n\t\tExamples:\r\n\t\t\t| progress | goal | progressBar | color |\r\n\t\t\t| -1 | 5 | ―――○―――○―――○―――○―――🎁 | no |\r\n\t\t\t| 0 | 5 | ―――○―――○―――○―――○―――🎁 | no |\r\n\t\t\t| 1 | 5 | ―――●―――○―――○―――○―――🎁 | no |\r\n\t\t\t| 5 | 5 | ―――○―――○―――○―――●―――🎁 | yes |\r\n\t\t\t| 7 | 5 | ―――○―――○―――○―――●―――🎁 | yes |\r\n\r\n\r\n\tScenario Outline: Progress Bar Repeatable\r\n\r\n\t\tGiven a Task Card component\r\n\t\tAnd progress is <progress>\r\n\t\tAnd goal is <goal>\r\n\t\tAnd it is repeatable\r\n\t\tThen I have <progressBar>\r\n\t\tAnd <progressBar> shows <progress> with <unit> above\r\n\t\tAnd <icon1> is <color1> with <text1> displayed below\r\n\t\tAnd <icon2> is <color2> with <text2> displayed below\r\n\t\tAnd <icon3> is <color3> with <text3> displayed below\r\n\r\n\t\tExamples:\r\n\t\t\t| progress | goal | progressBar | unit | icon1 | color1 | text1 | icon2 | color2 | text 2 | icon3 | color3 | text 1 | text 3 |\r\n\t\t\t| 250 | 500 | ――――●――――🎁―――――――🎁 | $ | NA | NA | NA | gift | greyscale | 500 | gift | greyscale | NA | 1000 |\r\n\t\t\t| 500 | 500 | ―――――――――🎁―――――――🎁 | $ | NA | NA | NA | gift | colorful | 500 | gift | greyscale | NA | 1000 |\r\n\t\t\t| 750 | 500 | ―――――――――🎁―――●―――🎁 | $ | NA | NA | NA | gift | colorful | 500 | gift | greyscale | NA | 1000 |\r\n\t\t\t| 1000 | 500 | 🎁―――――――🎁―――――――🎁 | $ | gift | colorful | 500 | gift | colorful | 1000 | gift | greyscale | 500 | 1500 |\r\n\t\t\t| 1250 | 500 | 🎁―――――――🎁―――●―――🎁 | $ | gift | colorful | 500 | gift | colorful | 1000 | gift | greyscale | 500 | 1500 |\r\n\r\n\tScenario Outline: Progress Bar Steps Repeatable\r\n\r\n\t\tGiven a Task Card component\r\n\t\tAnd progress is <progress>\r\n\t\tAnd goal is <goal>\r\n\t\tAnd steps is enabled\r\n\t\tAnd it is repeatable\r\n\t\tThen I have <progressBar>\r\n\r\n\t\tExamples:\r\n\t\t\t| progress | goal | progressBar |";
21676
21857
 
21858
+ const ResizerStylesheet = `
21859
+
21860
+ :root{
21861
+ --checker-color-1: #ffffff00;
21862
+ --checker-color-2: #ffffff00;
21863
+ --checker-size: 7px;
21864
+ --checker-gradient: linear-gradient(45deg, var(--checker-color-1) 25%, transparent 25%, transparent 75%, var(--checker-color-1) 75%);
21865
+ }
21866
+ .resizer{
21867
+ resize: horizontal;
21868
+ border: 2px dashed gray;
21869
+ margin: -2px;
21870
+ padding: 12px;
21871
+ height: fit-content;
21872
+ overflow: hidden;
21873
+ }
21874
+
21875
+ .resizer{
21876
+ background-color: var(--checker-color-2);
21877
+ background-image: var(--checker-gradient), var(--checker-gradient);
21878
+ background-position: 0 0, var(--checker-size) var(--checker-size);
21879
+ background-size: calc(var(--checker-size) * 2) calc(var(--checker-size) * 2);
21880
+ }
21881
+ `;
21882
+ const Resizer = (_, children) => (index.h("div", { class: "resizer" }, children));
21883
+
21677
21884
  const scenario$5 = scenarioTaskCard + scenarioProgressBar;
21678
21885
  const TaskCard_stories = {
21679
21886
  title: "Components/Task Card/",
@@ -21707,6 +21914,7 @@ const oneAction = {
21707
21914
  showExpiry: false,
21708
21915
  rewardDuration: null,
21709
21916
  loading: false,
21917
+ finite: 0,
21710
21918
  };
21711
21919
  const coupleActions = {
21712
21920
  rewardAmount: 40,
@@ -21724,6 +21932,7 @@ const coupleActions = {
21724
21932
  showExpiry: false,
21725
21933
  rewardDuration: null,
21726
21934
  loading: false,
21935
+ finite: 0,
21727
21936
  };
21728
21937
  const manyActions = {
21729
21938
  rewardAmount: 150,
@@ -21741,6 +21950,49 @@ const manyActions = {
21741
21950
  showExpiry: false,
21742
21951
  rewardDuration: null,
21743
21952
  loading: false,
21953
+ finite: 0,
21954
+ };
21955
+ const TaskCard$1 = () => {
21956
+ const expire = {
21957
+ showExpiry: true,
21958
+ rewardDuration: "2021-11-30T08:00:00.000Z/2021-12-01T08:00:00.000Z",
21959
+ };
21960
+ const expireRepeat = { ...expire, repeatable: true };
21961
+ return (index.h("div", { style: storyFrame },
21962
+ index.h(Resizer, null,
21963
+ index.h("h4", null, "Not Repeatable"),
21964
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 0 })),
21965
+ " ",
21966
+ index.h("h5", null),
21967
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 1 })),
21968
+ " ",
21969
+ index.h("h5", null),
21970
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 230 }))),
21971
+ index.h(Resizer, null,
21972
+ index.h("h4", null, "Repeatable"),
21973
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 2, repeatable: true })),
21974
+ " ",
21975
+ index.h("h5", null),
21976
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 7, repeatable: true })),
21977
+ index.h("h5", null),
21978
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 650, repeatable: true }))),
21979
+ index.h(Resizer, null,
21980
+ index.h("h4", null, "Complete"),
21981
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 1 })),
21982
+ " ",
21983
+ index.h("h5", null),
21984
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 5 })),
21985
+ " ",
21986
+ index.h("h5", null),
21987
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 500 }))),
21988
+ index.h(Resizer, null,
21989
+ index.h("h4", null, "Unavailable"),
21990
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 0 }, expireRepeat)),
21991
+ " ",
21992
+ index.h("h5", null),
21993
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 3 }, expireRepeat)),
21994
+ index.h("h5", null),
21995
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 250 }, expireRepeat)))));
21744
21996
  };
21745
21997
  const TaskCardNotRepeatable = () => {
21746
21998
  return (index.h("div", { style: storyFrame },
@@ -21800,10 +22052,51 @@ const TaskCardRepeatable = () => {
21800
22052
  index.h(TaskCardView, Object.assign({}, manyActions, { progress: 1000, repeatable: true })),
21801
22053
  index.h("h5", null))));
21802
22054
  };
22055
+ const TaskCardRepeatableFinite = () => {
22056
+ return (index.h("div", { style: storyFrame },
22057
+ index.h("div", { style: resizable },
22058
+ index.h("h4", null, "One Action"),
22059
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 0, repeatable: true, finite: 2 })),
22060
+ " ",
22061
+ index.h("h5", null),
22062
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 1, repeatable: true, finite: 2 })),
22063
+ " ",
22064
+ index.h("h5", null),
22065
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 2, repeatable: true, finite: 2 })),
22066
+ " ",
22067
+ index.h("h5", null)),
22068
+ index.h("div", { style: resizable },
22069
+ index.h("h4", null, "A Couple Actions"),
22070
+ index.h("h5", null)),
22071
+ index.h("div", { style: resizable },
22072
+ index.h("h4", null, "Many Actions"),
22073
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 100, repeatable: true, finite: 2 })),
22074
+ index.h("h5", null),
22075
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 500, repeatable: true, finite: 2 })),
22076
+ index.h("h5", null),
22077
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 650, repeatable: true, finite: 2 })),
22078
+ index.h("h5", null),
22079
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 950, repeatable: true, finite: 2 })),
22080
+ index.h("h5", null),
22081
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 1000, repeatable: true, finite: 2 })),
22082
+ index.h("h5", null),
22083
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 1300, repeatable: true, finite: 3 })),
22084
+ index.h("h5", null),
22085
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 1500, repeatable: true, finite: 3 })),
22086
+ index.h("h5", null),
22087
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 2500, repeatable: true, finite: 3 })),
22088
+ index.h("h5", null),
22089
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 2500, repeatable: true, finite: 4 })),
22090
+ index.h("h5", null),
22091
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 2500, repeatable: true, finite: 5 })),
22092
+ index.h("h5", null))));
22093
+ };
21803
22094
  const TaskCardEndDate = () => {
21804
22095
  const expire = {
21805
22096
  showExpiry: true,
21806
- rewardDuration: "2021-12-01T08:00:00.000Z/2077-12-01T08:00:00.000Z",
22097
+ rewardDuration: luxon.DateTime.now().minus({ days: 1 }).toISO() +
22098
+ "/" +
22099
+ luxon.DateTime.now().plus({ days: 1 }).toISO(),
21807
22100
  };
21808
22101
  const expireRepeat = { ...expire, repeatable: true };
21809
22102
  return (index.h("div", { style: storyFrame },
@@ -21860,10 +22153,60 @@ const TaskCardLoading = () => {
21860
22153
  " ",
21861
22154
  index.h("h5", null))));
21862
22155
  };
21863
- const TaskCardUnavailable = () => {
22156
+ const TaskCardNotStarted = () => {
21864
22157
  const expire = {
21865
22158
  showExpiry: true,
21866
- rewardDuration: "2021-11-30T08:00:00.000Z/2021-12-01T08:00:00.000Z",
22159
+ rewardDuration: luxon.DateTime.now().plus({ days: 1 }).toISO() +
22160
+ "/" +
22161
+ luxon.DateTime.now().plus({ days: 2 }).toISO(),
22162
+ };
22163
+ const expireRepeat = { ...expire, repeatable: true };
22164
+ return (index.h("div", { style: storyFrame },
22165
+ index.h("div", { style: resizable },
22166
+ index.h("h4", null, "One Action"),
22167
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 0 }, expire)),
22168
+ " ",
22169
+ index.h("h5", null),
22170
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 1 }, expire)),
22171
+ " ",
22172
+ index.h("h5", null),
22173
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 0 }, expireRepeat)),
22174
+ " ",
22175
+ index.h("h5", null),
22176
+ index.h(TaskCardView, Object.assign({}, oneAction, { progress: 1 }, expireRepeat)),
22177
+ " ",
22178
+ index.h("h5", null)),
22179
+ index.h("div", { style: resizable },
22180
+ index.h("h4", null, "A Couple Actions"),
22181
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 1 }, expire)),
22182
+ " ",
22183
+ index.h("h5", null),
22184
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 5 }, expire)),
22185
+ " ",
22186
+ index.h("h5", null),
22187
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 1 }, expireRepeat)),
22188
+ index.h("h5", null),
22189
+ index.h(TaskCardView, Object.assign({}, coupleActions, { progress: 5 }, expireRepeat)),
22190
+ index.h("h5", null)),
22191
+ index.h("div", { style: resizable },
22192
+ index.h("h4", null, "Many Actions"),
22193
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 100 }, expire)),
22194
+ " ",
22195
+ index.h("h5", null),
22196
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 500 }, expire)),
22197
+ " ",
22198
+ index.h("h5", null),
22199
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 100 }, expireRepeat)),
22200
+ index.h("h5", null),
22201
+ index.h(TaskCardView, Object.assign({}, manyActions, { progress: 500 }, expireRepeat)),
22202
+ index.h("h5", null))));
22203
+ };
22204
+ const TaskCardEnded = () => {
22205
+ const expire = {
22206
+ showExpiry: true,
22207
+ rewardDuration: luxon.DateTime.now().minus({ days: 2 }).toISO() +
22208
+ "/" +
22209
+ luxon.DateTime.now().minus({ days: 1 }).toISO(),
21867
22210
  };
21868
22211
  const expireRepeat = { ...expire, repeatable: true };
21869
22212
  return (index.h("div", { style: storyFrame },
@@ -21947,14 +22290,17 @@ const ProgressBarStepsRepeatable = () => {
21947
22290
  index.h(MatrixStory, { matrix: { progress: [1, 5, 7, 12] }, props: props, Component: ProgressBarView })));
21948
22291
  };
21949
22292
 
21950
- const TaskCard$1 = /*#__PURE__*/Object.freeze({
22293
+ const TaskCard$2 = /*#__PURE__*/Object.freeze({
21951
22294
  __proto__: null,
21952
22295
  'default': TaskCard_stories,
22296
+ TaskCard: TaskCard$1,
21953
22297
  TaskCardNotRepeatable: TaskCardNotRepeatable,
21954
22298
  TaskCardRepeatable: TaskCardRepeatable,
22299
+ TaskCardRepeatableFinite: TaskCardRepeatableFinite,
21955
22300
  TaskCardEndDate: TaskCardEndDate,
21956
22301
  TaskCardLoading: TaskCardLoading,
21957
- TaskCardUnavailable: TaskCardUnavailable,
22302
+ TaskCardNotStarted: TaskCardNotStarted,
22303
+ TaskCardEnded: TaskCardEnded,
21958
22304
  ProgressBar: ProgressBar$1,
21959
22305
  ProgressBarSteps: ProgressBarSteps,
21960
22306
  ProgressBarRepeatable: ProgressBarRepeatable,
@@ -25492,19 +25838,19 @@ const NameFields$1 = /*#__PURE__*/Object.freeze({
25492
25838
  NameFieldsWithErrors: NameFieldsWithErrors
25493
25839
  });
25494
25840
 
25495
- const baseResponse = (data, selected = null) => ({
25841
+ const baseResponse = (data, stage = "chooseReward", selectedItem = null, selectedStep = null, error = false, loading = false) => ({
25496
25842
  states: {
25497
25843
  content: {
25498
25844
  text: {
25499
25845
  notAvailableError: "{unavailableReason, select, US_TAX {US Tax limit} INSUFFICIENT_REDEEMABLE_CREDIT {Not enough points} other {Not available} }",
25500
25846
  },
25501
25847
  },
25502
- redeemStage: "chooseReward",
25848
+ redeemStage: stage,
25503
25849
  amount: 0,
25504
- exchangeError: false,
25505
- loading: false,
25506
- selectedItem: selected,
25507
- selectedStep: null,
25850
+ exchangeError: error,
25851
+ loading: loading,
25852
+ selectedItem: selectedItem,
25853
+ selectedStep: selectedStep,
25508
25854
  },
25509
25855
  data: {
25510
25856
  exchangeList: data,
@@ -25521,7 +25867,7 @@ const baseResponse = (data, selected = null) => ({
25521
25867
  const baseReward$2 = {
25522
25868
  key: "",
25523
25869
  name: "",
25524
- description: "",
25870
+ description: "Description of reward. Lorem ipsum dolor sit amet, consectetur adipiscing. Id nec semper sapien dignissim rhoncus nunc.",
25525
25871
  imageUrl: "",
25526
25872
  available: true,
25527
25873
  unavailableReason: null,
@@ -25556,8 +25902,8 @@ const selected = {
25556
25902
  const imageUrl = (props) => ({
25557
25903
  imageUrl: props,
25558
25904
  });
25559
- const description = (props) => ({
25560
- description: props,
25905
+ const name = (props) => ({
25906
+ name: props,
25561
25907
  });
25562
25908
  const fixedValue = (props) => ({
25563
25909
  prettySourceValue: props,
@@ -25572,54 +25918,54 @@ const variableValue = (min, max, text) => ({
25572
25918
  const data = [
25573
25919
  {
25574
25920
  ...baseReward$2,
25575
- ...description("Free swag with a promo code"),
25576
- ...imageUrl("https://i.imgur.com/Ds7M19I.png"),
25921
+ ...name("Free swag with a promo code"),
25922
+ ...imageUrl("https://i.imgur.com/n7vC4BR.png"),
25577
25923
  ...fixedValue("40 SaaSquatch Points"),
25578
25924
  },
25579
25925
  {
25580
25926
  ...baseReward$2,
25581
25927
  ...selected,
25582
- ...description("Visa® Prepaid Card USD"),
25583
- ...imageUrl("https://i.imgur.com/4s3q2zz.png"),
25928
+ ...name("Visa® Prepaid Card USD"),
25929
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25584
25930
  ...variableValue(20, 80, "SaaSquatch Points"),
25585
25931
  },
25586
25932
  {
25587
25933
  ...baseReward$2,
25588
- ...description("A very exclusive gift box"),
25589
- ...imageUrl("https://i.imgur.com/XuiJi4l.png"),
25934
+ ...name("A very exclusive gift box"),
25935
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
25590
25936
  ...fixedValue("30 SaaSquatch Points"),
25591
25937
  },
25592
25938
  {
25593
25939
  ...baseReward$2,
25594
- ...description("$50 Store credit"),
25940
+ ...name("$50 Store credit"),
25595
25941
  ...imageUrl("https://i.imgur.com/WkCMVSE.png"),
25596
25942
  ...fixedValue("100 SaaSquatch Points"),
25597
25943
  },
25598
25944
  {
25599
25945
  ...baseReward$2,
25600
- ...description("Variable amount of store credit"),
25946
+ ...name("Variable amount of store credit"),
25601
25947
  ...imageUrl("https://i.imgur.com/Jn2fE0s.png"),
25602
25948
  ...variableValue(20, 100, "SaaSquatch Points"),
25603
25949
  },
25604
25950
  {
25605
25951
  ...baseReward$2,
25606
25952
  ...notEnoughPoints,
25607
- ...description("A very rare cactus"),
25608
- ...imageUrl("https://i.imgur.com/CvCdpXc.png"),
25953
+ ...name("A very rare cactus"),
25954
+ ...imageUrl("https://i.imgur.com/hhlF2Ey.png"),
25609
25955
  ...fixedValue("2000 SaaSquatch Points"),
25610
25956
  },
25611
25957
  {
25612
25958
  ...baseReward$2,
25613
25959
  ...usTax,
25614
- ...description("$1000 Store credit"),
25615
- ...imageUrl("https://i.imgur.com/I9FCh9Z.png"),
25960
+ ...name("$1000 Store credit"),
25961
+ ...imageUrl("https://i.imgur.com/y9HSls1.png"),
25616
25962
  ...fixedValue("2000 SaaSquatch Points"),
25617
25963
  },
25618
25964
  {
25619
25965
  ...baseReward$2,
25620
25966
  ...notEnoughPoints,
25621
- ...description("A holiday gift box"),
25622
- ...imageUrl("https://i.imgur.com/HBJS1WH.png"),
25967
+ ...name("A holiday gift box"),
25968
+ ...imageUrl("https://i.imgur.com/dWEdB3p.png"),
25623
25969
  ...fixedValue("100 SaaSquatch Points"),
25624
25970
  },
25625
25971
  ];
@@ -25627,142 +25973,3409 @@ const rewardExchange = {
25627
25973
  ...baseResponse(data),
25628
25974
  };
25629
25975
  const rewardExchangeSelected = {
25630
- ...baseResponse(data, {
25976
+ ...baseResponse(data, "chooseReward", {
25631
25977
  ...baseReward$2,
25632
25978
  ...selected,
25633
- ...description("Visa® Prepaid Card USD"),
25634
- ...imageUrl("https://i.imgur.com/4s3q2zz.png"),
25979
+ ...name("Visa® Prepaid Card USD"),
25980
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25635
25981
  ...variableValue(20, 80, "SaaSquatch Points"),
25636
25982
  }),
25637
25983
  };
25638
- const test2 = {
25639
- states: {
25640
- content: {
25641
- text: {
25642
- buttonText: "Exchange Rewards",
25643
- ignored: true,
25644
- },
25645
- },
25646
- redeemStage: "chooseAmount",
25647
- amount: 0,
25648
- exchangeError: false,
25649
- loading: false,
25650
- selectedItem: {
25651
- key: "r4",
25652
- name: "Salmon Coins",
25653
- description: "Points for Salmon Coins",
25654
- 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",
25655
- available: true,
25656
- unavailableReason: null,
25657
- unavailableReasonCode: null,
25658
- ruleType: "VARIABLE_CREDIT_REWARD",
25659
- sourceUnit: "POINT",
25660
- sourceValue: null,
25661
- prettySourceValue: null,
25662
- sourceMinValue: 1,
25663
- prettySourceMinValue: "1 Point",
25664
- sourceMaxValue: 100,
25665
- prettySourceMaxValue: "100 Points",
25666
- destinationMinValue: 1,
25667
- prettyDestinationMinValue: "1 Salmon Coin",
25668
- destinationMaxValue: 100,
25669
- prettyDestinationMaxValue: "100 Salmons",
25670
- globalRewardKey: null,
25671
- destinationUnit: "TESTUNIT",
25672
- steps: [
25673
- {
25674
- sourceValue: 1,
25675
- prettySourceValue: "1 Point",
25676
- destinationValue: 1,
25677
- prettyDestinationValue: "1 Salmon Coin",
25678
- available: true,
25679
- unavailableReasonCode: null,
25680
- unavailableReason: "",
25681
- },
25682
- {
25683
- sourceValue: 2,
25684
- prettySourceValue: "2 Points",
25685
- destinationValue: 2,
25686
- prettyDestinationValue: "2 Salmons",
25687
- available: true,
25688
- unavailableReasonCode: null,
25689
- unavailableReason: "",
25690
- },
25691
- {
25692
- sourceValue: 3,
25693
- prettySourceValue: "3 Points",
25694
- destinationValue: 3,
25695
- prettyDestinationValue: "3 Salmons",
25696
- available: true,
25697
- unavailableReasonCode: null,
25698
- unavailableReason: "",
25699
- },
25700
- {
25701
- sourceValue: 4,
25702
- prettySourceValue: "4 Points",
25703
- destinationValue: 4,
25704
- prettyDestinationValue: "4 Salmons",
25705
- available: true,
25706
- unavailableReasonCode: null,
25707
- unavailableReason: "",
25708
- },
25709
- {
25710
- sourceValue: 5,
25711
- prettySourceValue: "5 Points",
25712
- destinationValue: 5,
25713
- prettyDestinationValue: "5 Salmons",
25714
- available: true,
25715
- unavailableReasonCode: null,
25716
- unavailableReason: "",
25717
- },
25718
- ],
25719
- },
25720
- selectedStep: null,
25721
- },
25722
- data: {
25723
- exchangeList: null,
25724
- },
25725
- callbacks: {
25726
- exchangeReward: null,
25727
- resetState: null,
25728
- setStage: null,
25729
- setExchangeState: null,
25730
- refs: {
25731
- drawerRef: {},
25732
- },
25733
- },
25734
- refs: null,
25984
+ const baseStep = (dst, dstUnit, src, srcUnit, available = true) => ({
25985
+ destinationValue: dst,
25986
+ prettyDestinationValue: dstUnit + dst,
25987
+ sourceValue: src,
25988
+ prettySourceValue: src + " " + srcUnit,
25989
+ available: available,
25990
+ unavailableReasonCode: null,
25991
+ unavailableReason: "",
25992
+ });
25993
+ const chooseAmountVariable = {
25994
+ ...baseResponse(data, "chooseAmount", {
25995
+ ...baseReward$2,
25996
+ ...name("Visa® Prepaid Card USD"),
25997
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
25998
+ ...variableValue(20, 80, "SaaSquatch Points"),
25999
+ steps: [
26000
+ baseStep(20, "$", 40, "SaaSquatch Points"),
26001
+ baseStep(30, "$", 60, "SaaSquatch Points"),
26002
+ baseStep(40, "$", 80, "SaaSquatch Points"),
26003
+ baseStep(50, "$", 100, "SaaSquatch Points"),
26004
+ baseStep(60, "$", 120, "SaaSquatch Points"),
26005
+ ],
26006
+ }),
26007
+ };
26008
+ const chooseAmountFixed = {
26009
+ ...baseResponse(data, "chooseAmount", {
26010
+ ...baseReward$2,
26011
+ ...name("Free swag with a promo code"),
26012
+ ...imageUrl("https://i.imgur.com/n7vC4BR.png"),
26013
+ ...fixedValue("40 SaaSquatch Points"),
26014
+ }),
26015
+ };
26016
+ const confirmFixed = {
26017
+ ...baseResponse(data, "confirmation", {
26018
+ ...baseReward$2,
26019
+ ...name("A very exclusive gift box"),
26020
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
26021
+ ...fixedValue("30 SaaSquatch Points"),
26022
+ }),
26023
+ };
26024
+ const confirmVariable = {
26025
+ ...baseResponse(data, "confirmation", {
26026
+ ...baseReward$2,
26027
+ ...name("Visa® Prepaid Card USD"),
26028
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
26029
+ ...variableValue(20, 80, "SaaSquatch Points"),
26030
+ }, baseStep(20, "$", 40, "SaaSquatch Points")),
26031
+ };
26032
+ const error$1 = {
26033
+ ...baseResponse(data, "confirmation", {
26034
+ ...baseReward$2,
26035
+ ...name("Visa® Prepaid Card USD"),
26036
+ ...imageUrl("https://i.imgur.com/veHErQX.png"),
26037
+ ...variableValue(20, 80, "SaaSquatch Points"),
26038
+ }, baseStep(20, "$", 40, "SaaSquatch Points"), true),
26039
+ };
26040
+ const success = {
26041
+ ...baseResponse(data, "success", {
26042
+ ...baseReward$2,
26043
+ ...name("A very exclusive gift box"),
26044
+ ...imageUrl("https://i.imgur.com/93BvEgH.png"),
26045
+ ...fixedValue("30 SaaSquatch Points"),
26046
+ }),
26047
+ };
26048
+ const loading = {
26049
+ ...baseResponse(null, "chooseReward", null, null, false, true),
25735
26050
  };
25736
26051
 
25737
- const RewardExchangeList_stories = {
25738
- title: "Components/Reward Exchange List",
25739
- };
25740
- const resizable$1 = {
25741
- width: "683px",
25742
- minWidth: "260px",
25743
- resize: "horizontal",
25744
- height: "fit-content",
25745
- overflow: "hidden",
25746
- };
25747
- const rewardExchange$1 = () => {
25748
- return (index.h("div", { style: resizable$1 },
25749
- index.h(RewardExchangeView, Object.assign({}, rewardExchange))));
25750
- };
25751
- const rewardExchangeSelected$1 = () => {
25752
- return (index.h("div", { style: resizable$1 },
25753
- index.h(RewardExchangeView, Object.assign({}, rewardExchangeSelected))));
25754
- };
25755
- const Default2 = () => {
25756
- return (index.h("div", { style: { ...resizable$1, height: "700px" } },
25757
- index.h(RewardExchangeView, Object.assign({}, test2))));
25758
- };
26052
+ const RewardExchangeList_stories = {
26053
+ title: "Components/Reward Exchange List",
26054
+ };
26055
+ const StoryBase = (props) => () => {
26056
+ return index.h(Resizer, null,
26057
+ index.h(RewardExchangeView, Object.assign({}, props)));
26058
+ };
26059
+ const ChooseReward = StoryBase(rewardExchange);
26060
+ const ChooseRewardSelected = StoryBase(rewardExchangeSelected);
26061
+ const ChooseAmount = StoryBase(chooseAmountFixed);
26062
+ const ChooseAmountVariable = StoryBase(chooseAmountVariable);
26063
+ const Confirm = StoryBase(confirmFixed);
26064
+ const ConfirmVariable = StoryBase(confirmVariable);
26065
+ const Error$3 = StoryBase(error$1);
26066
+ const Success$2 = StoryBase(success);
26067
+ const Loading$3 = StoryBase(loading);
26068
+
26069
+ const RewardExchangeList = /*#__PURE__*/Object.freeze({
26070
+ __proto__: null,
26071
+ 'default': RewardExchangeList_stories,
26072
+ ChooseReward: ChooseReward,
26073
+ ChooseRewardSelected: ChooseRewardSelected,
26074
+ ChooseAmount: ChooseAmount,
26075
+ ChooseAmountVariable: ChooseAmountVariable,
26076
+ Confirm: Confirm,
26077
+ ConfirmVariable: ConfirmVariable,
26078
+ Error: Error$3,
26079
+ Success: Success$2,
26080
+ Loading: Loading$3
26081
+ });
26082
+
26083
+ var chroma = _extends.createCommonjsModule(function (module, exports) {
26084
+ /**
26085
+ * chroma.js - JavaScript library for color conversions
26086
+ *
26087
+ * Copyright (c) 2011-2019, Gregor Aisch
26088
+ * All rights reserved.
26089
+ *
26090
+ * Redistribution and use in source and binary forms, with or without
26091
+ * modification, are permitted provided that the following conditions are met:
26092
+ *
26093
+ * 1. Redistributions of source code must retain the above copyright notice, this
26094
+ * list of conditions and the following disclaimer.
26095
+ *
26096
+ * 2. Redistributions in binary form must reproduce the above copyright notice,
26097
+ * this list of conditions and the following disclaimer in the documentation
26098
+ * and/or other materials provided with the distribution.
26099
+ *
26100
+ * 3. The name Gregor Aisch may not be used to endorse or promote products
26101
+ * derived from this software without specific prior written permission.
26102
+ *
26103
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
26104
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26105
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
26106
+ * DISCLAIMED. IN NO EVENT SHALL GREGOR AISCH OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
26107
+ * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
26108
+ * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26109
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
26110
+ * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26111
+ * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
26112
+ * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26113
+ *
26114
+ * -------------------------------------------------------
26115
+ *
26116
+ * chroma.js includes colors from colorbrewer2.org, which are released under
26117
+ * the following license:
26118
+ *
26119
+ * Copyright (c) 2002 Cynthia Brewer, Mark Harrower,
26120
+ * and The Pennsylvania State University.
26121
+ *
26122
+ * Licensed under the Apache License, Version 2.0 (the "License");
26123
+ * you may not use this file except in compliance with the License.
26124
+ * You may obtain a copy of the License at
26125
+ * http://www.apache.org/licenses/LICENSE-2.0
26126
+ *
26127
+ * Unless required by applicable law or agreed to in writing,
26128
+ * software distributed under the License is distributed on an
26129
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
26130
+ * either express or implied. See the License for the specific
26131
+ * language governing permissions and limitations under the License.
26132
+ *
26133
+ * ------------------------------------------------------
26134
+ *
26135
+ * Named colors are taken from X11 Color Names.
26136
+ * http://www.w3.org/TR/css3-color/#svg-color
26137
+ *
26138
+ * @preserve
26139
+ */
26140
+
26141
+ (function (global, factory) {
26142
+ module.exports = factory() ;
26143
+ }(_extends.commonjsGlobal, (function () {
26144
+ var limit = function (x, min, max) {
26145
+ if ( min === void 0 ) min=0;
26146
+ if ( max === void 0 ) max=1;
26147
+
26148
+ return x < min ? min : x > max ? max : x;
26149
+ };
26150
+
26151
+ var clip_rgb = function (rgb) {
26152
+ rgb._clipped = false;
26153
+ rgb._unclipped = rgb.slice(0);
26154
+ for (var i=0; i<=3; i++) {
26155
+ if (i < 3) {
26156
+ if (rgb[i] < 0 || rgb[i] > 255) { rgb._clipped = true; }
26157
+ rgb[i] = limit(rgb[i], 0, 255);
26158
+ } else if (i === 3) {
26159
+ rgb[i] = limit(rgb[i], 0, 1);
26160
+ }
26161
+ }
26162
+ return rgb;
26163
+ };
26164
+
26165
+ // ported from jQuery's $.type
26166
+ var classToType = {};
26167
+ for (var i = 0, list = ['Boolean', 'Number', 'String', 'Function', 'Array', 'Date', 'RegExp', 'Undefined', 'Null']; i < list.length; i += 1) {
26168
+ var name = list[i];
26169
+
26170
+ classToType[("[object " + name + "]")] = name.toLowerCase();
26171
+ }
26172
+ var type = function(obj) {
26173
+ return classToType[Object.prototype.toString.call(obj)] || "object";
26174
+ };
26175
+
26176
+ var unpack = function (args, keyOrder) {
26177
+ if ( keyOrder === void 0 ) keyOrder=null;
26178
+
26179
+ // if called with more than 3 arguments, we return the arguments
26180
+ if (args.length >= 3) { return Array.prototype.slice.call(args); }
26181
+ // with less than 3 args we check if first arg is object
26182
+ // and use the keyOrder string to extract and sort properties
26183
+ if (type(args[0]) == 'object' && keyOrder) {
26184
+ return keyOrder.split('')
26185
+ .filter(function (k) { return args[0][k] !== undefined; })
26186
+ .map(function (k) { return args[0][k]; });
26187
+ }
26188
+ // otherwise we just return the first argument
26189
+ // (which we suppose is an array of args)
26190
+ return args[0];
26191
+ };
26192
+
26193
+ var last = function (args) {
26194
+ if (args.length < 2) { return null; }
26195
+ var l = args.length-1;
26196
+ if (type(args[l]) == 'string') { return args[l].toLowerCase(); }
26197
+ return null;
26198
+ };
26199
+
26200
+ var PI = Math.PI;
26201
+
26202
+ var utils = {
26203
+ clip_rgb: clip_rgb,
26204
+ limit: limit,
26205
+ type: type,
26206
+ unpack: unpack,
26207
+ last: last,
26208
+ PI: PI,
26209
+ TWOPI: PI*2,
26210
+ PITHIRD: PI/3,
26211
+ DEG2RAD: PI / 180,
26212
+ RAD2DEG: 180 / PI
26213
+ };
26214
+
26215
+ var input = {
26216
+ format: {},
26217
+ autodetect: []
26218
+ };
26219
+
26220
+ var last$1 = utils.last;
26221
+ var clip_rgb$1 = utils.clip_rgb;
26222
+ var type$1 = utils.type;
26223
+
26224
+
26225
+ var Color = function Color() {
26226
+ var args = [], len = arguments.length;
26227
+ while ( len-- ) args[ len ] = arguments[ len ];
26228
+
26229
+ var me = this;
26230
+ if (type$1(args[0]) === 'object' &&
26231
+ args[0].constructor &&
26232
+ args[0].constructor === this.constructor) {
26233
+ // the argument is already a Color instance
26234
+ return args[0];
26235
+ }
26236
+
26237
+ // last argument could be the mode
26238
+ var mode = last$1(args);
26239
+ var autodetect = false;
26240
+
26241
+ if (!mode) {
26242
+ autodetect = true;
26243
+ if (!input.sorted) {
26244
+ input.autodetect = input.autodetect.sort(function (a,b) { return b.p - a.p; });
26245
+ input.sorted = true;
26246
+ }
26247
+ // auto-detect format
26248
+ for (var i = 0, list = input.autodetect; i < list.length; i += 1) {
26249
+ var chk = list[i];
26250
+
26251
+ mode = chk.test.apply(chk, args);
26252
+ if (mode) { break; }
26253
+ }
26254
+ }
26255
+
26256
+ if (input.format[mode]) {
26257
+ var rgb = input.format[mode].apply(null, autodetect ? args : args.slice(0,-1));
26258
+ me._rgb = clip_rgb$1(rgb);
26259
+ } else {
26260
+ throw new Error('unknown format: '+args);
26261
+ }
26262
+
26263
+ // add alpha channel
26264
+ if (me._rgb.length === 3) { me._rgb.push(1); }
26265
+ };
26266
+
26267
+ Color.prototype.toString = function toString () {
26268
+ if (type$1(this.hex) == 'function') { return this.hex(); }
26269
+ return ("[" + (this._rgb.join(',')) + "]");
26270
+ };
26271
+
26272
+ var Color_1 = Color;
26273
+
26274
+ var chroma = function () {
26275
+ var args = [], len = arguments.length;
26276
+ while ( len-- ) args[ len ] = arguments[ len ];
26277
+
26278
+ return new (Function.prototype.bind.apply( chroma.Color, [ null ].concat( args) ));
26279
+ };
26280
+
26281
+ chroma.Color = Color_1;
26282
+ chroma.version = '2.1.2';
26283
+
26284
+ var chroma_1 = chroma;
26285
+
26286
+ var unpack$1 = utils.unpack;
26287
+ var max = Math.max;
26288
+
26289
+ var rgb2cmyk = function () {
26290
+ var args = [], len = arguments.length;
26291
+ while ( len-- ) args[ len ] = arguments[ len ];
26292
+
26293
+ var ref = unpack$1(args, 'rgb');
26294
+ var r = ref[0];
26295
+ var g = ref[1];
26296
+ var b = ref[2];
26297
+ r = r / 255;
26298
+ g = g / 255;
26299
+ b = b / 255;
26300
+ var k = 1 - max(r,max(g,b));
26301
+ var f = k < 1 ? 1 / (1-k) : 0;
26302
+ var c = (1-r-k) * f;
26303
+ var m = (1-g-k) * f;
26304
+ var y = (1-b-k) * f;
26305
+ return [c,m,y,k];
26306
+ };
26307
+
26308
+ var rgb2cmyk_1 = rgb2cmyk;
26309
+
26310
+ var unpack$2 = utils.unpack;
26311
+
26312
+ var cmyk2rgb = function () {
26313
+ var args = [], len = arguments.length;
26314
+ while ( len-- ) args[ len ] = arguments[ len ];
26315
+
26316
+ args = unpack$2(args, 'cmyk');
26317
+ var c = args[0];
26318
+ var m = args[1];
26319
+ var y = args[2];
26320
+ var k = args[3];
26321
+ var alpha = args.length > 4 ? args[4] : 1;
26322
+ if (k === 1) { return [0,0,0,alpha]; }
26323
+ return [
26324
+ c >= 1 ? 0 : 255 * (1-c) * (1-k), // r
26325
+ m >= 1 ? 0 : 255 * (1-m) * (1-k), // g
26326
+ y >= 1 ? 0 : 255 * (1-y) * (1-k), // b
26327
+ alpha
26328
+ ];
26329
+ };
26330
+
26331
+ var cmyk2rgb_1 = cmyk2rgb;
26332
+
26333
+ var unpack$3 = utils.unpack;
26334
+ var type$2 = utils.type;
26335
+
26336
+
26337
+
26338
+ Color_1.prototype.cmyk = function() {
26339
+ return rgb2cmyk_1(this._rgb);
26340
+ };
26341
+
26342
+ chroma_1.cmyk = function () {
26343
+ var args = [], len = arguments.length;
26344
+ while ( len-- ) args[ len ] = arguments[ len ];
26345
+
26346
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['cmyk']) ));
26347
+ };
26348
+
26349
+ input.format.cmyk = cmyk2rgb_1;
26350
+
26351
+ input.autodetect.push({
26352
+ p: 2,
26353
+ test: function () {
26354
+ var args = [], len = arguments.length;
26355
+ while ( len-- ) args[ len ] = arguments[ len ];
26356
+
26357
+ args = unpack$3(args, 'cmyk');
26358
+ if (type$2(args) === 'array' && args.length === 4) {
26359
+ return 'cmyk';
26360
+ }
26361
+ }
26362
+ });
26363
+
26364
+ var unpack$4 = utils.unpack;
26365
+ var last$2 = utils.last;
26366
+ var rnd = function (a) { return Math.round(a*100)/100; };
26367
+
26368
+ /*
26369
+ * supported arguments:
26370
+ * - hsl2css(h,s,l)
26371
+ * - hsl2css(h,s,l,a)
26372
+ * - hsl2css([h,s,l], mode)
26373
+ * - hsl2css([h,s,l,a], mode)
26374
+ * - hsl2css({h,s,l,a}, mode)
26375
+ */
26376
+ var hsl2css = function () {
26377
+ var args = [], len = arguments.length;
26378
+ while ( len-- ) args[ len ] = arguments[ len ];
26379
+
26380
+ var hsla = unpack$4(args, 'hsla');
26381
+ var mode = last$2(args) || 'lsa';
26382
+ hsla[0] = rnd(hsla[0] || 0);
26383
+ hsla[1] = rnd(hsla[1]*100) + '%';
26384
+ hsla[2] = rnd(hsla[2]*100) + '%';
26385
+ if (mode === 'hsla' || (hsla.length > 3 && hsla[3]<1)) {
26386
+ hsla[3] = hsla.length > 3 ? hsla[3] : 1;
26387
+ mode = 'hsla';
26388
+ } else {
26389
+ hsla.length = 3;
26390
+ }
26391
+ return (mode + "(" + (hsla.join(',')) + ")");
26392
+ };
26393
+
26394
+ var hsl2css_1 = hsl2css;
26395
+
26396
+ var unpack$5 = utils.unpack;
26397
+
26398
+ /*
26399
+ * supported arguments:
26400
+ * - rgb2hsl(r,g,b)
26401
+ * - rgb2hsl(r,g,b,a)
26402
+ * - rgb2hsl([r,g,b])
26403
+ * - rgb2hsl([r,g,b,a])
26404
+ * - rgb2hsl({r,g,b,a})
26405
+ */
26406
+ var rgb2hsl = function () {
26407
+ var args = [], len = arguments.length;
26408
+ while ( len-- ) args[ len ] = arguments[ len ];
26409
+
26410
+ args = unpack$5(args, 'rgba');
26411
+ var r = args[0];
26412
+ var g = args[1];
26413
+ var b = args[2];
26414
+
26415
+ r /= 255;
26416
+ g /= 255;
26417
+ b /= 255;
26418
+
26419
+ var min = Math.min(r, g, b);
26420
+ var max = Math.max(r, g, b);
26421
+
26422
+ var l = (max + min) / 2;
26423
+ var s, h;
26424
+
26425
+ if (max === min){
26426
+ s = 0;
26427
+ h = Number.NaN;
26428
+ } else {
26429
+ s = l < 0.5 ? (max - min) / (max + min) : (max - min) / (2 - max - min);
26430
+ }
26431
+
26432
+ if (r == max) { h = (g - b) / (max - min); }
26433
+ else if (g == max) { h = 2 + (b - r) / (max - min); }
26434
+ else if (b == max) { h = 4 + (r - g) / (max - min); }
26435
+
26436
+ h *= 60;
26437
+ if (h < 0) { h += 360; }
26438
+ if (args.length>3 && args[3]!==undefined) { return [h,s,l,args[3]]; }
26439
+ return [h,s,l];
26440
+ };
26441
+
26442
+ var rgb2hsl_1 = rgb2hsl;
26443
+
26444
+ var unpack$6 = utils.unpack;
26445
+ var last$3 = utils.last;
26446
+
26447
+
26448
+ var round = Math.round;
26449
+
26450
+ /*
26451
+ * supported arguments:
26452
+ * - rgb2css(r,g,b)
26453
+ * - rgb2css(r,g,b,a)
26454
+ * - rgb2css([r,g,b], mode)
26455
+ * - rgb2css([r,g,b,a], mode)
26456
+ * - rgb2css({r,g,b,a}, mode)
26457
+ */
26458
+ var rgb2css = function () {
26459
+ var args = [], len = arguments.length;
26460
+ while ( len-- ) args[ len ] = arguments[ len ];
26461
+
26462
+ var rgba = unpack$6(args, 'rgba');
26463
+ var mode = last$3(args) || 'rgb';
26464
+ if (mode.substr(0,3) == 'hsl') {
26465
+ return hsl2css_1(rgb2hsl_1(rgba), mode);
26466
+ }
26467
+ rgba[0] = round(rgba[0]);
26468
+ rgba[1] = round(rgba[1]);
26469
+ rgba[2] = round(rgba[2]);
26470
+ if (mode === 'rgba' || (rgba.length > 3 && rgba[3]<1)) {
26471
+ rgba[3] = rgba.length > 3 ? rgba[3] : 1;
26472
+ mode = 'rgba';
26473
+ }
26474
+ return (mode + "(" + (rgba.slice(0,mode==='rgb'?3:4).join(',')) + ")");
26475
+ };
26476
+
26477
+ var rgb2css_1 = rgb2css;
26478
+
26479
+ var unpack$7 = utils.unpack;
26480
+ var round$1 = Math.round;
26481
+
26482
+ var hsl2rgb = function () {
26483
+ var assign;
26484
+
26485
+ var args = [], len = arguments.length;
26486
+ while ( len-- ) args[ len ] = arguments[ len ];
26487
+ args = unpack$7(args, 'hsl');
26488
+ var h = args[0];
26489
+ var s = args[1];
26490
+ var l = args[2];
26491
+ var r,g,b;
26492
+ if (s === 0) {
26493
+ r = g = b = l*255;
26494
+ } else {
26495
+ var t3 = [0,0,0];
26496
+ var c = [0,0,0];
26497
+ var t2 = l < 0.5 ? l * (1+s) : l+s-l*s;
26498
+ var t1 = 2 * l - t2;
26499
+ var h_ = h / 360;
26500
+ t3[0] = h_ + 1/3;
26501
+ t3[1] = h_;
26502
+ t3[2] = h_ - 1/3;
26503
+ for (var i=0; i<3; i++) {
26504
+ if (t3[i] < 0) { t3[i] += 1; }
26505
+ if (t3[i] > 1) { t3[i] -= 1; }
26506
+ if (6 * t3[i] < 1)
26507
+ { c[i] = t1 + (t2 - t1) * 6 * t3[i]; }
26508
+ else if (2 * t3[i] < 1)
26509
+ { c[i] = t2; }
26510
+ else if (3 * t3[i] < 2)
26511
+ { c[i] = t1 + (t2 - t1) * ((2 / 3) - t3[i]) * 6; }
26512
+ else
26513
+ { c[i] = t1; }
26514
+ }
26515
+ (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]);
26516
+ }
26517
+ if (args.length > 3) {
26518
+ // keep alpha channel
26519
+ return [r,g,b,args[3]];
26520
+ }
26521
+ return [r,g,b,1];
26522
+ };
26523
+
26524
+ var hsl2rgb_1 = hsl2rgb;
26525
+
26526
+ var RE_RGB = /^rgb\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*\)$/;
26527
+ var RE_RGBA = /^rgba\(\s*(-?\d+),\s*(-?\d+)\s*,\s*(-?\d+)\s*,\s*([01]|[01]?\.\d+)\)$/;
26528
+ var RE_RGB_PCT = /^rgb\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/;
26529
+ var RE_RGBA_PCT = /^rgba\(\s*(-?\d+(?:\.\d+)?)%,\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/;
26530
+ var RE_HSL = /^hsl\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*\)$/;
26531
+ var RE_HSLA = /^hsla\(\s*(-?\d+(?:\.\d+)?),\s*(-?\d+(?:\.\d+)?)%\s*,\s*(-?\d+(?:\.\d+)?)%\s*,\s*([01]|[01]?\.\d+)\)$/;
26532
+
26533
+ var round$2 = Math.round;
26534
+
26535
+ var css2rgb = function (css) {
26536
+ css = css.toLowerCase().trim();
26537
+ var m;
26538
+
26539
+ if (input.format.named) {
26540
+ try {
26541
+ return input.format.named(css);
26542
+ } catch (e) {
26543
+ // eslint-disable-next-line
26544
+ }
26545
+ }
26546
+
26547
+ // rgb(250,20,0)
26548
+ if ((m = css.match(RE_RGB))) {
26549
+ var rgb = m.slice(1,4);
26550
+ for (var i=0; i<3; i++) {
26551
+ rgb[i] = +rgb[i];
26552
+ }
26553
+ rgb[3] = 1; // default alpha
26554
+ return rgb;
26555
+ }
26556
+
26557
+ // rgba(250,20,0,0.4)
26558
+ if ((m = css.match(RE_RGBA))) {
26559
+ var rgb$1 = m.slice(1,5);
26560
+ for (var i$1=0; i$1<4; i$1++) {
26561
+ rgb$1[i$1] = +rgb$1[i$1];
26562
+ }
26563
+ return rgb$1;
26564
+ }
26565
+
26566
+ // rgb(100%,0%,0%)
26567
+ if ((m = css.match(RE_RGB_PCT))) {
26568
+ var rgb$2 = m.slice(1,4);
26569
+ for (var i$2=0; i$2<3; i$2++) {
26570
+ rgb$2[i$2] = round$2(rgb$2[i$2] * 2.55);
26571
+ }
26572
+ rgb$2[3] = 1; // default alpha
26573
+ return rgb$2;
26574
+ }
26575
+
26576
+ // rgba(100%,0%,0%,0.4)
26577
+ if ((m = css.match(RE_RGBA_PCT))) {
26578
+ var rgb$3 = m.slice(1,5);
26579
+ for (var i$3=0; i$3<3; i$3++) {
26580
+ rgb$3[i$3] = round$2(rgb$3[i$3] * 2.55);
26581
+ }
26582
+ rgb$3[3] = +rgb$3[3];
26583
+ return rgb$3;
26584
+ }
26585
+
26586
+ // hsl(0,100%,50%)
26587
+ if ((m = css.match(RE_HSL))) {
26588
+ var hsl = m.slice(1,4);
26589
+ hsl[1] *= 0.01;
26590
+ hsl[2] *= 0.01;
26591
+ var rgb$4 = hsl2rgb_1(hsl);
26592
+ rgb$4[3] = 1;
26593
+ return rgb$4;
26594
+ }
26595
+
26596
+ // hsla(0,100%,50%,0.5)
26597
+ if ((m = css.match(RE_HSLA))) {
26598
+ var hsl$1 = m.slice(1,4);
26599
+ hsl$1[1] *= 0.01;
26600
+ hsl$1[2] *= 0.01;
26601
+ var rgb$5 = hsl2rgb_1(hsl$1);
26602
+ rgb$5[3] = +m[4]; // default alpha = 1
26603
+ return rgb$5;
26604
+ }
26605
+ };
26606
+
26607
+ css2rgb.test = function (s) {
26608
+ return RE_RGB.test(s) ||
26609
+ RE_RGBA.test(s) ||
26610
+ RE_RGB_PCT.test(s) ||
26611
+ RE_RGBA_PCT.test(s) ||
26612
+ RE_HSL.test(s) ||
26613
+ RE_HSLA.test(s);
26614
+ };
26615
+
26616
+ var css2rgb_1 = css2rgb;
26617
+
26618
+ var type$3 = utils.type;
26619
+
26620
+
26621
+
26622
+
26623
+ Color_1.prototype.css = function(mode) {
26624
+ return rgb2css_1(this._rgb, mode);
26625
+ };
26626
+
26627
+ chroma_1.css = function () {
26628
+ var args = [], len = arguments.length;
26629
+ while ( len-- ) args[ len ] = arguments[ len ];
26630
+
26631
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['css']) ));
26632
+ };
26633
+
26634
+ input.format.css = css2rgb_1;
26635
+
26636
+ input.autodetect.push({
26637
+ p: 5,
26638
+ test: function (h) {
26639
+ var rest = [], len = arguments.length - 1;
26640
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
26641
+
26642
+ if (!rest.length && type$3(h) === 'string' && css2rgb_1.test(h)) {
26643
+ return 'css';
26644
+ }
26645
+ }
26646
+ });
26647
+
26648
+ var unpack$8 = utils.unpack;
26649
+
26650
+ input.format.gl = function () {
26651
+ var args = [], len = arguments.length;
26652
+ while ( len-- ) args[ len ] = arguments[ len ];
26653
+
26654
+ var rgb = unpack$8(args, 'rgba');
26655
+ rgb[0] *= 255;
26656
+ rgb[1] *= 255;
26657
+ rgb[2] *= 255;
26658
+ return rgb;
26659
+ };
26660
+
26661
+ chroma_1.gl = function () {
26662
+ var args = [], len = arguments.length;
26663
+ while ( len-- ) args[ len ] = arguments[ len ];
26664
+
26665
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['gl']) ));
26666
+ };
26667
+
26668
+ Color_1.prototype.gl = function() {
26669
+ var rgb = this._rgb;
26670
+ return [rgb[0]/255, rgb[1]/255, rgb[2]/255, rgb[3]];
26671
+ };
26672
+
26673
+ var unpack$9 = utils.unpack;
26674
+
26675
+ var rgb2hcg = function () {
26676
+ var args = [], len = arguments.length;
26677
+ while ( len-- ) args[ len ] = arguments[ len ];
26678
+
26679
+ var ref = unpack$9(args, 'rgb');
26680
+ var r = ref[0];
26681
+ var g = ref[1];
26682
+ var b = ref[2];
26683
+ var min = Math.min(r, g, b);
26684
+ var max = Math.max(r, g, b);
26685
+ var delta = max - min;
26686
+ var c = delta * 100 / 255;
26687
+ var _g = min / (255 - delta) * 100;
26688
+ var h;
26689
+ if (delta === 0) {
26690
+ h = Number.NaN;
26691
+ } else {
26692
+ if (r === max) { h = (g - b) / delta; }
26693
+ if (g === max) { h = 2+(b - r) / delta; }
26694
+ if (b === max) { h = 4+(r - g) / delta; }
26695
+ h *= 60;
26696
+ if (h < 0) { h += 360; }
26697
+ }
26698
+ return [h, c, _g];
26699
+ };
26700
+
26701
+ var rgb2hcg_1 = rgb2hcg;
26702
+
26703
+ var unpack$a = utils.unpack;
26704
+ var floor = Math.floor;
26705
+
26706
+ /*
26707
+ * this is basically just HSV with some minor tweaks
26708
+ *
26709
+ * hue.. [0..360]
26710
+ * chroma .. [0..1]
26711
+ * grayness .. [0..1]
26712
+ */
26713
+
26714
+ var hcg2rgb = function () {
26715
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
26716
+
26717
+ var args = [], len = arguments.length;
26718
+ while ( len-- ) args[ len ] = arguments[ len ];
26719
+ args = unpack$a(args, 'hcg');
26720
+ var h = args[0];
26721
+ var c = args[1];
26722
+ var _g = args[2];
26723
+ var r,g,b;
26724
+ _g = _g * 255;
26725
+ var _c = c * 255;
26726
+ if (c === 0) {
26727
+ r = g = b = _g;
26728
+ } else {
26729
+ if (h === 360) { h = 0; }
26730
+ if (h > 360) { h -= 360; }
26731
+ if (h < 0) { h += 360; }
26732
+ h /= 60;
26733
+ var i = floor(h);
26734
+ var f = h - i;
26735
+ var p = _g * (1 - c);
26736
+ var q = p + _c * (1 - f);
26737
+ var t = p + _c * f;
26738
+ var v = p + _c;
26739
+ switch (i) {
26740
+ case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break
26741
+ case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break
26742
+ case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break
26743
+ case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break
26744
+ case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break
26745
+ case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break
26746
+ }
26747
+ }
26748
+ return [r, g, b, args.length > 3 ? args[3] : 1];
26749
+ };
26750
+
26751
+ var hcg2rgb_1 = hcg2rgb;
26752
+
26753
+ var unpack$b = utils.unpack;
26754
+ var type$4 = utils.type;
26755
+
26756
+
26757
+
26758
+
26759
+
26760
+
26761
+ Color_1.prototype.hcg = function() {
26762
+ return rgb2hcg_1(this._rgb);
26763
+ };
26764
+
26765
+ chroma_1.hcg = function () {
26766
+ var args = [], len = arguments.length;
26767
+ while ( len-- ) args[ len ] = arguments[ len ];
26768
+
26769
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcg']) ));
26770
+ };
26771
+
26772
+ input.format.hcg = hcg2rgb_1;
26773
+
26774
+ input.autodetect.push({
26775
+ p: 1,
26776
+ test: function () {
26777
+ var args = [], len = arguments.length;
26778
+ while ( len-- ) args[ len ] = arguments[ len ];
26779
+
26780
+ args = unpack$b(args, 'hcg');
26781
+ if (type$4(args) === 'array' && args.length === 3) {
26782
+ return 'hcg';
26783
+ }
26784
+ }
26785
+ });
26786
+
26787
+ var unpack$c = utils.unpack;
26788
+ var last$4 = utils.last;
26789
+ var round$3 = Math.round;
26790
+
26791
+ var rgb2hex = function () {
26792
+ var args = [], len = arguments.length;
26793
+ while ( len-- ) args[ len ] = arguments[ len ];
26794
+
26795
+ var ref = unpack$c(args, 'rgba');
26796
+ var r = ref[0];
26797
+ var g = ref[1];
26798
+ var b = ref[2];
26799
+ var a = ref[3];
26800
+ var mode = last$4(args) || 'auto';
26801
+ if (a === undefined) { a = 1; }
26802
+ if (mode === 'auto') {
26803
+ mode = a < 1 ? 'rgba' : 'rgb';
26804
+ }
26805
+ r = round$3(r);
26806
+ g = round$3(g);
26807
+ b = round$3(b);
26808
+ var u = r << 16 | g << 8 | b;
26809
+ var str = "000000" + u.toString(16); //#.toUpperCase();
26810
+ str = str.substr(str.length - 6);
26811
+ var hxa = '0' + round$3(a * 255).toString(16);
26812
+ hxa = hxa.substr(hxa.length - 2);
26813
+ switch (mode.toLowerCase()) {
26814
+ case 'rgba': return ("#" + str + hxa);
26815
+ case 'argb': return ("#" + hxa + str);
26816
+ default: return ("#" + str);
26817
+ }
26818
+ };
26819
+
26820
+ var rgb2hex_1 = rgb2hex;
26821
+
26822
+ var RE_HEX = /^#?([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
26823
+ var RE_HEXA = /^#?([A-Fa-f0-9]{8}|[A-Fa-f0-9]{4})$/;
26824
+
26825
+ var hex2rgb = function (hex) {
26826
+ if (hex.match(RE_HEX)) {
26827
+ // remove optional leading #
26828
+ if (hex.length === 4 || hex.length === 7) {
26829
+ hex = hex.substr(1);
26830
+ }
26831
+ // expand short-notation to full six-digit
26832
+ if (hex.length === 3) {
26833
+ hex = hex.split('');
26834
+ hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2];
26835
+ }
26836
+ var u = parseInt(hex, 16);
26837
+ var r = u >> 16;
26838
+ var g = u >> 8 & 0xFF;
26839
+ var b = u & 0xFF;
26840
+ return [r,g,b,1];
26841
+ }
26842
+
26843
+ // match rgba hex format, eg #FF000077
26844
+ if (hex.match(RE_HEXA)) {
26845
+ if (hex.length === 5 || hex.length === 9) {
26846
+ // remove optional leading #
26847
+ hex = hex.substr(1);
26848
+ }
26849
+ // expand short-notation to full eight-digit
26850
+ if (hex.length === 4) {
26851
+ hex = hex.split('');
26852
+ hex = hex[0]+hex[0]+hex[1]+hex[1]+hex[2]+hex[2]+hex[3]+hex[3];
26853
+ }
26854
+ var u$1 = parseInt(hex, 16);
26855
+ var r$1 = u$1 >> 24 & 0xFF;
26856
+ var g$1 = u$1 >> 16 & 0xFF;
26857
+ var b$1 = u$1 >> 8 & 0xFF;
26858
+ var a = Math.round((u$1 & 0xFF) / 0xFF * 100) / 100;
26859
+ return [r$1,g$1,b$1,a];
26860
+ }
26861
+
26862
+ // we used to check for css colors here
26863
+ // if _input.css? and rgb = _input.css hex
26864
+ // return rgb
26865
+
26866
+ throw new Error(("unknown hex color: " + hex));
26867
+ };
26868
+
26869
+ var hex2rgb_1 = hex2rgb;
26870
+
26871
+ var type$5 = utils.type;
26872
+
26873
+
26874
+
26875
+
26876
+ Color_1.prototype.hex = function(mode) {
26877
+ return rgb2hex_1(this._rgb, mode);
26878
+ };
26879
+
26880
+ chroma_1.hex = function () {
26881
+ var args = [], len = arguments.length;
26882
+ while ( len-- ) args[ len ] = arguments[ len ];
26883
+
26884
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hex']) ));
26885
+ };
26886
+
26887
+ input.format.hex = hex2rgb_1;
26888
+ input.autodetect.push({
26889
+ p: 4,
26890
+ test: function (h) {
26891
+ var rest = [], len = arguments.length - 1;
26892
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
26893
+
26894
+ if (!rest.length && type$5(h) === 'string' && [3,4,5,6,7,8,9].indexOf(h.length) >= 0) {
26895
+ return 'hex';
26896
+ }
26897
+ }
26898
+ });
26899
+
26900
+ var unpack$d = utils.unpack;
26901
+ var TWOPI = utils.TWOPI;
26902
+ var min = Math.min;
26903
+ var sqrt = Math.sqrt;
26904
+ var acos = Math.acos;
26905
+
26906
+ var rgb2hsi = function () {
26907
+ var args = [], len = arguments.length;
26908
+ while ( len-- ) args[ len ] = arguments[ len ];
26909
+
26910
+ /*
26911
+ borrowed from here:
26912
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/rgb2hsi.cpp
26913
+ */
26914
+ var ref = unpack$d(args, 'rgb');
26915
+ var r = ref[0];
26916
+ var g = ref[1];
26917
+ var b = ref[2];
26918
+ r /= 255;
26919
+ g /= 255;
26920
+ b /= 255;
26921
+ var h;
26922
+ var min_ = min(r,g,b);
26923
+ var i = (r+g+b) / 3;
26924
+ var s = i > 0 ? 1 - min_/i : 0;
26925
+ if (s === 0) {
26926
+ h = NaN;
26927
+ } else {
26928
+ h = ((r-g)+(r-b)) / 2;
26929
+ h /= sqrt((r-g)*(r-g) + (r-b)*(g-b));
26930
+ h = acos(h);
26931
+ if (b > g) {
26932
+ h = TWOPI - h;
26933
+ }
26934
+ h /= TWOPI;
26935
+ }
26936
+ return [h*360,s,i];
26937
+ };
26938
+
26939
+ var rgb2hsi_1 = rgb2hsi;
26940
+
26941
+ var unpack$e = utils.unpack;
26942
+ var limit$1 = utils.limit;
26943
+ var TWOPI$1 = utils.TWOPI;
26944
+ var PITHIRD = utils.PITHIRD;
26945
+ var cos = Math.cos;
26946
+
26947
+ /*
26948
+ * hue [0..360]
26949
+ * saturation [0..1]
26950
+ * intensity [0..1]
26951
+ */
26952
+ var hsi2rgb = function () {
26953
+ var args = [], len = arguments.length;
26954
+ while ( len-- ) args[ len ] = arguments[ len ];
26955
+
26956
+ /*
26957
+ borrowed from here:
26958
+ http://hummer.stanford.edu/museinfo/doc/examples/humdrum/keyscape2/hsi2rgb.cpp
26959
+ */
26960
+ args = unpack$e(args, 'hsi');
26961
+ var h = args[0];
26962
+ var s = args[1];
26963
+ var i = args[2];
26964
+ var r,g,b;
26965
+
26966
+ if (isNaN(h)) { h = 0; }
26967
+ if (isNaN(s)) { s = 0; }
26968
+ // normalize hue
26969
+ if (h > 360) { h -= 360; }
26970
+ if (h < 0) { h += 360; }
26971
+ h /= 360;
26972
+ if (h < 1/3) {
26973
+ b = (1-s)/3;
26974
+ r = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26975
+ g = 1 - (b+r);
26976
+ } else if (h < 2/3) {
26977
+ h -= 1/3;
26978
+ r = (1-s)/3;
26979
+ g = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26980
+ b = 1 - (r+g);
26981
+ } else {
26982
+ h -= 2/3;
26983
+ g = (1-s)/3;
26984
+ b = (1+s*cos(TWOPI$1*h)/cos(PITHIRD-TWOPI$1*h))/3;
26985
+ r = 1 - (g+b);
26986
+ }
26987
+ r = limit$1(i*r*3);
26988
+ g = limit$1(i*g*3);
26989
+ b = limit$1(i*b*3);
26990
+ return [r*255, g*255, b*255, args.length > 3 ? args[3] : 1];
26991
+ };
26992
+
26993
+ var hsi2rgb_1 = hsi2rgb;
26994
+
26995
+ var unpack$f = utils.unpack;
26996
+ var type$6 = utils.type;
26997
+
26998
+
26999
+
27000
+
27001
+
27002
+
27003
+ Color_1.prototype.hsi = function() {
27004
+ return rgb2hsi_1(this._rgb);
27005
+ };
27006
+
27007
+ chroma_1.hsi = function () {
27008
+ var args = [], len = arguments.length;
27009
+ while ( len-- ) args[ len ] = arguments[ len ];
27010
+
27011
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsi']) ));
27012
+ };
27013
+
27014
+ input.format.hsi = hsi2rgb_1;
27015
+
27016
+ input.autodetect.push({
27017
+ p: 2,
27018
+ test: function () {
27019
+ var args = [], len = arguments.length;
27020
+ while ( len-- ) args[ len ] = arguments[ len ];
27021
+
27022
+ args = unpack$f(args, 'hsi');
27023
+ if (type$6(args) === 'array' && args.length === 3) {
27024
+ return 'hsi';
27025
+ }
27026
+ }
27027
+ });
27028
+
27029
+ var unpack$g = utils.unpack;
27030
+ var type$7 = utils.type;
27031
+
27032
+
27033
+
27034
+
27035
+
27036
+
27037
+ Color_1.prototype.hsl = function() {
27038
+ return rgb2hsl_1(this._rgb);
27039
+ };
27040
+
27041
+ chroma_1.hsl = function () {
27042
+ var args = [], len = arguments.length;
27043
+ while ( len-- ) args[ len ] = arguments[ len ];
27044
+
27045
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsl']) ));
27046
+ };
27047
+
27048
+ input.format.hsl = hsl2rgb_1;
27049
+
27050
+ input.autodetect.push({
27051
+ p: 2,
27052
+ test: function () {
27053
+ var args = [], len = arguments.length;
27054
+ while ( len-- ) args[ len ] = arguments[ len ];
27055
+
27056
+ args = unpack$g(args, 'hsl');
27057
+ if (type$7(args) === 'array' && args.length === 3) {
27058
+ return 'hsl';
27059
+ }
27060
+ }
27061
+ });
27062
+
27063
+ var unpack$h = utils.unpack;
27064
+ var min$1 = Math.min;
27065
+ var max$1 = Math.max;
27066
+
27067
+ /*
27068
+ * supported arguments:
27069
+ * - rgb2hsv(r,g,b)
27070
+ * - rgb2hsv([r,g,b])
27071
+ * - rgb2hsv({r,g,b})
27072
+ */
27073
+ var rgb2hsl$1 = function () {
27074
+ var args = [], len = arguments.length;
27075
+ while ( len-- ) args[ len ] = arguments[ len ];
27076
+
27077
+ args = unpack$h(args, 'rgb');
27078
+ var r = args[0];
27079
+ var g = args[1];
27080
+ var b = args[2];
27081
+ var min_ = min$1(r, g, b);
27082
+ var max_ = max$1(r, g, b);
27083
+ var delta = max_ - min_;
27084
+ var h,s,v;
27085
+ v = max_ / 255.0;
27086
+ if (max_ === 0) {
27087
+ h = Number.NaN;
27088
+ s = 0;
27089
+ } else {
27090
+ s = delta / max_;
27091
+ if (r === max_) { h = (g - b) / delta; }
27092
+ if (g === max_) { h = 2+(b - r) / delta; }
27093
+ if (b === max_) { h = 4+(r - g) / delta; }
27094
+ h *= 60;
27095
+ if (h < 0) { h += 360; }
27096
+ }
27097
+ return [h, s, v]
27098
+ };
27099
+
27100
+ var rgb2hsv = rgb2hsl$1;
27101
+
27102
+ var unpack$i = utils.unpack;
27103
+ var floor$1 = Math.floor;
27104
+
27105
+ var hsv2rgb = function () {
27106
+ var assign, assign$1, assign$2, assign$3, assign$4, assign$5;
27107
+
27108
+ var args = [], len = arguments.length;
27109
+ while ( len-- ) args[ len ] = arguments[ len ];
27110
+ args = unpack$i(args, 'hsv');
27111
+ var h = args[0];
27112
+ var s = args[1];
27113
+ var v = args[2];
27114
+ var r,g,b;
27115
+ v *= 255;
27116
+ if (s === 0) {
27117
+ r = g = b = v;
27118
+ } else {
27119
+ if (h === 360) { h = 0; }
27120
+ if (h > 360) { h -= 360; }
27121
+ if (h < 0) { h += 360; }
27122
+ h /= 60;
27123
+
27124
+ var i = floor$1(h);
27125
+ var f = h - i;
27126
+ var p = v * (1 - s);
27127
+ var q = v * (1 - s * f);
27128
+ var t = v * (1 - s * (1 - f));
27129
+
27130
+ switch (i) {
27131
+ case 0: (assign = [v, t, p], r = assign[0], g = assign[1], b = assign[2]); break
27132
+ case 1: (assign$1 = [q, v, p], r = assign$1[0], g = assign$1[1], b = assign$1[2]); break
27133
+ case 2: (assign$2 = [p, v, t], r = assign$2[0], g = assign$2[1], b = assign$2[2]); break
27134
+ case 3: (assign$3 = [p, q, v], r = assign$3[0], g = assign$3[1], b = assign$3[2]); break
27135
+ case 4: (assign$4 = [t, p, v], r = assign$4[0], g = assign$4[1], b = assign$4[2]); break
27136
+ case 5: (assign$5 = [v, p, q], r = assign$5[0], g = assign$5[1], b = assign$5[2]); break
27137
+ }
27138
+ }
27139
+ return [r,g,b,args.length > 3?args[3]:1];
27140
+ };
27141
+
27142
+ var hsv2rgb_1 = hsv2rgb;
27143
+
27144
+ var unpack$j = utils.unpack;
27145
+ var type$8 = utils.type;
27146
+
27147
+
27148
+
27149
+
27150
+
27151
+
27152
+ Color_1.prototype.hsv = function() {
27153
+ return rgb2hsv(this._rgb);
27154
+ };
27155
+
27156
+ chroma_1.hsv = function () {
27157
+ var args = [], len = arguments.length;
27158
+ while ( len-- ) args[ len ] = arguments[ len ];
27159
+
27160
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hsv']) ));
27161
+ };
27162
+
27163
+ input.format.hsv = hsv2rgb_1;
27164
+
27165
+ input.autodetect.push({
27166
+ p: 2,
27167
+ test: function () {
27168
+ var args = [], len = arguments.length;
27169
+ while ( len-- ) args[ len ] = arguments[ len ];
27170
+
27171
+ args = unpack$j(args, 'hsv');
27172
+ if (type$8(args) === 'array' && args.length === 3) {
27173
+ return 'hsv';
27174
+ }
27175
+ }
27176
+ });
27177
+
27178
+ var labConstants = {
27179
+ // Corresponds roughly to RGB brighter/darker
27180
+ Kn: 18,
27181
+
27182
+ // D65 standard referent
27183
+ Xn: 0.950470,
27184
+ Yn: 1,
27185
+ Zn: 1.088830,
27186
+
27187
+ t0: 0.137931034, // 4 / 29
27188
+ t1: 0.206896552, // 6 / 29
27189
+ t2: 0.12841855, // 3 * t1 * t1
27190
+ t3: 0.008856452, // t1 * t1 * t1
27191
+ };
27192
+
27193
+ var unpack$k = utils.unpack;
27194
+ var pow = Math.pow;
27195
+
27196
+ var rgb2lab = function () {
27197
+ var args = [], len = arguments.length;
27198
+ while ( len-- ) args[ len ] = arguments[ len ];
27199
+
27200
+ var ref = unpack$k(args, 'rgb');
27201
+ var r = ref[0];
27202
+ var g = ref[1];
27203
+ var b = ref[2];
27204
+ var ref$1 = rgb2xyz(r,g,b);
27205
+ var x = ref$1[0];
27206
+ var y = ref$1[1];
27207
+ var z = ref$1[2];
27208
+ var l = 116 * y - 16;
27209
+ return [l < 0 ? 0 : l, 500 * (x - y), 200 * (y - z)];
27210
+ };
27211
+
27212
+ var rgb_xyz = function (r) {
27213
+ if ((r /= 255) <= 0.04045) { return r / 12.92; }
27214
+ return pow((r + 0.055) / 1.055, 2.4);
27215
+ };
27216
+
27217
+ var xyz_lab = function (t) {
27218
+ if (t > labConstants.t3) { return pow(t, 1 / 3); }
27219
+ return t / labConstants.t2 + labConstants.t0;
27220
+ };
27221
+
27222
+ var rgb2xyz = function (r,g,b) {
27223
+ r = rgb_xyz(r);
27224
+ g = rgb_xyz(g);
27225
+ b = rgb_xyz(b);
27226
+ var x = xyz_lab((0.4124564 * r + 0.3575761 * g + 0.1804375 * b) / labConstants.Xn);
27227
+ var y = xyz_lab((0.2126729 * r + 0.7151522 * g + 0.0721750 * b) / labConstants.Yn);
27228
+ var z = xyz_lab((0.0193339 * r + 0.1191920 * g + 0.9503041 * b) / labConstants.Zn);
27229
+ return [x,y,z];
27230
+ };
27231
+
27232
+ var rgb2lab_1 = rgb2lab;
27233
+
27234
+ var unpack$l = utils.unpack;
27235
+ var pow$1 = Math.pow;
27236
+
27237
+ /*
27238
+ * L* [0..100]
27239
+ * a [-100..100]
27240
+ * b [-100..100]
27241
+ */
27242
+ var lab2rgb = function () {
27243
+ var args = [], len = arguments.length;
27244
+ while ( len-- ) args[ len ] = arguments[ len ];
27245
+
27246
+ args = unpack$l(args, 'lab');
27247
+ var l = args[0];
27248
+ var a = args[1];
27249
+ var b = args[2];
27250
+ var x,y,z, r,g,b_;
27251
+
27252
+ y = (l + 16) / 116;
27253
+ x = isNaN(a) ? y : y + a / 500;
27254
+ z = isNaN(b) ? y : y - b / 200;
27255
+
27256
+ y = labConstants.Yn * lab_xyz(y);
27257
+ x = labConstants.Xn * lab_xyz(x);
27258
+ z = labConstants.Zn * lab_xyz(z);
27259
+
27260
+ r = xyz_rgb(3.2404542 * x - 1.5371385 * y - 0.4985314 * z); // D65 -> sRGB
27261
+ g = xyz_rgb(-0.9692660 * x + 1.8760108 * y + 0.0415560 * z);
27262
+ b_ = xyz_rgb(0.0556434 * x - 0.2040259 * y + 1.0572252 * z);
27263
+
27264
+ return [r,g,b_,args.length > 3 ? args[3] : 1];
27265
+ };
27266
+
27267
+ var xyz_rgb = function (r) {
27268
+ return 255 * (r <= 0.00304 ? 12.92 * r : 1.055 * pow$1(r, 1 / 2.4) - 0.055)
27269
+ };
27270
+
27271
+ var lab_xyz = function (t) {
27272
+ return t > labConstants.t1 ? t * t * t : labConstants.t2 * (t - labConstants.t0)
27273
+ };
27274
+
27275
+ var lab2rgb_1 = lab2rgb;
27276
+
27277
+ var unpack$m = utils.unpack;
27278
+ var type$9 = utils.type;
27279
+
27280
+
27281
+
27282
+
27283
+
27284
+
27285
+ Color_1.prototype.lab = function() {
27286
+ return rgb2lab_1(this._rgb);
27287
+ };
27288
+
27289
+ chroma_1.lab = function () {
27290
+ var args = [], len = arguments.length;
27291
+ while ( len-- ) args[ len ] = arguments[ len ];
27292
+
27293
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lab']) ));
27294
+ };
27295
+
27296
+ input.format.lab = lab2rgb_1;
27297
+
27298
+ input.autodetect.push({
27299
+ p: 2,
27300
+ test: function () {
27301
+ var args = [], len = arguments.length;
27302
+ while ( len-- ) args[ len ] = arguments[ len ];
27303
+
27304
+ args = unpack$m(args, 'lab');
27305
+ if (type$9(args) === 'array' && args.length === 3) {
27306
+ return 'lab';
27307
+ }
27308
+ }
27309
+ });
27310
+
27311
+ var unpack$n = utils.unpack;
27312
+ var RAD2DEG = utils.RAD2DEG;
27313
+ var sqrt$1 = Math.sqrt;
27314
+ var atan2 = Math.atan2;
27315
+ var round$4 = Math.round;
27316
+
27317
+ var lab2lch = function () {
27318
+ var args = [], len = arguments.length;
27319
+ while ( len-- ) args[ len ] = arguments[ len ];
27320
+
27321
+ var ref = unpack$n(args, 'lab');
27322
+ var l = ref[0];
27323
+ var a = ref[1];
27324
+ var b = ref[2];
27325
+ var c = sqrt$1(a * a + b * b);
27326
+ var h = (atan2(b, a) * RAD2DEG + 360) % 360;
27327
+ if (round$4(c*10000) === 0) { h = Number.NaN; }
27328
+ return [l, c, h];
27329
+ };
27330
+
27331
+ var lab2lch_1 = lab2lch;
27332
+
27333
+ var unpack$o = utils.unpack;
27334
+
27335
+
27336
+
27337
+ var rgb2lch = function () {
27338
+ var args = [], len = arguments.length;
27339
+ while ( len-- ) args[ len ] = arguments[ len ];
27340
+
27341
+ var ref = unpack$o(args, 'rgb');
27342
+ var r = ref[0];
27343
+ var g = ref[1];
27344
+ var b = ref[2];
27345
+ var ref$1 = rgb2lab_1(r,g,b);
27346
+ var l = ref$1[0];
27347
+ var a = ref$1[1];
27348
+ var b_ = ref$1[2];
27349
+ return lab2lch_1(l,a,b_);
27350
+ };
27351
+
27352
+ var rgb2lch_1 = rgb2lch;
27353
+
27354
+ var unpack$p = utils.unpack;
27355
+ var DEG2RAD = utils.DEG2RAD;
27356
+ var sin = Math.sin;
27357
+ var cos$1 = Math.cos;
27358
+
27359
+ var lch2lab = function () {
27360
+ var args = [], len = arguments.length;
27361
+ while ( len-- ) args[ len ] = arguments[ len ];
27362
+
27363
+ /*
27364
+ Convert from a qualitative parameter h and a quantitative parameter l to a 24-bit pixel.
27365
+ These formulas were invented by David Dalrymple to obtain maximum contrast without going
27366
+ out of gamut if the parameters are in the range 0-1.
27367
+
27368
+ A saturation multiplier was added by Gregor Aisch
27369
+ */
27370
+ var ref = unpack$p(args, 'lch');
27371
+ var l = ref[0];
27372
+ var c = ref[1];
27373
+ var h = ref[2];
27374
+ if (isNaN(h)) { h = 0; }
27375
+ h = h * DEG2RAD;
27376
+ return [l, cos$1(h) * c, sin(h) * c]
27377
+ };
27378
+
27379
+ var lch2lab_1 = lch2lab;
27380
+
27381
+ var unpack$q = utils.unpack;
27382
+
27383
+
27384
+
27385
+ var lch2rgb = function () {
27386
+ var args = [], len = arguments.length;
27387
+ while ( len-- ) args[ len ] = arguments[ len ];
27388
+
27389
+ args = unpack$q(args, 'lch');
27390
+ var l = args[0];
27391
+ var c = args[1];
27392
+ var h = args[2];
27393
+ var ref = lch2lab_1 (l,c,h);
27394
+ var L = ref[0];
27395
+ var a = ref[1];
27396
+ var b_ = ref[2];
27397
+ var ref$1 = lab2rgb_1 (L,a,b_);
27398
+ var r = ref$1[0];
27399
+ var g = ref$1[1];
27400
+ var b = ref$1[2];
27401
+ return [r, g, b, args.length > 3 ? args[3] : 1];
27402
+ };
27403
+
27404
+ var lch2rgb_1 = lch2rgb;
27405
+
27406
+ var unpack$r = utils.unpack;
27407
+
27408
+
27409
+ var hcl2rgb = function () {
27410
+ var args = [], len = arguments.length;
27411
+ while ( len-- ) args[ len ] = arguments[ len ];
27412
+
27413
+ var hcl = unpack$r(args, 'hcl').reverse();
27414
+ return lch2rgb_1.apply(void 0, hcl);
27415
+ };
27416
+
27417
+ var hcl2rgb_1 = hcl2rgb;
27418
+
27419
+ var unpack$s = utils.unpack;
27420
+ var type$a = utils.type;
27421
+
27422
+
27423
+
27424
+
27425
+
27426
+
27427
+ Color_1.prototype.lch = function() { return rgb2lch_1(this._rgb); };
27428
+ Color_1.prototype.hcl = function() { return rgb2lch_1(this._rgb).reverse(); };
27429
+
27430
+ chroma_1.lch = function () {
27431
+ var args = [], len = arguments.length;
27432
+ while ( len-- ) args[ len ] = arguments[ len ];
27433
+
27434
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['lch']) ));
27435
+ };
27436
+ chroma_1.hcl = function () {
27437
+ var args = [], len = arguments.length;
27438
+ while ( len-- ) args[ len ] = arguments[ len ];
27439
+
27440
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['hcl']) ));
27441
+ };
27442
+
27443
+ input.format.lch = lch2rgb_1;
27444
+ input.format.hcl = hcl2rgb_1;
27445
+
27446
+ ['lch','hcl'].forEach(function (m) { return input.autodetect.push({
27447
+ p: 2,
27448
+ test: function () {
27449
+ var args = [], len = arguments.length;
27450
+ while ( len-- ) args[ len ] = arguments[ len ];
27451
+
27452
+ args = unpack$s(args, m);
27453
+ if (type$a(args) === 'array' && args.length === 3) {
27454
+ return m;
27455
+ }
27456
+ }
27457
+ }); });
27458
+
27459
+ /**
27460
+ X11 color names
27461
+
27462
+ http://www.w3.org/TR/css3-color/#svg-color
27463
+ */
27464
+
27465
+ var w3cx11 = {
27466
+ aliceblue: '#f0f8ff',
27467
+ antiquewhite: '#faebd7',
27468
+ aqua: '#00ffff',
27469
+ aquamarine: '#7fffd4',
27470
+ azure: '#f0ffff',
27471
+ beige: '#f5f5dc',
27472
+ bisque: '#ffe4c4',
27473
+ black: '#000000',
27474
+ blanchedalmond: '#ffebcd',
27475
+ blue: '#0000ff',
27476
+ blueviolet: '#8a2be2',
27477
+ brown: '#a52a2a',
27478
+ burlywood: '#deb887',
27479
+ cadetblue: '#5f9ea0',
27480
+ chartreuse: '#7fff00',
27481
+ chocolate: '#d2691e',
27482
+ coral: '#ff7f50',
27483
+ cornflower: '#6495ed',
27484
+ cornflowerblue: '#6495ed',
27485
+ cornsilk: '#fff8dc',
27486
+ crimson: '#dc143c',
27487
+ cyan: '#00ffff',
27488
+ darkblue: '#00008b',
27489
+ darkcyan: '#008b8b',
27490
+ darkgoldenrod: '#b8860b',
27491
+ darkgray: '#a9a9a9',
27492
+ darkgreen: '#006400',
27493
+ darkgrey: '#a9a9a9',
27494
+ darkkhaki: '#bdb76b',
27495
+ darkmagenta: '#8b008b',
27496
+ darkolivegreen: '#556b2f',
27497
+ darkorange: '#ff8c00',
27498
+ darkorchid: '#9932cc',
27499
+ darkred: '#8b0000',
27500
+ darksalmon: '#e9967a',
27501
+ darkseagreen: '#8fbc8f',
27502
+ darkslateblue: '#483d8b',
27503
+ darkslategray: '#2f4f4f',
27504
+ darkslategrey: '#2f4f4f',
27505
+ darkturquoise: '#00ced1',
27506
+ darkviolet: '#9400d3',
27507
+ deeppink: '#ff1493',
27508
+ deepskyblue: '#00bfff',
27509
+ dimgray: '#696969',
27510
+ dimgrey: '#696969',
27511
+ dodgerblue: '#1e90ff',
27512
+ firebrick: '#b22222',
27513
+ floralwhite: '#fffaf0',
27514
+ forestgreen: '#228b22',
27515
+ fuchsia: '#ff00ff',
27516
+ gainsboro: '#dcdcdc',
27517
+ ghostwhite: '#f8f8ff',
27518
+ gold: '#ffd700',
27519
+ goldenrod: '#daa520',
27520
+ gray: '#808080',
27521
+ green: '#008000',
27522
+ greenyellow: '#adff2f',
27523
+ grey: '#808080',
27524
+ honeydew: '#f0fff0',
27525
+ hotpink: '#ff69b4',
27526
+ indianred: '#cd5c5c',
27527
+ indigo: '#4b0082',
27528
+ ivory: '#fffff0',
27529
+ khaki: '#f0e68c',
27530
+ laserlemon: '#ffff54',
27531
+ lavender: '#e6e6fa',
27532
+ lavenderblush: '#fff0f5',
27533
+ lawngreen: '#7cfc00',
27534
+ lemonchiffon: '#fffacd',
27535
+ lightblue: '#add8e6',
27536
+ lightcoral: '#f08080',
27537
+ lightcyan: '#e0ffff',
27538
+ lightgoldenrod: '#fafad2',
27539
+ lightgoldenrodyellow: '#fafad2',
27540
+ lightgray: '#d3d3d3',
27541
+ lightgreen: '#90ee90',
27542
+ lightgrey: '#d3d3d3',
27543
+ lightpink: '#ffb6c1',
27544
+ lightsalmon: '#ffa07a',
27545
+ lightseagreen: '#20b2aa',
27546
+ lightskyblue: '#87cefa',
27547
+ lightslategray: '#778899',
27548
+ lightslategrey: '#778899',
27549
+ lightsteelblue: '#b0c4de',
27550
+ lightyellow: '#ffffe0',
27551
+ lime: '#00ff00',
27552
+ limegreen: '#32cd32',
27553
+ linen: '#faf0e6',
27554
+ magenta: '#ff00ff',
27555
+ maroon: '#800000',
27556
+ maroon2: '#7f0000',
27557
+ maroon3: '#b03060',
27558
+ mediumaquamarine: '#66cdaa',
27559
+ mediumblue: '#0000cd',
27560
+ mediumorchid: '#ba55d3',
27561
+ mediumpurple: '#9370db',
27562
+ mediumseagreen: '#3cb371',
27563
+ mediumslateblue: '#7b68ee',
27564
+ mediumspringgreen: '#00fa9a',
27565
+ mediumturquoise: '#48d1cc',
27566
+ mediumvioletred: '#c71585',
27567
+ midnightblue: '#191970',
27568
+ mintcream: '#f5fffa',
27569
+ mistyrose: '#ffe4e1',
27570
+ moccasin: '#ffe4b5',
27571
+ navajowhite: '#ffdead',
27572
+ navy: '#000080',
27573
+ oldlace: '#fdf5e6',
27574
+ olive: '#808000',
27575
+ olivedrab: '#6b8e23',
27576
+ orange: '#ffa500',
27577
+ orangered: '#ff4500',
27578
+ orchid: '#da70d6',
27579
+ palegoldenrod: '#eee8aa',
27580
+ palegreen: '#98fb98',
27581
+ paleturquoise: '#afeeee',
27582
+ palevioletred: '#db7093',
27583
+ papayawhip: '#ffefd5',
27584
+ peachpuff: '#ffdab9',
27585
+ peru: '#cd853f',
27586
+ pink: '#ffc0cb',
27587
+ plum: '#dda0dd',
27588
+ powderblue: '#b0e0e6',
27589
+ purple: '#800080',
27590
+ purple2: '#7f007f',
27591
+ purple3: '#a020f0',
27592
+ rebeccapurple: '#663399',
27593
+ red: '#ff0000',
27594
+ rosybrown: '#bc8f8f',
27595
+ royalblue: '#4169e1',
27596
+ saddlebrown: '#8b4513',
27597
+ salmon: '#fa8072',
27598
+ sandybrown: '#f4a460',
27599
+ seagreen: '#2e8b57',
27600
+ seashell: '#fff5ee',
27601
+ sienna: '#a0522d',
27602
+ silver: '#c0c0c0',
27603
+ skyblue: '#87ceeb',
27604
+ slateblue: '#6a5acd',
27605
+ slategray: '#708090',
27606
+ slategrey: '#708090',
27607
+ snow: '#fffafa',
27608
+ springgreen: '#00ff7f',
27609
+ steelblue: '#4682b4',
27610
+ tan: '#d2b48c',
27611
+ teal: '#008080',
27612
+ thistle: '#d8bfd8',
27613
+ tomato: '#ff6347',
27614
+ turquoise: '#40e0d0',
27615
+ violet: '#ee82ee',
27616
+ wheat: '#f5deb3',
27617
+ white: '#ffffff',
27618
+ whitesmoke: '#f5f5f5',
27619
+ yellow: '#ffff00',
27620
+ yellowgreen: '#9acd32'
27621
+ };
27622
+
27623
+ var w3cx11_1 = w3cx11;
27624
+
27625
+ var type$b = utils.type;
27626
+
27627
+
27628
+
27629
+
27630
+
27631
+ Color_1.prototype.name = function() {
27632
+ var hex = rgb2hex_1(this._rgb, 'rgb');
27633
+ for (var i = 0, list = Object.keys(w3cx11_1); i < list.length; i += 1) {
27634
+ var n = list[i];
27635
+
27636
+ if (w3cx11_1[n] === hex) { return n.toLowerCase(); }
27637
+ }
27638
+ return hex;
27639
+ };
27640
+
27641
+ input.format.named = function (name) {
27642
+ name = name.toLowerCase();
27643
+ if (w3cx11_1[name]) { return hex2rgb_1(w3cx11_1[name]); }
27644
+ throw new Error('unknown color name: '+name);
27645
+ };
27646
+
27647
+ input.autodetect.push({
27648
+ p: 5,
27649
+ test: function (h) {
27650
+ var rest = [], len = arguments.length - 1;
27651
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 1 ];
27652
+
27653
+ if (!rest.length && type$b(h) === 'string' && w3cx11_1[h.toLowerCase()]) {
27654
+ return 'named';
27655
+ }
27656
+ }
27657
+ });
27658
+
27659
+ var unpack$t = utils.unpack;
27660
+
27661
+ var rgb2num = function () {
27662
+ var args = [], len = arguments.length;
27663
+ while ( len-- ) args[ len ] = arguments[ len ];
27664
+
27665
+ var ref = unpack$t(args, 'rgb');
27666
+ var r = ref[0];
27667
+ var g = ref[1];
27668
+ var b = ref[2];
27669
+ return (r << 16) + (g << 8) + b;
27670
+ };
27671
+
27672
+ var rgb2num_1 = rgb2num;
27673
+
27674
+ var type$c = utils.type;
27675
+
27676
+ var num2rgb = function (num) {
27677
+ if (type$c(num) == "number" && num >= 0 && num <= 0xFFFFFF) {
27678
+ var r = num >> 16;
27679
+ var g = (num >> 8) & 0xFF;
27680
+ var b = num & 0xFF;
27681
+ return [r,g,b,1];
27682
+ }
27683
+ throw new Error("unknown num color: "+num);
27684
+ };
27685
+
27686
+ var num2rgb_1 = num2rgb;
27687
+
27688
+ var type$d = utils.type;
27689
+
27690
+
27691
+
27692
+ Color_1.prototype.num = function() {
27693
+ return rgb2num_1(this._rgb);
27694
+ };
27695
+
27696
+ chroma_1.num = function () {
27697
+ var args = [], len = arguments.length;
27698
+ while ( len-- ) args[ len ] = arguments[ len ];
27699
+
27700
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['num']) ));
27701
+ };
27702
+
27703
+ input.format.num = num2rgb_1;
27704
+
27705
+ input.autodetect.push({
27706
+ p: 5,
27707
+ test: function () {
27708
+ var args = [], len = arguments.length;
27709
+ while ( len-- ) args[ len ] = arguments[ len ];
27710
+
27711
+ if (args.length === 1 && type$d(args[0]) === 'number' && args[0] >= 0 && args[0] <= 0xFFFFFF) {
27712
+ return 'num';
27713
+ }
27714
+ }
27715
+ });
27716
+
27717
+ var unpack$u = utils.unpack;
27718
+ var type$e = utils.type;
27719
+ var round$5 = Math.round;
27720
+
27721
+ Color_1.prototype.rgb = function(rnd) {
27722
+ if ( rnd === void 0 ) rnd=true;
27723
+
27724
+ if (rnd === false) { return this._rgb.slice(0,3); }
27725
+ return this._rgb.slice(0,3).map(round$5);
27726
+ };
27727
+
27728
+ Color_1.prototype.rgba = function(rnd) {
27729
+ if ( rnd === void 0 ) rnd=true;
27730
+
27731
+ return this._rgb.slice(0,4).map(function (v,i) {
27732
+ return i<3 ? (rnd === false ? v : round$5(v)) : v;
27733
+ });
27734
+ };
27735
+
27736
+ chroma_1.rgb = function () {
27737
+ var args = [], len = arguments.length;
27738
+ while ( len-- ) args[ len ] = arguments[ len ];
27739
+
27740
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['rgb']) ));
27741
+ };
27742
+
27743
+ input.format.rgb = function () {
27744
+ var args = [], len = arguments.length;
27745
+ while ( len-- ) args[ len ] = arguments[ len ];
27746
+
27747
+ var rgba = unpack$u(args, 'rgba');
27748
+ if (rgba[3] === undefined) { rgba[3] = 1; }
27749
+ return rgba;
27750
+ };
27751
+
27752
+ input.autodetect.push({
27753
+ p: 3,
27754
+ test: function () {
27755
+ var args = [], len = arguments.length;
27756
+ while ( len-- ) args[ len ] = arguments[ len ];
27757
+
27758
+ args = unpack$u(args, 'rgba');
27759
+ if (type$e(args) === 'array' && (args.length === 3 ||
27760
+ args.length === 4 && type$e(args[3]) == 'number' && args[3] >= 0 && args[3] <= 1)) {
27761
+ return 'rgb';
27762
+ }
27763
+ }
27764
+ });
27765
+
27766
+ /*
27767
+ * Based on implementation by Neil Bartlett
27768
+ * https://github.com/neilbartlett/color-temperature
27769
+ */
27770
+
27771
+ var log = Math.log;
27772
+
27773
+ var temperature2rgb = function (kelvin) {
27774
+ var temp = kelvin / 100;
27775
+ var r,g,b;
27776
+ if (temp < 66) {
27777
+ r = 255;
27778
+ g = -155.25485562709179 - 0.44596950469579133 * (g = temp-2) + 104.49216199393888 * log(g);
27779
+ b = temp < 20 ? 0 : -254.76935184120902 + 0.8274096064007395 * (b = temp-10) + 115.67994401066147 * log(b);
27780
+ } else {
27781
+ r = 351.97690566805693 + 0.114206453784165 * (r = temp-55) - 40.25366309332127 * log(r);
27782
+ g = 325.4494125711974 + 0.07943456536662342 * (g = temp-50) - 28.0852963507957 * log(g);
27783
+ b = 255;
27784
+ }
27785
+ return [r,g,b,1];
27786
+ };
27787
+
27788
+ var temperature2rgb_1 = temperature2rgb;
27789
+
27790
+ /*
27791
+ * Based on implementation by Neil Bartlett
27792
+ * https://github.com/neilbartlett/color-temperature
27793
+ **/
27794
+
27795
+
27796
+ var unpack$v = utils.unpack;
27797
+ var round$6 = Math.round;
27798
+
27799
+ var rgb2temperature = function () {
27800
+ var args = [], len = arguments.length;
27801
+ while ( len-- ) args[ len ] = arguments[ len ];
27802
+
27803
+ var rgb = unpack$v(args, 'rgb');
27804
+ var r = rgb[0], b = rgb[2];
27805
+ var minTemp = 1000;
27806
+ var maxTemp = 40000;
27807
+ var eps = 0.4;
27808
+ var temp;
27809
+ while (maxTemp - minTemp > eps) {
27810
+ temp = (maxTemp + minTemp) * 0.5;
27811
+ var rgb$1 = temperature2rgb_1(temp);
27812
+ if ((rgb$1[2] / rgb$1[0]) >= (b / r)) {
27813
+ maxTemp = temp;
27814
+ } else {
27815
+ minTemp = temp;
27816
+ }
27817
+ }
27818
+ return round$6(temp);
27819
+ };
27820
+
27821
+ var rgb2temperature_1 = rgb2temperature;
27822
+
27823
+ Color_1.prototype.temp =
27824
+ Color_1.prototype.kelvin =
27825
+ Color_1.prototype.temperature = function() {
27826
+ return rgb2temperature_1(this._rgb);
27827
+ };
27828
+
27829
+ chroma_1.temp =
27830
+ chroma_1.kelvin =
27831
+ chroma_1.temperature = function () {
27832
+ var args = [], len = arguments.length;
27833
+ while ( len-- ) args[ len ] = arguments[ len ];
27834
+
27835
+ return new (Function.prototype.bind.apply( Color_1, [ null ].concat( args, ['temp']) ));
27836
+ };
27837
+
27838
+ input.format.temp =
27839
+ input.format.kelvin =
27840
+ input.format.temperature = temperature2rgb_1;
27841
+
27842
+ var type$f = utils.type;
27843
+
27844
+ Color_1.prototype.alpha = function(a, mutate) {
27845
+ if ( mutate === void 0 ) mutate=false;
27846
+
27847
+ if (a !== undefined && type$f(a) === 'number') {
27848
+ if (mutate) {
27849
+ this._rgb[3] = a;
27850
+ return this;
27851
+ }
27852
+ return new Color_1([this._rgb[0], this._rgb[1], this._rgb[2], a], 'rgb');
27853
+ }
27854
+ return this._rgb[3];
27855
+ };
27856
+
27857
+ Color_1.prototype.clipped = function() {
27858
+ return this._rgb._clipped || false;
27859
+ };
27860
+
27861
+ Color_1.prototype.darken = function(amount) {
27862
+ if ( amount === void 0 ) amount=1;
27863
+
27864
+ var me = this;
27865
+ var lab = me.lab();
27866
+ lab[0] -= labConstants.Kn * amount;
27867
+ return new Color_1(lab, 'lab').alpha(me.alpha(), true);
27868
+ };
27869
+
27870
+ Color_1.prototype.brighten = function(amount) {
27871
+ if ( amount === void 0 ) amount=1;
27872
+
27873
+ return this.darken(-amount);
27874
+ };
27875
+
27876
+ Color_1.prototype.darker = Color_1.prototype.darken;
27877
+ Color_1.prototype.brighter = Color_1.prototype.brighten;
27878
+
27879
+ Color_1.prototype.get = function(mc) {
27880
+ var ref = mc.split('.');
27881
+ var mode = ref[0];
27882
+ var channel = ref[1];
27883
+ var src = this[mode]();
27884
+ if (channel) {
27885
+ var i = mode.indexOf(channel);
27886
+ if (i > -1) { return src[i]; }
27887
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
27888
+ } else {
27889
+ return src;
27890
+ }
27891
+ };
27892
+
27893
+ var type$g = utils.type;
27894
+ var pow$2 = Math.pow;
27895
+
27896
+ var EPS = 1e-7;
27897
+ var MAX_ITER = 20;
27898
+
27899
+ Color_1.prototype.luminance = function(lum) {
27900
+ if (lum !== undefined && type$g(lum) === 'number') {
27901
+ if (lum === 0) {
27902
+ // return pure black
27903
+ return new Color_1([0,0,0,this._rgb[3]], 'rgb');
27904
+ }
27905
+ if (lum === 1) {
27906
+ // return pure white
27907
+ return new Color_1([255,255,255,this._rgb[3]], 'rgb');
27908
+ }
27909
+ // compute new color using...
27910
+ var cur_lum = this.luminance();
27911
+ var mode = 'rgb';
27912
+ var max_iter = MAX_ITER;
27913
+
27914
+ var test = function (low, high) {
27915
+ var mid = low.interpolate(high, 0.5, mode);
27916
+ var lm = mid.luminance();
27917
+ if (Math.abs(lum - lm) < EPS || !max_iter--) {
27918
+ // close enough
27919
+ return mid;
27920
+ }
27921
+ return lm > lum ? test(low, mid) : test(mid, high);
27922
+ };
27923
+
27924
+ var rgb = (cur_lum > lum ? test(new Color_1([0,0,0]), this) : test(this, new Color_1([255,255,255]))).rgb();
27925
+ return new Color_1(rgb.concat( [this._rgb[3]]));
27926
+ }
27927
+ return rgb2luminance.apply(void 0, (this._rgb).slice(0,3));
27928
+ };
27929
+
27930
+
27931
+ var rgb2luminance = function (r,g,b) {
27932
+ // relative luminance
27933
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef
27934
+ r = luminance_x(r);
27935
+ g = luminance_x(g);
27936
+ b = luminance_x(b);
27937
+ return 0.2126 * r + 0.7152 * g + 0.0722 * b;
27938
+ };
27939
+
27940
+ var luminance_x = function (x) {
27941
+ x /= 255;
27942
+ return x <= 0.03928 ? x/12.92 : pow$2((x+0.055)/1.055, 2.4);
27943
+ };
27944
+
27945
+ var interpolator = {};
27946
+
27947
+ var type$h = utils.type;
27948
+
27949
+
27950
+ var mix = function (col1, col2, f) {
27951
+ if ( f === void 0 ) f=0.5;
27952
+ var rest = [], len = arguments.length - 3;
27953
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 3 ];
27954
+
27955
+ var mode = rest[0] || 'lrgb';
27956
+ if (!interpolator[mode] && !rest.length) {
27957
+ // fall back to the first supported mode
27958
+ mode = Object.keys(interpolator)[0];
27959
+ }
27960
+ if (!interpolator[mode]) {
27961
+ throw new Error(("interpolation mode " + mode + " is not defined"));
27962
+ }
27963
+ if (type$h(col1) !== 'object') { col1 = new Color_1(col1); }
27964
+ if (type$h(col2) !== 'object') { col2 = new Color_1(col2); }
27965
+ return interpolator[mode](col1, col2, f)
27966
+ .alpha(col1.alpha() + f * (col2.alpha() - col1.alpha()));
27967
+ };
27968
+
27969
+ Color_1.prototype.mix =
27970
+ Color_1.prototype.interpolate = function(col2, f) {
27971
+ if ( f === void 0 ) f=0.5;
27972
+ var rest = [], len = arguments.length - 2;
27973
+ while ( len-- > 0 ) rest[ len ] = arguments[ len + 2 ];
27974
+
27975
+ return mix.apply(void 0, [ this, col2, f ].concat( rest ));
27976
+ };
27977
+
27978
+ Color_1.prototype.premultiply = function(mutate) {
27979
+ if ( mutate === void 0 ) mutate=false;
27980
+
27981
+ var rgb = this._rgb;
27982
+ var a = rgb[3];
27983
+ if (mutate) {
27984
+ this._rgb = [rgb[0]*a, rgb[1]*a, rgb[2]*a, a];
27985
+ return this;
27986
+ } else {
27987
+ return new Color_1([rgb[0]*a, rgb[1]*a, rgb[2]*a, a], 'rgb');
27988
+ }
27989
+ };
27990
+
27991
+ Color_1.prototype.saturate = function(amount) {
27992
+ if ( amount === void 0 ) amount=1;
27993
+
27994
+ var me = this;
27995
+ var lch = me.lch();
27996
+ lch[1] += labConstants.Kn * amount;
27997
+ if (lch[1] < 0) { lch[1] = 0; }
27998
+ return new Color_1(lch, 'lch').alpha(me.alpha(), true);
27999
+ };
28000
+
28001
+ Color_1.prototype.desaturate = function(amount) {
28002
+ if ( amount === void 0 ) amount=1;
28003
+
28004
+ return this.saturate(-amount);
28005
+ };
28006
+
28007
+ var type$i = utils.type;
28008
+
28009
+ Color_1.prototype.set = function(mc, value, mutate) {
28010
+ if ( mutate === void 0 ) mutate=false;
28011
+
28012
+ var ref = mc.split('.');
28013
+ var mode = ref[0];
28014
+ var channel = ref[1];
28015
+ var src = this[mode]();
28016
+ if (channel) {
28017
+ var i = mode.indexOf(channel);
28018
+ if (i > -1) {
28019
+ if (type$i(value) == 'string') {
28020
+ switch(value.charAt(0)) {
28021
+ case '+': src[i] += +value; break;
28022
+ case '-': src[i] += +value; break;
28023
+ case '*': src[i] *= +(value.substr(1)); break;
28024
+ case '/': src[i] /= +(value.substr(1)); break;
28025
+ default: src[i] = +value;
28026
+ }
28027
+ } else if (type$i(value) === 'number') {
28028
+ src[i] = value;
28029
+ } else {
28030
+ throw new Error("unsupported value for Color.set");
28031
+ }
28032
+ var out = new Color_1(src, mode);
28033
+ if (mutate) {
28034
+ this._rgb = out._rgb;
28035
+ return this;
28036
+ }
28037
+ return out;
28038
+ }
28039
+ throw new Error(("unknown channel " + channel + " in mode " + mode));
28040
+ } else {
28041
+ return src;
28042
+ }
28043
+ };
28044
+
28045
+ var rgb$1 = function (col1, col2, f) {
28046
+ var xyz0 = col1._rgb;
28047
+ var xyz1 = col2._rgb;
28048
+ return new Color_1(
28049
+ xyz0[0] + f * (xyz1[0]-xyz0[0]),
28050
+ xyz0[1] + f * (xyz1[1]-xyz0[1]),
28051
+ xyz0[2] + f * (xyz1[2]-xyz0[2]),
28052
+ 'rgb'
28053
+ )
28054
+ };
28055
+
28056
+ // register interpolator
28057
+ interpolator.rgb = rgb$1;
28058
+
28059
+ var sqrt$2 = Math.sqrt;
28060
+ var pow$3 = Math.pow;
28061
+
28062
+ var lrgb = function (col1, col2, f) {
28063
+ var ref = col1._rgb;
28064
+ var x1 = ref[0];
28065
+ var y1 = ref[1];
28066
+ var z1 = ref[2];
28067
+ var ref$1 = col2._rgb;
28068
+ var x2 = ref$1[0];
28069
+ var y2 = ref$1[1];
28070
+ var z2 = ref$1[2];
28071
+ return new Color_1(
28072
+ sqrt$2(pow$3(x1,2) * (1-f) + pow$3(x2,2) * f),
28073
+ sqrt$2(pow$3(y1,2) * (1-f) + pow$3(y2,2) * f),
28074
+ sqrt$2(pow$3(z1,2) * (1-f) + pow$3(z2,2) * f),
28075
+ 'rgb'
28076
+ )
28077
+ };
28078
+
28079
+ // register interpolator
28080
+ interpolator.lrgb = lrgb;
28081
+
28082
+ var lab$1 = function (col1, col2, f) {
28083
+ var xyz0 = col1.lab();
28084
+ var xyz1 = col2.lab();
28085
+ return new Color_1(
28086
+ xyz0[0] + f * (xyz1[0]-xyz0[0]),
28087
+ xyz0[1] + f * (xyz1[1]-xyz0[1]),
28088
+ xyz0[2] + f * (xyz1[2]-xyz0[2]),
28089
+ 'lab'
28090
+ )
28091
+ };
28092
+
28093
+ // register interpolator
28094
+ interpolator.lab = lab$1;
28095
+
28096
+ var _hsx = function (col1, col2, f, m) {
28097
+ var assign, assign$1;
28098
+
28099
+ var xyz0, xyz1;
28100
+ if (m === 'hsl') {
28101
+ xyz0 = col1.hsl();
28102
+ xyz1 = col2.hsl();
28103
+ } else if (m === 'hsv') {
28104
+ xyz0 = col1.hsv();
28105
+ xyz1 = col2.hsv();
28106
+ } else if (m === 'hcg') {
28107
+ xyz0 = col1.hcg();
28108
+ xyz1 = col2.hcg();
28109
+ } else if (m === 'hsi') {
28110
+ xyz0 = col1.hsi();
28111
+ xyz1 = col2.hsi();
28112
+ } else if (m === 'lch' || m === 'hcl') {
28113
+ m = 'hcl';
28114
+ xyz0 = col1.hcl();
28115
+ xyz1 = col2.hcl();
28116
+ }
28117
+
28118
+ var hue0, hue1, sat0, sat1, lbv0, lbv1;
28119
+ if (m.substr(0, 1) === 'h') {
28120
+ (assign = xyz0, hue0 = assign[0], sat0 = assign[1], lbv0 = assign[2]);
28121
+ (assign$1 = xyz1, hue1 = assign$1[0], sat1 = assign$1[1], lbv1 = assign$1[2]);
28122
+ }
28123
+
28124
+ var sat, hue, lbv, dh;
28125
+
28126
+ if (!isNaN(hue0) && !isNaN(hue1)) {
28127
+ // both colors have hue
28128
+ if (hue1 > hue0 && hue1 - hue0 > 180) {
28129
+ dh = hue1-(hue0+360);
28130
+ } else if (hue1 < hue0 && hue0 - hue1 > 180) {
28131
+ dh = hue1+360-hue0;
28132
+ } else {
28133
+ dh = hue1 - hue0;
28134
+ }
28135
+ hue = hue0 + f * dh;
28136
+ } else if (!isNaN(hue0)) {
28137
+ hue = hue0;
28138
+ if ((lbv1 == 1 || lbv1 == 0) && m != 'hsv') { sat = sat0; }
28139
+ } else if (!isNaN(hue1)) {
28140
+ hue = hue1;
28141
+ if ((lbv0 == 1 || lbv0 == 0) && m != 'hsv') { sat = sat1; }
28142
+ } else {
28143
+ hue = Number.NaN;
28144
+ }
28145
+
28146
+ if (sat === undefined) { sat = sat0 + f * (sat1 - sat0); }
28147
+ lbv = lbv0 + f * (lbv1-lbv0);
28148
+ return new Color_1([hue, sat, lbv], m);
28149
+ };
28150
+
28151
+ var lch$1 = function (col1, col2, f) {
28152
+ return _hsx(col1, col2, f, 'lch');
28153
+ };
28154
+
28155
+ // register interpolator
28156
+ interpolator.lch = lch$1;
28157
+ interpolator.hcl = lch$1;
28158
+
28159
+ var num$1 = function (col1, col2, f) {
28160
+ var c1 = col1.num();
28161
+ var c2 = col2.num();
28162
+ return new Color_1(c1 + f * (c2-c1), 'num')
28163
+ };
28164
+
28165
+ // register interpolator
28166
+ interpolator.num = num$1;
28167
+
28168
+ var hcg$1 = function (col1, col2, f) {
28169
+ return _hsx(col1, col2, f, 'hcg');
28170
+ };
28171
+
28172
+ // register interpolator
28173
+ interpolator.hcg = hcg$1;
28174
+
28175
+ var hsi$1 = function (col1, col2, f) {
28176
+ return _hsx(col1, col2, f, 'hsi');
28177
+ };
28178
+
28179
+ // register interpolator
28180
+ interpolator.hsi = hsi$1;
28181
+
28182
+ var hsl$1 = function (col1, col2, f) {
28183
+ return _hsx(col1, col2, f, 'hsl');
28184
+ };
28185
+
28186
+ // register interpolator
28187
+ interpolator.hsl = hsl$1;
28188
+
28189
+ var hsv$1 = function (col1, col2, f) {
28190
+ return _hsx(col1, col2, f, 'hsv');
28191
+ };
28192
+
28193
+ // register interpolator
28194
+ interpolator.hsv = hsv$1;
28195
+
28196
+ var clip_rgb$2 = utils.clip_rgb;
28197
+ var pow$4 = Math.pow;
28198
+ var sqrt$3 = Math.sqrt;
28199
+ var PI$1 = Math.PI;
28200
+ var cos$2 = Math.cos;
28201
+ var sin$1 = Math.sin;
28202
+ var atan2$1 = Math.atan2;
28203
+
28204
+ var average = function (colors, mode, weights) {
28205
+ if ( mode === void 0 ) mode='lrgb';
28206
+ if ( weights === void 0 ) weights=null;
28207
+
28208
+ var l = colors.length;
28209
+ if (!weights) { weights = Array.from(new Array(l)).map(function () { return 1; }); }
28210
+ // normalize weights
28211
+ var k = l / weights.reduce(function(a, b) { return a + b; });
28212
+ weights.forEach(function (w,i) { weights[i] *= k; });
28213
+ // convert colors to Color objects
28214
+ colors = colors.map(function (c) { return new Color_1(c); });
28215
+ if (mode === 'lrgb') {
28216
+ return _average_lrgb(colors, weights)
28217
+ }
28218
+ var first = colors.shift();
28219
+ var xyz = first.get(mode);
28220
+ var cnt = [];
28221
+ var dx = 0;
28222
+ var dy = 0;
28223
+ // initial color
28224
+ for (var i=0; i<xyz.length; i++) {
28225
+ xyz[i] = (xyz[i] || 0) * weights[0];
28226
+ cnt.push(isNaN(xyz[i]) ? 0 : weights[0]);
28227
+ if (mode.charAt(i) === 'h' && !isNaN(xyz[i])) {
28228
+ var A = xyz[i] / 180 * PI$1;
28229
+ dx += cos$2(A) * weights[0];
28230
+ dy += sin$1(A) * weights[0];
28231
+ }
28232
+ }
28233
+
28234
+ var alpha = first.alpha() * weights[0];
28235
+ colors.forEach(function (c,ci) {
28236
+ var xyz2 = c.get(mode);
28237
+ alpha += c.alpha() * weights[ci+1];
28238
+ for (var i=0; i<xyz.length; i++) {
28239
+ if (!isNaN(xyz2[i])) {
28240
+ cnt[i] += weights[ci+1];
28241
+ if (mode.charAt(i) === 'h') {
28242
+ var A = xyz2[i] / 180 * PI$1;
28243
+ dx += cos$2(A) * weights[ci+1];
28244
+ dy += sin$1(A) * weights[ci+1];
28245
+ } else {
28246
+ xyz[i] += xyz2[i] * weights[ci+1];
28247
+ }
28248
+ }
28249
+ }
28250
+ });
28251
+
28252
+ for (var i$1=0; i$1<xyz.length; i$1++) {
28253
+ if (mode.charAt(i$1) === 'h') {
28254
+ var A$1 = atan2$1(dy / cnt[i$1], dx / cnt[i$1]) / PI$1 * 180;
28255
+ while (A$1 < 0) { A$1 += 360; }
28256
+ while (A$1 >= 360) { A$1 -= 360; }
28257
+ xyz[i$1] = A$1;
28258
+ } else {
28259
+ xyz[i$1] = xyz[i$1]/cnt[i$1];
28260
+ }
28261
+ }
28262
+ alpha /= l;
28263
+ return (new Color_1(xyz, mode)).alpha(alpha > 0.99999 ? 1 : alpha, true);
28264
+ };
28265
+
28266
+
28267
+ var _average_lrgb = function (colors, weights) {
28268
+ var l = colors.length;
28269
+ var xyz = [0,0,0,0];
28270
+ for (var i=0; i < colors.length; i++) {
28271
+ var col = colors[i];
28272
+ var f = weights[i] / l;
28273
+ var rgb = col._rgb;
28274
+ xyz[0] += pow$4(rgb[0],2) * f;
28275
+ xyz[1] += pow$4(rgb[1],2) * f;
28276
+ xyz[2] += pow$4(rgb[2],2) * f;
28277
+ xyz[3] += rgb[3] * f;
28278
+ }
28279
+ xyz[0] = sqrt$3(xyz[0]);
28280
+ xyz[1] = sqrt$3(xyz[1]);
28281
+ xyz[2] = sqrt$3(xyz[2]);
28282
+ if (xyz[3] > 0.9999999) { xyz[3] = 1; }
28283
+ return new Color_1(clip_rgb$2(xyz));
28284
+ };
28285
+
28286
+ // minimal multi-purpose interface
28287
+
28288
+ // @requires utils color analyze
28289
+
28290
+
28291
+ var type$j = utils.type;
28292
+
28293
+ var pow$5 = Math.pow;
28294
+
28295
+ var scale = function(colors) {
28296
+
28297
+ // constructor
28298
+ var _mode = 'rgb';
28299
+ var _nacol = chroma_1('#ccc');
28300
+ var _spread = 0;
28301
+ // const _fixed = false;
28302
+ var _domain = [0, 1];
28303
+ var _pos = [];
28304
+ var _padding = [0,0];
28305
+ var _classes = false;
28306
+ var _colors = [];
28307
+ var _out = false;
28308
+ var _min = 0;
28309
+ var _max = 1;
28310
+ var _correctLightness = false;
28311
+ var _colorCache = {};
28312
+ var _useCache = true;
28313
+ var _gamma = 1;
28314
+
28315
+ // private methods
28316
+
28317
+ var setColors = function(colors) {
28318
+ colors = colors || ['#fff', '#000'];
28319
+ if (colors && type$j(colors) === 'string' && chroma_1.brewer &&
28320
+ chroma_1.brewer[colors.toLowerCase()]) {
28321
+ colors = chroma_1.brewer[colors.toLowerCase()];
28322
+ }
28323
+ if (type$j(colors) === 'array') {
28324
+ // handle single color
28325
+ if (colors.length === 1) {
28326
+ colors = [colors[0], colors[0]];
28327
+ }
28328
+ // make a copy of the colors
28329
+ colors = colors.slice(0);
28330
+ // convert to chroma classes
28331
+ for (var c=0; c<colors.length; c++) {
28332
+ colors[c] = chroma_1(colors[c]);
28333
+ }
28334
+ // auto-fill color position
28335
+ _pos.length = 0;
28336
+ for (var c$1=0; c$1<colors.length; c$1++) {
28337
+ _pos.push(c$1/(colors.length-1));
28338
+ }
28339
+ }
28340
+ resetCache();
28341
+ return _colors = colors;
28342
+ };
28343
+
28344
+ var getClass = function(value) {
28345
+ if (_classes != null) {
28346
+ var n = _classes.length-1;
28347
+ var i = 0;
28348
+ while (i < n && value >= _classes[i]) {
28349
+ i++;
28350
+ }
28351
+ return i-1;
28352
+ }
28353
+ return 0;
28354
+ };
28355
+
28356
+ var tMapLightness = function (t) { return t; };
28357
+ var tMapDomain = function (t) { return t; };
28358
+
28359
+ // const classifyValue = function(value) {
28360
+ // let val = value;
28361
+ // if (_classes.length > 2) {
28362
+ // const n = _classes.length-1;
28363
+ // const i = getClass(value);
28364
+ // const minc = _classes[0] + ((_classes[1]-_classes[0]) * (0 + (_spread * 0.5))); // center of 1st class
28365
+ // const maxc = _classes[n-1] + ((_classes[n]-_classes[n-1]) * (1 - (_spread * 0.5))); // center of last class
28366
+ // val = _min + ((((_classes[i] + ((_classes[i+1] - _classes[i]) * 0.5)) - minc) / (maxc-minc)) * (_max - _min));
28367
+ // }
28368
+ // return val;
28369
+ // };
28370
+
28371
+ var getColor = function(val, bypassMap) {
28372
+ var col, t;
28373
+ if (bypassMap == null) { bypassMap = false; }
28374
+ if (isNaN(val) || (val === null)) { return _nacol; }
28375
+ if (!bypassMap) {
28376
+ if (_classes && (_classes.length > 2)) {
28377
+ // find the class
28378
+ var c = getClass(val);
28379
+ t = c / (_classes.length-2);
28380
+ } else if (_max !== _min) {
28381
+ // just interpolate between min/max
28382
+ t = (val - _min) / (_max - _min);
28383
+ } else {
28384
+ t = 1;
28385
+ }
28386
+ } else {
28387
+ t = val;
28388
+ }
28389
+
28390
+ // domain map
28391
+ t = tMapDomain(t);
28392
+
28393
+ if (!bypassMap) {
28394
+ t = tMapLightness(t); // lightness correction
28395
+ }
28396
+
28397
+ if (_gamma !== 1) { t = pow$5(t, _gamma); }
28398
+
28399
+ t = _padding[0] + (t * (1 - _padding[0] - _padding[1]));
28400
+
28401
+ t = Math.min(1, Math.max(0, t));
28402
+
28403
+ var k = Math.floor(t * 10000);
28404
+
28405
+ if (_useCache && _colorCache[k]) {
28406
+ col = _colorCache[k];
28407
+ } else {
28408
+ if (type$j(_colors) === 'array') {
28409
+ //for i in [0.._pos.length-1]
28410
+ for (var i=0; i<_pos.length; i++) {
28411
+ var p = _pos[i];
28412
+ if (t <= p) {
28413
+ col = _colors[i];
28414
+ break;
28415
+ }
28416
+ if ((t >= p) && (i === (_pos.length-1))) {
28417
+ col = _colors[i];
28418
+ break;
28419
+ }
28420
+ if (t > p && t < _pos[i+1]) {
28421
+ t = (t-p)/(_pos[i+1]-p);
28422
+ col = chroma_1.interpolate(_colors[i], _colors[i+1], t, _mode);
28423
+ break;
28424
+ }
28425
+ }
28426
+ } else if (type$j(_colors) === 'function') {
28427
+ col = _colors(t);
28428
+ }
28429
+ if (_useCache) { _colorCache[k] = col; }
28430
+ }
28431
+ return col;
28432
+ };
28433
+
28434
+ var resetCache = function () { return _colorCache = {}; };
28435
+
28436
+ setColors(colors);
28437
+
28438
+ // public interface
28439
+
28440
+ var f = function(v) {
28441
+ var c = chroma_1(getColor(v));
28442
+ if (_out && c[_out]) { return c[_out](); } else { return c; }
28443
+ };
28444
+
28445
+ f.classes = function(classes) {
28446
+ if (classes != null) {
28447
+ if (type$j(classes) === 'array') {
28448
+ _classes = classes;
28449
+ _domain = [classes[0], classes[classes.length-1]];
28450
+ } else {
28451
+ var d = chroma_1.analyze(_domain);
28452
+ if (classes === 0) {
28453
+ _classes = [d.min, d.max];
28454
+ } else {
28455
+ _classes = chroma_1.limits(d, 'e', classes);
28456
+ }
28457
+ }
28458
+ return f;
28459
+ }
28460
+ return _classes;
28461
+ };
28462
+
28463
+
28464
+ f.domain = function(domain) {
28465
+ if (!arguments.length) {
28466
+ return _domain;
28467
+ }
28468
+ _min = domain[0];
28469
+ _max = domain[domain.length-1];
28470
+ _pos = [];
28471
+ var k = _colors.length;
28472
+ if ((domain.length === k) && (_min !== _max)) {
28473
+ // update positions
28474
+ for (var i = 0, list = Array.from(domain); i < list.length; i += 1) {
28475
+ var d = list[i];
28476
+
28477
+ _pos.push((d-_min) / (_max-_min));
28478
+ }
28479
+ } else {
28480
+ for (var c=0; c<k; c++) {
28481
+ _pos.push(c/(k-1));
28482
+ }
28483
+ if (domain.length > 2) {
28484
+ // set domain map
28485
+ var tOut = domain.map(function (d,i) { return i/(domain.length-1); });
28486
+ var tBreaks = domain.map(function (d) { return (d - _min) / (_max - _min); });
28487
+ if (!tBreaks.every(function (val, i) { return tOut[i] === val; })) {
28488
+ tMapDomain = function (t) {
28489
+ if (t <= 0 || t >= 1) { return t; }
28490
+ var i = 0;
28491
+ while (t >= tBreaks[i+1]) { i++; }
28492
+ var f = (t - tBreaks[i]) / (tBreaks[i+1] - tBreaks[i]);
28493
+ var out = tOut[i] + f * (tOut[i+1] - tOut[i]);
28494
+ return out;
28495
+ };
28496
+ }
28497
+
28498
+ }
28499
+ }
28500
+ _domain = [_min, _max];
28501
+ return f;
28502
+ };
28503
+
28504
+ f.mode = function(_m) {
28505
+ if (!arguments.length) {
28506
+ return _mode;
28507
+ }
28508
+ _mode = _m;
28509
+ resetCache();
28510
+ return f;
28511
+ };
28512
+
28513
+ f.range = function(colors, _pos) {
28514
+ setColors(colors);
28515
+ return f;
28516
+ };
28517
+
28518
+ f.out = function(_o) {
28519
+ _out = _o;
28520
+ return f;
28521
+ };
28522
+
28523
+ f.spread = function(val) {
28524
+ if (!arguments.length) {
28525
+ return _spread;
28526
+ }
28527
+ _spread = val;
28528
+ return f;
28529
+ };
28530
+
28531
+ f.correctLightness = function(v) {
28532
+ if (v == null) { v = true; }
28533
+ _correctLightness = v;
28534
+ resetCache();
28535
+ if (_correctLightness) {
28536
+ tMapLightness = function(t) {
28537
+ var L0 = getColor(0, true).lab()[0];
28538
+ var L1 = getColor(1, true).lab()[0];
28539
+ var pol = L0 > L1;
28540
+ var L_actual = getColor(t, true).lab()[0];
28541
+ var L_ideal = L0 + ((L1 - L0) * t);
28542
+ var L_diff = L_actual - L_ideal;
28543
+ var t0 = 0;
28544
+ var t1 = 1;
28545
+ var max_iter = 20;
28546
+ while ((Math.abs(L_diff) > 1e-2) && (max_iter-- > 0)) {
28547
+ (function() {
28548
+ if (pol) { L_diff *= -1; }
28549
+ if (L_diff < 0) {
28550
+ t0 = t;
28551
+ t += (t1 - t) * 0.5;
28552
+ } else {
28553
+ t1 = t;
28554
+ t += (t0 - t) * 0.5;
28555
+ }
28556
+ L_actual = getColor(t, true).lab()[0];
28557
+ return L_diff = L_actual - L_ideal;
28558
+ })();
28559
+ }
28560
+ return t;
28561
+ };
28562
+ } else {
28563
+ tMapLightness = function (t) { return t; };
28564
+ }
28565
+ return f;
28566
+ };
28567
+
28568
+ f.padding = function(p) {
28569
+ if (p != null) {
28570
+ if (type$j(p) === 'number') {
28571
+ p = [p,p];
28572
+ }
28573
+ _padding = p;
28574
+ return f;
28575
+ } else {
28576
+ return _padding;
28577
+ }
28578
+ };
28579
+
28580
+ f.colors = function(numColors, out) {
28581
+ // If no arguments are given, return the original colors that were provided
28582
+ if (arguments.length < 2) { out = 'hex'; }
28583
+ var result = [];
28584
+
28585
+ if (arguments.length === 0) {
28586
+ result = _colors.slice(0);
28587
+
28588
+ } else if (numColors === 1) {
28589
+ result = [f(0.5)];
28590
+
28591
+ } else if (numColors > 1) {
28592
+ var dm = _domain[0];
28593
+ var dd = _domain[1] - dm;
28594
+ result = __range__(0, numColors, false).map(function (i) { return f( dm + ((i/(numColors-1)) * dd) ); });
28595
+
28596
+ } else { // returns all colors based on the defined classes
28597
+ colors = [];
28598
+ var samples = [];
28599
+ if (_classes && (_classes.length > 2)) {
28600
+ for (var i = 1, end = _classes.length, asc = 1 <= end; asc ? i < end : i > end; asc ? i++ : i--) {
28601
+ samples.push((_classes[i-1]+_classes[i])*0.5);
28602
+ }
28603
+ } else {
28604
+ samples = _domain;
28605
+ }
28606
+ result = samples.map(function (v) { return f(v); });
28607
+ }
25759
28608
 
25760
- const RewardExchangeList = /*#__PURE__*/Object.freeze({
28609
+ if (chroma_1[out]) {
28610
+ result = result.map(function (c) { return c[out](); });
28611
+ }
28612
+ return result;
28613
+ };
28614
+
28615
+ f.cache = function(c) {
28616
+ if (c != null) {
28617
+ _useCache = c;
28618
+ return f;
28619
+ } else {
28620
+ return _useCache;
28621
+ }
28622
+ };
28623
+
28624
+ f.gamma = function(g) {
28625
+ if (g != null) {
28626
+ _gamma = g;
28627
+ return f;
28628
+ } else {
28629
+ return _gamma;
28630
+ }
28631
+ };
28632
+
28633
+ f.nodata = function(d) {
28634
+ if (d != null) {
28635
+ _nacol = chroma_1(d);
28636
+ return f;
28637
+ } else {
28638
+ return _nacol;
28639
+ }
28640
+ };
28641
+
28642
+ return f;
28643
+ };
28644
+
28645
+ function __range__(left, right, inclusive) {
28646
+ var range = [];
28647
+ var ascending = left < right;
28648
+ var end = !inclusive ? right : ascending ? right + 1 : right - 1;
28649
+ for (var i = left; ascending ? i < end : i > end; ascending ? i++ : i--) {
28650
+ range.push(i);
28651
+ }
28652
+ return range;
28653
+ }
28654
+
28655
+ //
28656
+ // interpolates between a set of colors uzing a bezier spline
28657
+ //
28658
+
28659
+ // @requires utils lab
28660
+
28661
+
28662
+
28663
+
28664
+ var bezier = function(colors) {
28665
+ var assign, assign$1, assign$2;
28666
+
28667
+ var I, lab0, lab1, lab2;
28668
+ colors = colors.map(function (c) { return new Color_1(c); });
28669
+ if (colors.length === 2) {
28670
+ // linear interpolation
28671
+ (assign = colors.map(function (c) { return c.lab(); }), lab0 = assign[0], lab1 = assign[1]);
28672
+ I = function(t) {
28673
+ var lab = ([0, 1, 2].map(function (i) { return lab0[i] + (t * (lab1[i] - lab0[i])); }));
28674
+ return new Color_1(lab, 'lab');
28675
+ };
28676
+ } else if (colors.length === 3) {
28677
+ // quadratic bezier interpolation
28678
+ (assign$1 = colors.map(function (c) { return c.lab(); }), lab0 = assign$1[0], lab1 = assign$1[1], lab2 = assign$1[2]);
28679
+ I = function(t) {
28680
+ 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]); }));
28681
+ return new Color_1(lab, 'lab');
28682
+ };
28683
+ } else if (colors.length === 4) {
28684
+ // cubic bezier interpolation
28685
+ var lab3;
28686
+ (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]);
28687
+ I = function(t) {
28688
+ 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]); }));
28689
+ return new Color_1(lab, 'lab');
28690
+ };
28691
+ } else if (colors.length === 5) {
28692
+ var I0 = bezier(colors.slice(0, 3));
28693
+ var I1 = bezier(colors.slice(2, 5));
28694
+ I = function(t) {
28695
+ if (t < 0.5) {
28696
+ return I0(t*2);
28697
+ } else {
28698
+ return I1((t-0.5)*2);
28699
+ }
28700
+ };
28701
+ }
28702
+ return I;
28703
+ };
28704
+
28705
+ var bezier_1 = function (colors) {
28706
+ var f = bezier(colors);
28707
+ f.scale = function () { return scale(f); };
28708
+ return f;
28709
+ };
28710
+
28711
+ /*
28712
+ * interpolates between a set of colors uzing a bezier spline
28713
+ * blend mode formulas taken from http://www.venture-ware.com/kevin/coding/lets-learn-math-photoshop-blend-modes/
28714
+ */
28715
+
28716
+
28717
+
28718
+
28719
+ var blend = function (bottom, top, mode) {
28720
+ if (!blend[mode]) {
28721
+ throw new Error('unknown blend mode ' + mode);
28722
+ }
28723
+ return blend[mode](bottom, top);
28724
+ };
28725
+
28726
+ var blend_f = function (f) { return function (bottom,top) {
28727
+ var c0 = chroma_1(top).rgb();
28728
+ var c1 = chroma_1(bottom).rgb();
28729
+ return chroma_1.rgb(f(c0, c1));
28730
+ }; };
28731
+
28732
+ var each = function (f) { return function (c0, c1) {
28733
+ var out = [];
28734
+ out[0] = f(c0[0], c1[0]);
28735
+ out[1] = f(c0[1], c1[1]);
28736
+ out[2] = f(c0[2], c1[2]);
28737
+ return out;
28738
+ }; };
28739
+
28740
+ var normal = function (a) { return a; };
28741
+ var multiply = function (a,b) { return a * b / 255; };
28742
+ var darken$1 = function (a,b) { return a > b ? b : a; };
28743
+ var lighten = function (a,b) { return a > b ? a : b; };
28744
+ var screen = function (a,b) { return 255 * (1 - (1-a/255) * (1-b/255)); };
28745
+ var overlay = function (a,b) { return b < 128 ? 2 * a * b / 255 : 255 * (1 - 2 * (1 - a / 255 ) * ( 1 - b / 255 )); };
28746
+ var burn = function (a,b) { return 255 * (1 - (1 - b / 255) / (a/255)); };
28747
+ var dodge = function (a,b) {
28748
+ if (a === 255) { return 255; }
28749
+ a = 255 * (b / 255) / (1 - a / 255);
28750
+ return a > 255 ? 255 : a
28751
+ };
28752
+
28753
+ // # add = (a,b) ->
28754
+ // # if (a + b > 255) then 255 else a + b
28755
+
28756
+ blend.normal = blend_f(each(normal));
28757
+ blend.multiply = blend_f(each(multiply));
28758
+ blend.screen = blend_f(each(screen));
28759
+ blend.overlay = blend_f(each(overlay));
28760
+ blend.darken = blend_f(each(darken$1));
28761
+ blend.lighten = blend_f(each(lighten));
28762
+ blend.dodge = blend_f(each(dodge));
28763
+ blend.burn = blend_f(each(burn));
28764
+ // blend.add = blend_f(each(add));
28765
+
28766
+ var blend_1 = blend;
28767
+
28768
+ // cubehelix interpolation
28769
+ // based on D.A. Green "A colour scheme for the display of astronomical intensity images"
28770
+ // http://astron-soc.in/bulletin/11June/289392011.pdf
28771
+
28772
+ var type$k = utils.type;
28773
+ var clip_rgb$3 = utils.clip_rgb;
28774
+ var TWOPI$2 = utils.TWOPI;
28775
+ var pow$6 = Math.pow;
28776
+ var sin$2 = Math.sin;
28777
+ var cos$3 = Math.cos;
28778
+
28779
+
28780
+ var cubehelix = function(start, rotations, hue, gamma, lightness) {
28781
+ if ( start === void 0 ) start=300;
28782
+ if ( rotations === void 0 ) rotations=-1.5;
28783
+ if ( hue === void 0 ) hue=1;
28784
+ if ( gamma === void 0 ) gamma=1;
28785
+ if ( lightness === void 0 ) lightness=[0,1];
28786
+
28787
+ var dh = 0, dl;
28788
+ if (type$k(lightness) === 'array') {
28789
+ dl = lightness[1] - lightness[0];
28790
+ } else {
28791
+ dl = 0;
28792
+ lightness = [lightness, lightness];
28793
+ }
28794
+
28795
+ var f = function(fract) {
28796
+ var a = TWOPI$2 * (((start+120)/360) + (rotations * fract));
28797
+ var l = pow$6(lightness[0] + (dl * fract), gamma);
28798
+ var h = dh !== 0 ? hue[0] + (fract * dh) : hue;
28799
+ var amp = (h * l * (1-l)) / 2;
28800
+ var cos_a = cos$3(a);
28801
+ var sin_a = sin$2(a);
28802
+ var r = l + (amp * ((-0.14861 * cos_a) + (1.78277* sin_a)));
28803
+ var g = l + (amp * ((-0.29227 * cos_a) - (0.90649* sin_a)));
28804
+ var b = l + (amp * (+1.97294 * cos_a));
28805
+ return chroma_1(clip_rgb$3([r*255,g*255,b*255,1]));
28806
+ };
28807
+
28808
+ f.start = function(s) {
28809
+ if ((s == null)) { return start; }
28810
+ start = s;
28811
+ return f;
28812
+ };
28813
+
28814
+ f.rotations = function(r) {
28815
+ if ((r == null)) { return rotations; }
28816
+ rotations = r;
28817
+ return f;
28818
+ };
28819
+
28820
+ f.gamma = function(g) {
28821
+ if ((g == null)) { return gamma; }
28822
+ gamma = g;
28823
+ return f;
28824
+ };
28825
+
28826
+ f.hue = function(h) {
28827
+ if ((h == null)) { return hue; }
28828
+ hue = h;
28829
+ if (type$k(hue) === 'array') {
28830
+ dh = hue[1] - hue[0];
28831
+ if (dh === 0) { hue = hue[1]; }
28832
+ } else {
28833
+ dh = 0;
28834
+ }
28835
+ return f;
28836
+ };
28837
+
28838
+ f.lightness = function(h) {
28839
+ if ((h == null)) { return lightness; }
28840
+ if (type$k(h) === 'array') {
28841
+ lightness = h;
28842
+ dl = h[1] - h[0];
28843
+ } else {
28844
+ lightness = [h,h];
28845
+ dl = 0;
28846
+ }
28847
+ return f;
28848
+ };
28849
+
28850
+ f.scale = function () { return chroma_1.scale(f); };
28851
+
28852
+ f.hue(hue);
28853
+
28854
+ return f;
28855
+ };
28856
+
28857
+ var digits = '0123456789abcdef';
28858
+
28859
+ var floor$2 = Math.floor;
28860
+ var random = Math.random;
28861
+
28862
+ var random_1 = function () {
28863
+ var code = '#';
28864
+ for (var i=0; i<6; i++) {
28865
+ code += digits.charAt(floor$2(random() * 16));
28866
+ }
28867
+ return new Color_1(code, 'hex');
28868
+ };
28869
+
28870
+ var log$1 = Math.log;
28871
+ var pow$7 = Math.pow;
28872
+ var floor$3 = Math.floor;
28873
+ var abs = Math.abs;
28874
+
28875
+
28876
+ var analyze = function (data, key) {
28877
+ if ( key === void 0 ) key=null;
28878
+
28879
+ var r = {
28880
+ min: Number.MAX_VALUE,
28881
+ max: Number.MAX_VALUE*-1,
28882
+ sum: 0,
28883
+ values: [],
28884
+ count: 0
28885
+ };
28886
+ if (type(data) === 'object') {
28887
+ data = Object.values(data);
28888
+ }
28889
+ data.forEach(function (val) {
28890
+ if (key && type(val) === 'object') { val = val[key]; }
28891
+ if (val !== undefined && val !== null && !isNaN(val)) {
28892
+ r.values.push(val);
28893
+ r.sum += val;
28894
+ if (val < r.min) { r.min = val; }
28895
+ if (val > r.max) { r.max = val; }
28896
+ r.count += 1;
28897
+ }
28898
+ });
28899
+
28900
+ r.domain = [r.min, r.max];
28901
+
28902
+ r.limits = function (mode, num) { return limits(r, mode, num); };
28903
+
28904
+ return r;
28905
+ };
28906
+
28907
+
28908
+ var limits = function (data, mode, num) {
28909
+ if ( mode === void 0 ) mode='equal';
28910
+ if ( num === void 0 ) num=7;
28911
+
28912
+ if (type(data) == 'array') {
28913
+ data = analyze(data);
28914
+ }
28915
+ var min = data.min;
28916
+ var max = data.max;
28917
+ var values = data.values.sort(function (a,b) { return a-b; });
28918
+
28919
+ if (num === 1) { return [min,max]; }
28920
+
28921
+ var limits = [];
28922
+
28923
+ if (mode.substr(0,1) === 'c') { // continuous
28924
+ limits.push(min);
28925
+ limits.push(max);
28926
+ }
28927
+
28928
+ if (mode.substr(0,1) === 'e') { // equal interval
28929
+ limits.push(min);
28930
+ for (var i=1; i<num; i++) {
28931
+ limits.push(min+((i/num)*(max-min)));
28932
+ }
28933
+ limits.push(max);
28934
+ }
28935
+
28936
+ else if (mode.substr(0,1) === 'l') { // log scale
28937
+ if (min <= 0) {
28938
+ throw new Error('Logarithmic scales are only possible for values > 0');
28939
+ }
28940
+ var min_log = Math.LOG10E * log$1(min);
28941
+ var max_log = Math.LOG10E * log$1(max);
28942
+ limits.push(min);
28943
+ for (var i$1=1; i$1<num; i$1++) {
28944
+ limits.push(pow$7(10, min_log + ((i$1/num) * (max_log - min_log))));
28945
+ }
28946
+ limits.push(max);
28947
+ }
28948
+
28949
+ else if (mode.substr(0,1) === 'q') { // quantile scale
28950
+ limits.push(min);
28951
+ for (var i$2=1; i$2<num; i$2++) {
28952
+ var p = ((values.length-1) * i$2)/num;
28953
+ var pb = floor$3(p);
28954
+ if (pb === p) {
28955
+ limits.push(values[pb]);
28956
+ } else { // p > pb
28957
+ var pr = p - pb;
28958
+ limits.push((values[pb]*(1-pr)) + (values[pb+1]*pr));
28959
+ }
28960
+ }
28961
+ limits.push(max);
28962
+
28963
+ }
28964
+
28965
+ else if (mode.substr(0,1) === 'k') { // k-means clustering
28966
+ /*
28967
+ implementation based on
28968
+ http://code.google.com/p/figue/source/browse/trunk/figue.js#336
28969
+ simplified for 1-d input values
28970
+ */
28971
+ var cluster;
28972
+ var n = values.length;
28973
+ var assignments = new Array(n);
28974
+ var clusterSizes = new Array(num);
28975
+ var repeat = true;
28976
+ var nb_iters = 0;
28977
+ var centroids = null;
28978
+
28979
+ // get seed values
28980
+ centroids = [];
28981
+ centroids.push(min);
28982
+ for (var i$3=1; i$3<num; i$3++) {
28983
+ centroids.push(min + ((i$3/num) * (max-min)));
28984
+ }
28985
+ centroids.push(max);
28986
+
28987
+ while (repeat) {
28988
+ // assignment step
28989
+ for (var j=0; j<num; j++) {
28990
+ clusterSizes[j] = 0;
28991
+ }
28992
+ for (var i$4=0; i$4<n; i$4++) {
28993
+ var value = values[i$4];
28994
+ var mindist = Number.MAX_VALUE;
28995
+ var best = (void 0);
28996
+ for (var j$1=0; j$1<num; j$1++) {
28997
+ var dist = abs(centroids[j$1]-value);
28998
+ if (dist < mindist) {
28999
+ mindist = dist;
29000
+ best = j$1;
29001
+ }
29002
+ clusterSizes[best]++;
29003
+ assignments[i$4] = best;
29004
+ }
29005
+ }
29006
+
29007
+ // update centroids step
29008
+ var newCentroids = new Array(num);
29009
+ for (var j$2=0; j$2<num; j$2++) {
29010
+ newCentroids[j$2] = null;
29011
+ }
29012
+ for (var i$5=0; i$5<n; i$5++) {
29013
+ cluster = assignments[i$5];
29014
+ if (newCentroids[cluster] === null) {
29015
+ newCentroids[cluster] = values[i$5];
29016
+ } else {
29017
+ newCentroids[cluster] += values[i$5];
29018
+ }
29019
+ }
29020
+ for (var j$3=0; j$3<num; j$3++) {
29021
+ newCentroids[j$3] *= 1/clusterSizes[j$3];
29022
+ }
29023
+
29024
+ // check convergence
29025
+ repeat = false;
29026
+ for (var j$4=0; j$4<num; j$4++) {
29027
+ if (newCentroids[j$4] !== centroids[j$4]) {
29028
+ repeat = true;
29029
+ break;
29030
+ }
29031
+ }
29032
+
29033
+ centroids = newCentroids;
29034
+ nb_iters++;
29035
+
29036
+ if (nb_iters > 200) {
29037
+ repeat = false;
29038
+ }
29039
+ }
29040
+
29041
+ // finished k-means clustering
29042
+ // the next part is borrowed from gabrielflor.it
29043
+ var kClusters = {};
29044
+ for (var j$5=0; j$5<num; j$5++) {
29045
+ kClusters[j$5] = [];
29046
+ }
29047
+ for (var i$6=0; i$6<n; i$6++) {
29048
+ cluster = assignments[i$6];
29049
+ kClusters[cluster].push(values[i$6]);
29050
+ }
29051
+ var tmpKMeansBreaks = [];
29052
+ for (var j$6=0; j$6<num; j$6++) {
29053
+ tmpKMeansBreaks.push(kClusters[j$6][0]);
29054
+ tmpKMeansBreaks.push(kClusters[j$6][kClusters[j$6].length-1]);
29055
+ }
29056
+ tmpKMeansBreaks = tmpKMeansBreaks.sort(function (a,b){ return a-b; });
29057
+ limits.push(tmpKMeansBreaks[0]);
29058
+ for (var i$7=1; i$7 < tmpKMeansBreaks.length; i$7+= 2) {
29059
+ var v = tmpKMeansBreaks[i$7];
29060
+ if (!isNaN(v) && (limits.indexOf(v) === -1)) {
29061
+ limits.push(v);
29062
+ }
29063
+ }
29064
+ }
29065
+ return limits;
29066
+ };
29067
+
29068
+ var analyze_1 = {analyze: analyze, limits: limits};
29069
+
29070
+ var contrast = function (a, b) {
29071
+ // WCAG contrast ratio
29072
+ // see http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef
29073
+ a = new Color_1(a);
29074
+ b = new Color_1(b);
29075
+ var l1 = a.luminance();
29076
+ var l2 = b.luminance();
29077
+ return l1 > l2 ? (l1 + 0.05) / (l2 + 0.05) : (l2 + 0.05) / (l1 + 0.05);
29078
+ };
29079
+
29080
+ var sqrt$4 = Math.sqrt;
29081
+ var atan2$2 = Math.atan2;
29082
+ var abs$1 = Math.abs;
29083
+ var cos$4 = Math.cos;
29084
+ var PI$2 = Math.PI;
29085
+
29086
+ var deltaE = function(a, b, L, C) {
29087
+ if ( L === void 0 ) L=1;
29088
+ if ( C === void 0 ) C=1;
29089
+
29090
+ // Delta E (CMC)
29091
+ // see http://www.brucelindbloom.com/index.html?Eqn_DeltaE_CMC.html
29092
+ a = new Color_1(a);
29093
+ b = new Color_1(b);
29094
+ var ref = Array.from(a.lab());
29095
+ var L1 = ref[0];
29096
+ var a1 = ref[1];
29097
+ var b1 = ref[2];
29098
+ var ref$1 = Array.from(b.lab());
29099
+ var L2 = ref$1[0];
29100
+ var a2 = ref$1[1];
29101
+ var b2 = ref$1[2];
29102
+ var c1 = sqrt$4((a1 * a1) + (b1 * b1));
29103
+ var c2 = sqrt$4((a2 * a2) + (b2 * b2));
29104
+ var sl = L1 < 16.0 ? 0.511 : (0.040975 * L1) / (1.0 + (0.01765 * L1));
29105
+ var sc = ((0.0638 * c1) / (1.0 + (0.0131 * c1))) + 0.638;
29106
+ var h1 = c1 < 0.000001 ? 0.0 : (atan2$2(b1, a1) * 180.0) / PI$2;
29107
+ while (h1 < 0) { h1 += 360; }
29108
+ while (h1 >= 360) { h1 -= 360; }
29109
+ 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)));
29110
+ var c4 = c1 * c1 * c1 * c1;
29111
+ var f = sqrt$4(c4 / (c4 + 1900.0));
29112
+ var sh = sc * (((f * t) + 1.0) - f);
29113
+ var delL = L1 - L2;
29114
+ var delC = c1 - c2;
29115
+ var delA = a1 - a2;
29116
+ var delB = b1 - b2;
29117
+ var dH2 = ((delA * delA) + (delB * delB)) - (delC * delC);
29118
+ var v1 = delL / (L * sl);
29119
+ var v2 = delC / (C * sc);
29120
+ var v3 = sh;
29121
+ return sqrt$4((v1 * v1) + (v2 * v2) + (dH2 / (v3 * v3)));
29122
+ };
29123
+
29124
+ // simple Euclidean distance
29125
+ var distance = function(a, b, mode) {
29126
+ if ( mode === void 0 ) mode='lab';
29127
+
29128
+ // Delta E (CIE 1976)
29129
+ // see http://www.brucelindbloom.com/index.html?Equations.html
29130
+ a = new Color_1(a);
29131
+ b = new Color_1(b);
29132
+ var l1 = a.get(mode);
29133
+ var l2 = b.get(mode);
29134
+ var sum_sq = 0;
29135
+ for (var i in l1) {
29136
+ var d = (l1[i] || 0) - (l2[i] || 0);
29137
+ sum_sq += d*d;
29138
+ }
29139
+ return Math.sqrt(sum_sq);
29140
+ };
29141
+
29142
+ var valid = function () {
29143
+ var args = [], len = arguments.length;
29144
+ while ( len-- ) args[ len ] = arguments[ len ];
29145
+
29146
+ try {
29147
+ new (Function.prototype.bind.apply( Color_1, [ null ].concat( args) ));
29148
+ return true;
29149
+ } catch (e) {
29150
+ return false;
29151
+ }
29152
+ };
29153
+
29154
+ // some pre-defined color scales:
29155
+
29156
+
29157
+
29158
+
29159
+ var scales = {
29160
+ cool: function cool() { return scale([chroma_1.hsl(180,1,.9), chroma_1.hsl(250,.7,.4)]) },
29161
+ hot: function hot() { return scale(['#000','#f00','#ff0','#fff']).mode('rgb') }
29162
+ };
29163
+
29164
+ /**
29165
+ ColorBrewer colors for chroma.js
29166
+
29167
+ Copyright (c) 2002 Cynthia Brewer, Mark Harrower, and The
29168
+ Pennsylvania State University.
29169
+
29170
+ Licensed under the Apache License, Version 2.0 (the "License");
29171
+ you may not use this file except in compliance with the License.
29172
+ You may obtain a copy of the License at
29173
+ http://www.apache.org/licenses/LICENSE-2.0
29174
+
29175
+ Unless required by applicable law or agreed to in writing, software distributed
29176
+ under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
29177
+ CONDITIONS OF ANY KIND, either express or implied. See the License for the
29178
+ specific language governing permissions and limitations under the License.
29179
+ */
29180
+
29181
+ var colorbrewer = {
29182
+ // sequential
29183
+ OrRd: ['#fff7ec', '#fee8c8', '#fdd49e', '#fdbb84', '#fc8d59', '#ef6548', '#d7301f', '#b30000', '#7f0000'],
29184
+ PuBu: ['#fff7fb', '#ece7f2', '#d0d1e6', '#a6bddb', '#74a9cf', '#3690c0', '#0570b0', '#045a8d', '#023858'],
29185
+ BuPu: ['#f7fcfd', '#e0ecf4', '#bfd3e6', '#9ebcda', '#8c96c6', '#8c6bb1', '#88419d', '#810f7c', '#4d004b'],
29186
+ Oranges: ['#fff5eb', '#fee6ce', '#fdd0a2', '#fdae6b', '#fd8d3c', '#f16913', '#d94801', '#a63603', '#7f2704'],
29187
+ BuGn: ['#f7fcfd', '#e5f5f9', '#ccece6', '#99d8c9', '#66c2a4', '#41ae76', '#238b45', '#006d2c', '#00441b'],
29188
+ YlOrBr: ['#ffffe5', '#fff7bc', '#fee391', '#fec44f', '#fe9929', '#ec7014', '#cc4c02', '#993404', '#662506'],
29189
+ YlGn: ['#ffffe5', '#f7fcb9', '#d9f0a3', '#addd8e', '#78c679', '#41ab5d', '#238443', '#006837', '#004529'],
29190
+ Reds: ['#fff5f0', '#fee0d2', '#fcbba1', '#fc9272', '#fb6a4a', '#ef3b2c', '#cb181d', '#a50f15', '#67000d'],
29191
+ RdPu: ['#fff7f3', '#fde0dd', '#fcc5c0', '#fa9fb5', '#f768a1', '#dd3497', '#ae017e', '#7a0177', '#49006a'],
29192
+ Greens: ['#f7fcf5', '#e5f5e0', '#c7e9c0', '#a1d99b', '#74c476', '#41ab5d', '#238b45', '#006d2c', '#00441b'],
29193
+ YlGnBu: ['#ffffd9', '#edf8b1', '#c7e9b4', '#7fcdbb', '#41b6c4', '#1d91c0', '#225ea8', '#253494', '#081d58'],
29194
+ Purples: ['#fcfbfd', '#efedf5', '#dadaeb', '#bcbddc', '#9e9ac8', '#807dba', '#6a51a3', '#54278f', '#3f007d'],
29195
+ GnBu: ['#f7fcf0', '#e0f3db', '#ccebc5', '#a8ddb5', '#7bccc4', '#4eb3d3', '#2b8cbe', '#0868ac', '#084081'],
29196
+ Greys: ['#ffffff', '#f0f0f0', '#d9d9d9', '#bdbdbd', '#969696', '#737373', '#525252', '#252525', '#000000'],
29197
+ YlOrRd: ['#ffffcc', '#ffeda0', '#fed976', '#feb24c', '#fd8d3c', '#fc4e2a', '#e31a1c', '#bd0026', '#800026'],
29198
+ PuRd: ['#f7f4f9', '#e7e1ef', '#d4b9da', '#c994c7', '#df65b0', '#e7298a', '#ce1256', '#980043', '#67001f'],
29199
+ Blues: ['#f7fbff', '#deebf7', '#c6dbef', '#9ecae1', '#6baed6', '#4292c6', '#2171b5', '#08519c', '#08306b'],
29200
+ PuBuGn: ['#fff7fb', '#ece2f0', '#d0d1e6', '#a6bddb', '#67a9cf', '#3690c0', '#02818a', '#016c59', '#014636'],
29201
+ Viridis: ['#440154', '#482777', '#3f4a8a', '#31678e', '#26838f', '#1f9d8a', '#6cce5a', '#b6de2b', '#fee825'],
29202
+
29203
+ // diverging
29204
+
29205
+ Spectral: ['#9e0142', '#d53e4f', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#e6f598', '#abdda4', '#66c2a5', '#3288bd', '#5e4fa2'],
29206
+ RdYlGn: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee08b', '#ffffbf', '#d9ef8b', '#a6d96a', '#66bd63', '#1a9850', '#006837'],
29207
+ RdBu: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#f7f7f7', '#d1e5f0', '#92c5de', '#4393c3', '#2166ac', '#053061'],
29208
+ PiYG: ['#8e0152', '#c51b7d', '#de77ae', '#f1b6da', '#fde0ef', '#f7f7f7', '#e6f5d0', '#b8e186', '#7fbc41', '#4d9221', '#276419'],
29209
+ PRGn: ['#40004b', '#762a83', '#9970ab', '#c2a5cf', '#e7d4e8', '#f7f7f7', '#d9f0d3', '#a6dba0', '#5aae61', '#1b7837', '#00441b'],
29210
+ RdYlBu: ['#a50026', '#d73027', '#f46d43', '#fdae61', '#fee090', '#ffffbf', '#e0f3f8', '#abd9e9', '#74add1', '#4575b4', '#313695'],
29211
+ BrBG: ['#543005', '#8c510a', '#bf812d', '#dfc27d', '#f6e8c3', '#f5f5f5', '#c7eae5', '#80cdc1', '#35978f', '#01665e', '#003c30'],
29212
+ RdGy: ['#67001f', '#b2182b', '#d6604d', '#f4a582', '#fddbc7', '#ffffff', '#e0e0e0', '#bababa', '#878787', '#4d4d4d', '#1a1a1a'],
29213
+ PuOr: ['#7f3b08', '#b35806', '#e08214', '#fdb863', '#fee0b6', '#f7f7f7', '#d8daeb', '#b2abd2', '#8073ac', '#542788', '#2d004b'],
29214
+
29215
+ // qualitative
29216
+
29217
+ Set2: ['#66c2a5', '#fc8d62', '#8da0cb', '#e78ac3', '#a6d854', '#ffd92f', '#e5c494', '#b3b3b3'],
29218
+ Accent: ['#7fc97f', '#beaed4', '#fdc086', '#ffff99', '#386cb0', '#f0027f', '#bf5b17', '#666666'],
29219
+ Set1: ['#e41a1c', '#377eb8', '#4daf4a', '#984ea3', '#ff7f00', '#ffff33', '#a65628', '#f781bf', '#999999'],
29220
+ Set3: ['#8dd3c7', '#ffffb3', '#bebada', '#fb8072', '#80b1d3', '#fdb462', '#b3de69', '#fccde5', '#d9d9d9', '#bc80bd', '#ccebc5', '#ffed6f'],
29221
+ Dark2: ['#1b9e77', '#d95f02', '#7570b3', '#e7298a', '#66a61e', '#e6ab02', '#a6761d', '#666666'],
29222
+ Paired: ['#a6cee3', '#1f78b4', '#b2df8a', '#33a02c', '#fb9a99', '#e31a1c', '#fdbf6f', '#ff7f00', '#cab2d6', '#6a3d9a', '#ffff99', '#b15928'],
29223
+ Pastel2: ['#b3e2cd', '#fdcdac', '#cbd5e8', '#f4cae4', '#e6f5c9', '#fff2ae', '#f1e2cc', '#cccccc'],
29224
+ Pastel1: ['#fbb4ae', '#b3cde3', '#ccebc5', '#decbe4', '#fed9a6', '#ffffcc', '#e5d8bd', '#fddaec', '#f2f2f2'],
29225
+ };
29226
+
29227
+ // add lowercase aliases for case-insensitive matches
29228
+ for (var i$1 = 0, list$1 = Object.keys(colorbrewer); i$1 < list$1.length; i$1 += 1) {
29229
+ var key = list$1[i$1];
29230
+
29231
+ colorbrewer[key.toLowerCase()] = colorbrewer[key];
29232
+ }
29233
+
29234
+ var colorbrewer_1 = colorbrewer;
29235
+
29236
+ // feel free to comment out anything to rollup
29237
+ // a smaller chroma.js built
29238
+
29239
+ // io --> convert colors
29240
+
29241
+
29242
+
29243
+
29244
+
29245
+
29246
+
29247
+
29248
+
29249
+
29250
+
29251
+
29252
+
29253
+
29254
+
29255
+ // operators --> modify existing Colors
29256
+
29257
+
29258
+
29259
+
29260
+
29261
+
29262
+
29263
+
29264
+
29265
+
29266
+ // interpolators
29267
+
29268
+
29269
+
29270
+
29271
+
29272
+
29273
+
29274
+
29275
+
29276
+
29277
+ // generators -- > create new colors
29278
+ chroma_1.average = average;
29279
+ chroma_1.bezier = bezier_1;
29280
+ chroma_1.blend = blend_1;
29281
+ chroma_1.cubehelix = cubehelix;
29282
+ chroma_1.mix = chroma_1.interpolate = mix;
29283
+ chroma_1.random = random_1;
29284
+ chroma_1.scale = scale;
29285
+
29286
+ // other utility methods
29287
+ chroma_1.analyze = analyze_1.analyze;
29288
+ chroma_1.contrast = contrast;
29289
+ chroma_1.deltaE = deltaE;
29290
+ chroma_1.distance = distance;
29291
+ chroma_1.limits = analyze_1.limits;
29292
+ chroma_1.valid = valid;
29293
+
29294
+ // scale
29295
+ chroma_1.scales = scales;
29296
+
29297
+ // colors
29298
+ chroma_1.colors = w3cx11_1;
29299
+ chroma_1.brewer = colorbrewer_1;
29300
+
29301
+ var chroma_js = chroma_1;
29302
+
29303
+ return chroma_js;
29304
+
29305
+ })));
29306
+ });
29307
+
29308
+ function autoColorScaleCss(color, name = "primary") {
29309
+ if (!chroma.valid(color)) {
29310
+ return;
29311
+ }
29312
+ const colorScale = [50, 100, 200, 300, 400, 500, 600, 700, 800, 900, 950];
29313
+ const hex = chroma(color).hex();
29314
+ const scale = chroma
29315
+ .scale([
29316
+ chroma(hex).luminance(0.95),
29317
+ chroma(hex).luminance(0.84),
29318
+ chroma(hex).luminance(0.73),
29319
+ chroma(hex).luminance(0.62),
29320
+ chroma(hex).luminance(0.49),
29321
+ chroma(hex).luminance(0.35),
29322
+ chroma(hex).luminance(0.23),
29323
+ chroma(hex).luminance(0.15),
29324
+ chroma(hex).luminance(0.1),
29325
+ chroma(hex).luminance(0.05),
29326
+ chroma(hex).luminance(0.02),
29327
+ ])
29328
+ .colors(colorScale.length);
29329
+ return scale
29330
+ .map((color, index) => `--sl-color-${name}-${colorScale[index]}: ${chroma(color).hex()};`)
29331
+ .join("\n");
29332
+ }
29333
+
29334
+ /**
29335
+ *
29336
+ * Themes
29337
+ *
29338
+ * Export only valid CSS. Those will be injected into style tags.
29339
+ *
29340
+ * Useful links:
29341
+ * - https://brandcolors.net/
29342
+ * - Shoelace color generator: https://codepen.io/claviska/full/QWveRgL
29343
+ *
29344
+ */
29345
+ //
29346
+ const Default$b = `
29347
+ // No CSS
29348
+ `;
29349
+ const Orangey = `
29350
+ :root{
29351
+ ${autoColorScaleCss("orange")}
29352
+ }
29353
+ `;
29354
+ const Netflix = `
29355
+ :root{
29356
+ ${autoColorScaleCss("#e50914")}
29357
+ }
29358
+ `;
29359
+ const SaaSquatchCorporate = `
29360
+ :root{
29361
+ ${autoColorScaleCss("green")}
29362
+ --sl-font-sans: Arial;
29363
+ }
29364
+ `;
29365
+ const NYTimes = `
29366
+ :root{
29367
+ ${autoColorScaleCss("black")}
29368
+ --sl-font-sans: Georgia, 'Times New Roman', serif;
29369
+ }
29370
+ `;
29371
+
29372
+ const Themes = /*#__PURE__*/Object.freeze({
25761
29373
  __proto__: null,
25762
- 'default': RewardExchangeList_stories,
25763
- rewardExchange: rewardExchange$1,
25764
- rewardExchangeSelected: rewardExchangeSelected$1,
25765
- Default2: Default2
29374
+ Default: Default$b,
29375
+ Orangey: Orangey,
29376
+ Netflix: Netflix,
29377
+ SaaSquatchCorporate: SaaSquatchCorporate,
29378
+ NYTimes: NYTimes
25766
29379
  });
25767
29380
 
25768
29381
  function deepFreeze(obj) {
@@ -27235,7 +30848,7 @@ const seenDeprecations = {};
27235
30848
  /**
27236
30849
  * @param {string} message
27237
30850
  */
27238
- const error$1 = (message) => {
30851
+ const error$2 = (message) => {
27239
30852
  console.error(message);
27240
30853
  };
27241
30854
 
@@ -27735,7 +31348,7 @@ const HLJS = function(hljs) {
27735
31348
 
27736
31349
  const language = getLanguage(languageName);
27737
31350
  if (!language) {
27738
- error$1(LANGUAGE_NOT_FOUND.replace("{}", languageName));
31351
+ error$2(LANGUAGE_NOT_FOUND.replace("{}", languageName));
27739
31352
  throw new Error('Unknown language: "' + languageName + '"');
27740
31353
  }
27741
31354
 
@@ -28071,10 +31684,10 @@ const HLJS = function(hljs) {
28071
31684
  let lang = null;
28072
31685
  try {
28073
31686
  lang = languageDefinition(hljs);
28074
- } catch (error$1$1) {
28075
- error$1("Language definition for '{}' could not be registered.".replace("{}", languageName));
31687
+ } catch (error$1) {
31688
+ error$2("Language definition for '{}' could not be registered.".replace("{}", languageName));
28076
31689
  // hard or soft error
28077
- if (!SAFE_MODE) { throw error$1$1; } else { error$1(error$1$1); }
31690
+ if (!SAFE_MODE) { throw error$1; } else { error$2(error$1); }
28078
31691
  // languages that have serious errors are replaced with essentially a
28079
31692
  // "plaintext" stand-in so that the code blocks will still get normal
28080
31693
  // css classes applied to them - and one bad language won't break the
@@ -28384,7 +31997,7 @@ const stories = [
28384
31997
  ReferralTableRewardsCell$1,
28385
31998
  UserName,
28386
31999
  PasswordField,
28387
- TaskCard$1,
32000
+ TaskCard$2,
28388
32001
  PortalTemplates,
28389
32002
  ProgramMenu$1,
28390
32003
  PoweredByImg,
@@ -28395,7 +32008,7 @@ const stories = [
28395
32008
  RewardExchangeList,
28396
32009
  UseRewardExchangeList,
28397
32010
  UseTaskCard,
28398
- UseRewardsTable
32011
+ UseRewardsTable,
28399
32012
  ];
28400
32013
  const StencilStorybook = class {
28401
32014
  constructor(hostRef) {
@@ -28410,9 +32023,29 @@ const StencilStorybook = class {
28410
32023
  title: "Mint Components",
28411
32024
  addons: [CucumberAddon, ShadowViewAddon.ShadowViewAddon, HookStoryAddon],
28412
32025
  });
28413
- return (index.h(index.Host, { class: Style, onClick: {} }, children));
32026
+ const [selectedTheme, setSelected] = _extends.useState("Default");
32027
+ const [checkerboard, setCheckerboard] = _extends.useState(true);
32028
+ const themes = Object.keys(Themes);
32029
+ const theme = Themes[selectedTheme];
32030
+ return (index.h(index.Host, { class: Style, onClick: {} }, index.h("div", { style: {
32031
+ position: "absolute",
32032
+ top: "0",
32033
+ right: "0",
32034
+ zIndex: "999999",
32035
+ } }, "Branding:", index.h("select", { onChange: (e) => setSelected(e.target.value) }, themes.map((t) => (index.h("option", { selected: t === selectedTheme }, t)))), index.h("div", null, index.h("div", null)), index.h(ColorScale, null), index.h("br", null), index.h("input", { type: "checkbox", id: "checkerboard", onClick: () => setCheckerboard(!checkerboard), onChange: () => document.documentElement.style.setProperty("--checker-color-1", checkerboard ? "#ebebeb" : "#ffffff00") }), index.h("label", { htmlFor: "checkerboard" }, "Checkerboard?")), index.h("style", null, theme), index.h("style", null, ResizerStylesheet), children));
28414
32036
  }
28415
- };
32037
+ };
32038
+ function ColorScale() {
32039
+ return (index.h("span", null, index.h(ColorToken, null), index.h(ColorToken, { type: "success" }), index.h(ColorToken, { type: "warning" }), index.h(ColorToken, { type: "danger" }), index.h(ColorToken, { type: "neutral" })));
32040
+ }
32041
+ function ColorToken({ type = "primary" }) {
32042
+ return (index.h("span", { style: {
32043
+ background: `var(--sl-color-${type}-500)`,
32044
+ width: "1em",
32045
+ marginRight: "2px",
32046
+ padding: "0 4px",
32047
+ }, title: type }, type.charAt(0)));
32048
+ }
28416
32049
 
28417
32050
  const TableCell$1 = class {
28418
32051
  constructor(hostRef) {
@@ -28435,7 +32068,7 @@ const TableRow = class {
28435
32068
  }
28436
32069
  };
28437
32070
 
28438
- const TaskCard$2 = class {
32071
+ const TaskCard$3 = class {
28439
32072
  constructor(hostRef) {
28440
32073
  index.registerInstance(this, hostRef);
28441
32074
  this.ignored = true;
@@ -28459,6 +32092,10 @@ const TaskCard$2 = class {
28459
32092
  * @uiName Goal Repeatable
28460
32093
  */
28461
32094
  this.repeatable = false;
32095
+ /**
32096
+ * @uiName Repeat Amount (0 for no limit)
32097
+ */
32098
+ this.finite = 0;
28462
32099
  /**
28463
32100
  * @uiName Show Progress Bar
28464
32101
  */
@@ -28664,6 +32301,6 @@ exports.sqm_share_link = ShareLink;
28664
32301
  exports.sqm_stencilbook = StencilStorybook;
28665
32302
  exports.sqm_table_cell = TableCell$1;
28666
32303
  exports.sqm_table_row = TableRow;
28667
- exports.sqm_task_card = TaskCard$2;
32304
+ exports.sqm_task_card = TaskCard$3;
28668
32305
  exports.sqm_text = Text;
28669
32306
  exports.sqm_user_name = UserName$1;