@powerhousedao/service-offering 1.0.0-dev.4 → 1.0.0-dev.6

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 (235) hide show
  1. package/dist/document-models/facet/v1/actions.d.ts +3 -1
  2. package/dist/document-models/facet/v1/actions.d.ts.map +1 -1
  3. package/dist/document-models/facet/v1/gen/controller.d.ts +4 -0
  4. package/dist/document-models/facet/v1/gen/controller.d.ts.map +1 -0
  5. package/dist/document-models/facet/v1/gen/controller.js +3 -0
  6. package/dist/document-models/facet/v1/gen/document-model.d.ts.map +1 -1
  7. package/dist/document-models/facet/v1/gen/document-model.js +31 -7
  8. package/dist/document-models/facet/v1/gen/document-schema.d.ts +6 -6
  9. package/dist/document-models/facet/v1/gen/index.d.ts +1 -0
  10. package/dist/document-models/facet/v1/gen/index.d.ts.map +1 -1
  11. package/dist/document-models/facet/v1/gen/index.js +1 -0
  12. package/dist/document-models/facet/v1/gen/option-management/error.d.ts +27 -1
  13. package/dist/document-models/facet/v1/gen/option-management/error.d.ts.map +1 -1
  14. package/dist/document-models/facet/v1/gen/option-management/error.js +23 -1
  15. package/dist/document-models/facet/v1/gen/ph-factories.js +2 -2
  16. package/dist/document-models/facet/v1/gen/schema/types.d.ts +2 -2
  17. package/dist/document-models/facet/v1/gen/schema/types.d.ts.map +1 -1
  18. package/dist/document-models/facet/v1/gen/schema/zod.js +2 -2
  19. package/dist/document-models/facet/v1/gen/utils.js +2 -2
  20. package/dist/document-models/facet/v1/module.d.ts +1 -1
  21. package/dist/document-models/facet/v1/module.d.ts.map +1 -1
  22. package/dist/document-models/facet/v1/module.js +4 -1
  23. package/dist/document-models/resource-instance/v1/actions.d.ts +4 -1
  24. package/dist/document-models/resource-instance/v1/actions.d.ts.map +1 -1
  25. package/dist/document-models/resource-instance/v1/gen/configuration-management/error.d.ts +34 -1
  26. package/dist/document-models/resource-instance/v1/gen/configuration-management/error.d.ts.map +1 -1
  27. package/dist/document-models/resource-instance/v1/gen/configuration-management/error.js +32 -1
  28. package/dist/document-models/resource-instance/v1/gen/controller.d.ts +4 -0
  29. package/dist/document-models/resource-instance/v1/gen/controller.d.ts.map +1 -0
  30. package/dist/document-models/resource-instance/v1/gen/controller.js +3 -0
  31. package/dist/document-models/resource-instance/v1/gen/document-model.d.ts.map +1 -1
  32. package/dist/document-models/resource-instance/v1/gen/document-model.js +222 -70
  33. package/dist/document-models/resource-instance/v1/gen/document-schema.d.ts +0 -6
  34. package/dist/document-models/resource-instance/v1/gen/document-schema.d.ts.map +1 -1
  35. package/dist/document-models/resource-instance/v1/gen/index.d.ts +1 -0
  36. package/dist/document-models/resource-instance/v1/gen/index.d.ts.map +1 -1
  37. package/dist/document-models/resource-instance/v1/gen/index.js +1 -0
  38. package/dist/document-models/resource-instance/v1/gen/instance-management/actions.d.ts +6 -2
  39. package/dist/document-models/resource-instance/v1/gen/instance-management/actions.d.ts.map +1 -1
  40. package/dist/document-models/resource-instance/v1/gen/instance-management/creators.d.ts +3 -2
  41. package/dist/document-models/resource-instance/v1/gen/instance-management/creators.d.ts.map +1 -1
  42. package/dist/document-models/resource-instance/v1/gen/instance-management/creators.js +2 -1
  43. package/dist/document-models/resource-instance/v1/gen/instance-management/error.d.ts +98 -1
  44. package/dist/document-models/resource-instance/v1/gen/instance-management/error.d.ts.map +1 -1
  45. package/dist/document-models/resource-instance/v1/gen/instance-management/error.js +112 -1
  46. package/dist/document-models/resource-instance/v1/gen/instance-management/operations.d.ts +2 -1
  47. package/dist/document-models/resource-instance/v1/gen/instance-management/operations.d.ts.map +1 -1
  48. package/dist/document-models/resource-instance/v1/gen/ph-factories.d.ts.map +1 -1
  49. package/dist/document-models/resource-instance/v1/gen/ph-factories.js +0 -2
  50. package/dist/document-models/resource-instance/v1/gen/reducer.d.ts.map +1 -1
  51. package/dist/document-models/resource-instance/v1/gen/reducer.js +6 -1
  52. package/dist/document-models/resource-instance/v1/gen/schema/types.d.ts +3 -3
  53. package/dist/document-models/resource-instance/v1/gen/schema/types.d.ts.map +1 -1
  54. package/dist/document-models/resource-instance/v1/gen/schema/zod.d.ts +2 -1
  55. package/dist/document-models/resource-instance/v1/gen/schema/zod.d.ts.map +1 -1
  56. package/dist/document-models/resource-instance/v1/gen/schema/zod.js +5 -3
  57. package/dist/document-models/resource-instance/v1/gen/utils.d.ts.map +1 -1
  58. package/dist/document-models/resource-instance/v1/gen/utils.js +0 -2
  59. package/dist/document-models/resource-instance/v1/module.d.ts +1 -1
  60. package/dist/document-models/resource-instance/v1/module.d.ts.map +1 -1
  61. package/dist/document-models/resource-instance/v1/module.js +4 -1
  62. package/dist/document-models/resource-instance/v1/src/reducers/configuration-management.d.ts.map +1 -1
  63. package/dist/document-models/resource-instance/v1/src/reducers/configuration-management.js +57 -53
  64. package/dist/document-models/resource-instance/v1/src/reducers/instance-management.d.ts.map +1 -1
  65. package/dist/document-models/resource-instance/v1/src/reducers/instance-management.js +57 -21
  66. package/dist/document-models/resource-instance/v1/tests/instance-management.test.js +11 -1
  67. package/dist/document-models/resource-template/v1/actions.d.ts +3 -1
  68. package/dist/document-models/resource-template/v1/actions.d.ts.map +1 -1
  69. package/dist/document-models/resource-template/v1/gen/audience-management/error.d.ts +20 -1
  70. package/dist/document-models/resource-template/v1/gen/audience-management/error.d.ts.map +1 -1
  71. package/dist/document-models/resource-template/v1/gen/audience-management/error.js +16 -1
  72. package/dist/document-models/resource-template/v1/gen/controller.d.ts +4 -0
  73. package/dist/document-models/resource-template/v1/gen/controller.d.ts.map +1 -0
  74. package/dist/document-models/resource-template/v1/gen/controller.js +3 -0
  75. package/dist/document-models/resource-template/v1/gen/document-model.d.ts.map +1 -1
  76. package/dist/document-models/resource-template/v1/gen/document-model.js +207 -89
  77. package/dist/document-models/resource-template/v1/gen/document-schema.d.ts +12 -12
  78. package/dist/document-models/resource-template/v1/gen/facet-targeting/error.d.ts +27 -1
  79. package/dist/document-models/resource-template/v1/gen/facet-targeting/error.d.ts.map +1 -1
  80. package/dist/document-models/resource-template/v1/gen/facet-targeting/error.js +23 -1
  81. package/dist/document-models/resource-template/v1/gen/index.d.ts +1 -0
  82. package/dist/document-models/resource-template/v1/gen/index.d.ts.map +1 -1
  83. package/dist/document-models/resource-template/v1/gen/index.js +1 -0
  84. package/dist/document-models/resource-template/v1/gen/option-group-management/error.d.ts +27 -1
  85. package/dist/document-models/resource-template/v1/gen/option-group-management/error.d.ts.map +1 -1
  86. package/dist/document-models/resource-template/v1/gen/option-group-management/error.js +23 -1
  87. package/dist/document-models/resource-template/v1/gen/ph-factories.js +3 -3
  88. package/dist/document-models/resource-template/v1/gen/schema/types.d.ts +4 -4
  89. package/dist/document-models/resource-template/v1/gen/schema/types.d.ts.map +1 -1
  90. package/dist/document-models/resource-template/v1/gen/schema/zod.js +4 -4
  91. package/dist/document-models/resource-template/v1/gen/service-management/error.d.ts +51 -1
  92. package/dist/document-models/resource-template/v1/gen/service-management/error.d.ts.map +1 -1
  93. package/dist/document-models/resource-template/v1/gen/service-management/error.js +49 -1
  94. package/dist/document-models/resource-template/v1/gen/utils.js +3 -3
  95. package/dist/document-models/resource-template/v1/module.d.ts +1 -1
  96. package/dist/document-models/resource-template/v1/module.d.ts.map +1 -1
  97. package/dist/document-models/resource-template/v1/module.js +4 -1
  98. package/dist/document-models/resource-template/v1/src/reducers/option-group-management.d.ts.map +1 -1
  99. package/dist/document-models/resource-template/v1/src/reducers/option-group-management.js +2 -21
  100. package/dist/document-models/service-offering/v1/actions.d.ts +3 -1
  101. package/dist/document-models/service-offering/v1/actions.d.ts.map +1 -1
  102. package/dist/document-models/service-offering/v1/gen/controller.d.ts +4 -0
  103. package/dist/document-models/service-offering/v1/gen/controller.d.ts.map +1 -0
  104. package/dist/document-models/service-offering/v1/gen/controller.js +3 -0
  105. package/dist/document-models/service-offering/v1/gen/document-model.d.ts.map +1 -1
  106. package/dist/document-models/service-offering/v1/gen/document-model.js +421 -199
  107. package/dist/document-models/service-offering/v1/gen/document-schema.d.ts +9 -9
  108. package/dist/document-models/service-offering/v1/gen/index.d.ts +1 -0
  109. package/dist/document-models/service-offering/v1/gen/index.d.ts.map +1 -1
  110. package/dist/document-models/service-offering/v1/gen/index.js +1 -0
  111. package/dist/document-models/service-offering/v1/gen/offering/error.d.ts +41 -1
  112. package/dist/document-models/service-offering/v1/gen/offering/error.d.ts.map +1 -1
  113. package/dist/document-models/service-offering/v1/gen/offering/error.js +37 -1
  114. package/dist/document-models/service-offering/v1/gen/option-groups/error.d.ts +55 -1
  115. package/dist/document-models/service-offering/v1/gen/option-groups/error.d.ts.map +1 -1
  116. package/dist/document-models/service-offering/v1/gen/option-groups/error.js +53 -1
  117. package/dist/document-models/service-offering/v1/gen/ph-factories.js +3 -3
  118. package/dist/document-models/service-offering/v1/gen/schema/types.d.ts +134 -61
  119. package/dist/document-models/service-offering/v1/gen/schema/types.d.ts.map +1 -1
  120. package/dist/document-models/service-offering/v1/gen/schema/zod.d.ts +35 -10
  121. package/dist/document-models/service-offering/v1/gen/schema/zod.d.ts.map +1 -1
  122. package/dist/document-models/service-offering/v1/gen/schema/zod.js +182 -64
  123. package/dist/document-models/service-offering/v1/gen/services/error.d.ts +20 -1
  124. package/dist/document-models/service-offering/v1/gen/services/error.d.ts.map +1 -1
  125. package/dist/document-models/service-offering/v1/gen/services/error.js +16 -1
  126. package/dist/document-models/service-offering/v1/gen/tiers/error.d.ts +100 -1
  127. package/dist/document-models/service-offering/v1/gen/tiers/error.d.ts.map +1 -1
  128. package/dist/document-models/service-offering/v1/gen/tiers/error.js +106 -1
  129. package/dist/document-models/service-offering/v1/gen/utils.js +4 -4
  130. package/dist/document-models/service-offering/v1/module.d.ts +1 -1
  131. package/dist/document-models/service-offering/v1/module.d.ts.map +1 -1
  132. package/dist/document-models/service-offering/v1/module.js +4 -1
  133. package/dist/document-models/service-offering/v1/src/reducers/offering.d.ts.map +1 -1
  134. package/dist/document-models/service-offering/v1/src/reducers/offering.js +20 -12
  135. package/dist/document-models/service-offering/v1/src/reducers/option-groups.d.ts.map +1 -1
  136. package/dist/document-models/service-offering/v1/src/reducers/option-groups.js +157 -39
  137. package/dist/document-models/service-offering/v1/src/reducers/services.d.ts.map +1 -1
  138. package/dist/document-models/service-offering/v1/src/reducers/services.js +17 -14
  139. package/dist/document-models/service-offering/v1/src/reducers/tiers.d.ts.map +1 -1
  140. package/dist/document-models/service-offering/v1/src/reducers/tiers.js +111 -78
  141. package/dist/document-models/service-offering/v1/src/utils.d.ts +60 -1
  142. package/dist/document-models/service-offering/v1/src/utils.d.ts.map +1 -1
  143. package/dist/document-models/service-offering/v1/src/utils.js +173 -1
  144. package/dist/document-models/service-offering/v1/tests/option-groups.test.js +1 -1
  145. package/dist/document-models/service-offering/v1/utils.d.ts +3 -0
  146. package/dist/document-models/service-offering/v1/utils.d.ts.map +1 -1
  147. package/dist/document-models/subscription-instance/v1/actions.d.ts +3 -1
  148. package/dist/document-models/subscription-instance/v1/actions.d.ts.map +1 -1
  149. package/dist/document-models/subscription-instance/v1/gen/controller.d.ts +4 -0
  150. package/dist/document-models/subscription-instance/v1/gen/controller.d.ts.map +1 -0
  151. package/dist/document-models/subscription-instance/v1/gen/controller.js +3 -0
  152. package/dist/document-models/subscription-instance/v1/gen/document-model.d.ts.map +1 -1
  153. package/dist/document-models/subscription-instance/v1/gen/document-model.js +488 -246
  154. package/dist/document-models/subscription-instance/v1/gen/document-schema.d.ts +3 -3
  155. package/dist/document-models/subscription-instance/v1/gen/index.d.ts +1 -0
  156. package/dist/document-models/subscription-instance/v1/gen/index.d.ts.map +1 -1
  157. package/dist/document-models/subscription-instance/v1/gen/index.js +1 -0
  158. package/dist/document-models/subscription-instance/v1/gen/metrics/error.d.ts +73 -1
  159. package/dist/document-models/subscription-instance/v1/gen/metrics/error.d.ts.map +1 -1
  160. package/dist/document-models/subscription-instance/v1/gen/metrics/error.js +86 -1
  161. package/dist/document-models/subscription-instance/v1/gen/ph-factories.js +1 -1
  162. package/dist/document-models/subscription-instance/v1/gen/schema/types.d.ts +199 -82
  163. package/dist/document-models/subscription-instance/v1/gen/schema/types.d.ts.map +1 -1
  164. package/dist/document-models/subscription-instance/v1/gen/schema/zod.d.ts +22 -12
  165. package/dist/document-models/subscription-instance/v1/gen/schema/zod.d.ts.map +1 -1
  166. package/dist/document-models/subscription-instance/v1/gen/schema/zod.js +230 -84
  167. package/dist/document-models/subscription-instance/v1/gen/service/error.d.ts +62 -1
  168. package/dist/document-models/subscription-instance/v1/gen/service/error.d.ts.map +1 -1
  169. package/dist/document-models/subscription-instance/v1/gen/service/error.js +60 -1
  170. package/dist/document-models/subscription-instance/v1/gen/service-group/error.d.ts +39 -1
  171. package/dist/document-models/subscription-instance/v1/gen/service-group/error.d.ts.map +1 -1
  172. package/dist/document-models/subscription-instance/v1/gen/service-group/error.js +39 -1
  173. package/dist/document-models/subscription-instance/v1/gen/subscription/error.d.ts +55 -1
  174. package/dist/document-models/subscription-instance/v1/gen/subscription/error.d.ts.map +1 -1
  175. package/dist/document-models/subscription-instance/v1/gen/subscription/error.js +51 -1
  176. package/dist/document-models/subscription-instance/v1/gen/utils.js +2 -2
  177. package/dist/document-models/subscription-instance/v1/module.d.ts +1 -1
  178. package/dist/document-models/subscription-instance/v1/module.d.ts.map +1 -1
  179. package/dist/document-models/subscription-instance/v1/module.js +4 -1
  180. package/dist/document-models/subscription-instance/v1/src/reducers/customer.d.ts.map +1 -1
  181. package/dist/document-models/subscription-instance/v1/src/reducers/customer.js +1 -0
  182. package/dist/document-models/subscription-instance/v1/src/reducers/metrics.d.ts.map +1 -1
  183. package/dist/document-models/subscription-instance/v1/src/reducers/metrics.js +70 -45
  184. package/dist/document-models/subscription-instance/v1/src/reducers/service-group.d.ts.map +1 -1
  185. package/dist/document-models/subscription-instance/v1/src/reducers/service-group.js +108 -30
  186. package/dist/document-models/subscription-instance/v1/src/reducers/service.d.ts.map +1 -1
  187. package/dist/document-models/subscription-instance/v1/src/reducers/service.js +108 -39
  188. package/dist/document-models/subscription-instance/v1/src/reducers/subscription.d.ts.map +1 -1
  189. package/dist/document-models/subscription-instance/v1/src/reducers/subscription.js +193 -35
  190. package/dist/editors/resource-instance-editor/editor.d.ts.map +1 -1
  191. package/dist/editors/resource-instance-editor/editor.js +13 -3
  192. package/dist/editors/service-offering-editor/components/ResourceTemplateSelector.d.ts.map +1 -1
  193. package/dist/editors/service-offering-editor/components/ResourceTemplateSelector.js +4 -2
  194. package/dist/editors/service-offering-editor/components/ServiceCatalog.d.ts.map +1 -1
  195. package/dist/editors/service-offering-editor/components/ServiceCatalog.js +189 -32
  196. package/dist/editors/service-offering-editor/components/TheMatrix.d.ts +1 -1
  197. package/dist/editors/service-offering-editor/components/TheMatrix.d.ts.map +1 -1
  198. package/dist/editors/service-offering-editor/components/TheMatrix.js +295 -140
  199. package/dist/editors/service-offering-editor/components/TierDefinition.d.ts.map +1 -1
  200. package/dist/editors/service-offering-editor/components/TierDefinition.js +2 -0
  201. package/dist/editors/service-offering-editor/components/TierPricingOptionsPanel.js +3 -3
  202. package/dist/editors/service-offering-editor/components/pricing-utils.d.ts.map +1 -1
  203. package/dist/editors/service-offering-editor/components/pricing-utils.js +26 -7
  204. package/dist/editors/subscription-instance-editor/components/BillingPanel.d.ts.map +1 -1
  205. package/dist/editors/subscription-instance-editor/components/BillingPanel.js +4 -4
  206. package/dist/editors/subscription-instance-editor/components/CustomerInfo.d.ts.map +1 -1
  207. package/dist/editors/subscription-instance-editor/components/CustomerInfo.js +3 -2
  208. package/dist/editors/subscription-instance-editor/components/ImportServiceConfigButton.d.ts +3 -0
  209. package/dist/editors/subscription-instance-editor/components/ImportServiceConfigButton.d.ts.map +1 -1
  210. package/dist/editors/subscription-instance-editor/components/ImportServiceConfigButton.js +12 -0
  211. package/dist/editors/subscription-instance-editor/components/MetricActions.d.ts.map +1 -1
  212. package/dist/editors/subscription-instance-editor/components/MetricActions.js +4 -2
  213. package/dist/editors/subscription-instance-editor/components/MockDataButton.d.ts.map +1 -1
  214. package/dist/editors/subscription-instance-editor/components/MockDataButton.js +214 -2
  215. package/dist/editors/subscription-instance-editor/components/OperatorNotes.js +1 -1
  216. package/dist/editors/subscription-instance-editor/components/ServicesPanel.d.ts.map +1 -1
  217. package/dist/editors/subscription-instance-editor/components/ServicesPanel.js +9 -20
  218. package/dist/editors/subscription-instance-editor/components/SubscriptionActions.d.ts.map +1 -1
  219. package/dist/editors/subscription-instance-editor/components/SubscriptionActions.js +8 -9
  220. package/dist/editors/subscription-instance-editor/components/SubscriptionHeader.d.ts.map +1 -1
  221. package/dist/editors/subscription-instance-editor/components/SubscriptionHeader.js +1 -1
  222. package/dist/editors/subscription-instance-editor/components/billing-utils.d.ts +14 -6
  223. package/dist/editors/subscription-instance-editor/components/billing-utils.d.ts.map +1 -1
  224. package/dist/editors/subscription-instance-editor/components/billing-utils.js +19 -23
  225. package/dist/editors/subscription-instance-editor/components/mapOfferingToSubscription.d.ts +16 -2
  226. package/dist/editors/subscription-instance-editor/components/mapOfferingToSubscription.d.ts.map +1 -1
  227. package/dist/editors/subscription-instance-editor/components/mapOfferingToSubscription.js +155 -6
  228. package/dist/powerhouse.manifest.json +29 -3
  229. package/dist/style.css +14 -0
  230. package/dist/subgraphs/resources-services/resolvers.d.ts +1 -1
  231. package/dist/subgraphs/resources-services/resolvers.d.ts.map +1 -1
  232. package/dist/subgraphs/resources-services/resolvers.js +273 -158
  233. package/dist/subgraphs/resources-services/schema.d.ts.map +1 -1
  234. package/dist/subgraphs/resources-services/schema.js +107 -41
  235. package/package.json +22 -18
@@ -1 +1,60 @@
1
- export const errors = {};
1
+ export class RemoveServiceNotFoundError extends Error {
2
+ errorCode = "RemoveServiceNotFoundError";
3
+ constructor(message = "RemoveServiceNotFoundError") {
4
+ super(message);
5
+ }
6
+ }
7
+ export class UpdateServiceSetupCostNotFoundError extends Error {
8
+ errorCode = "UpdateServiceSetupCostNotFoundError";
9
+ constructor(message = "UpdateServiceSetupCostNotFoundError") {
10
+ super(message);
11
+ }
12
+ }
13
+ export class UpdateServiceRecurringCostNotFoundError extends Error {
14
+ errorCode = "UpdateServiceRecurringCostNotFoundError";
15
+ constructor(message = "UpdateServiceRecurringCostNotFoundError") {
16
+ super(message);
17
+ }
18
+ }
19
+ export class ReportSetupPaymentServiceNotFoundError extends Error {
20
+ errorCode = "ReportSetupPaymentServiceNotFoundError";
21
+ constructor(message = "ReportSetupPaymentServiceNotFoundError") {
22
+ super(message);
23
+ }
24
+ }
25
+ export class ReportRecurringPaymentServiceNotFoundError extends Error {
26
+ errorCode = "ReportRecurringPaymentServiceNotFoundError";
27
+ constructor(message = "ReportRecurringPaymentServiceNotFoundError") {
28
+ super(message);
29
+ }
30
+ }
31
+ export class UpdateServiceInfoNotFoundError extends Error {
32
+ errorCode = "UpdateServiceInfoNotFoundError";
33
+ constructor(message = "UpdateServiceInfoNotFoundError") {
34
+ super(message);
35
+ }
36
+ }
37
+ export class AddServiceFacetSelectionServiceNotFoundError extends Error {
38
+ errorCode = "AddServiceFacetSelectionServiceNotFoundError";
39
+ constructor(message = "AddServiceFacetSelectionServiceNotFoundError") {
40
+ super(message);
41
+ }
42
+ }
43
+ export class RemoveServiceFacetSelectionServiceNotFoundError extends Error {
44
+ errorCode = "RemoveServiceFacetSelectionServiceNotFoundError";
45
+ constructor(message = "RemoveServiceFacetSelectionServiceNotFoundError") {
46
+ super(message);
47
+ }
48
+ }
49
+ export const errors = {
50
+ RemoveService: { RemoveServiceNotFoundError },
51
+ UpdateServiceSetupCost: { UpdateServiceSetupCostNotFoundError },
52
+ UpdateServiceRecurringCost: { UpdateServiceRecurringCostNotFoundError },
53
+ ReportSetupPayment: { ReportSetupPaymentServiceNotFoundError },
54
+ ReportRecurringPayment: { ReportRecurringPaymentServiceNotFoundError },
55
+ UpdateServiceInfo: { UpdateServiceInfoNotFoundError },
56
+ AddServiceFacetSelection: { AddServiceFacetSelectionServiceNotFoundError },
57
+ RemoveServiceFacetSelection: {
58
+ RemoveServiceFacetSelectionServiceNotFoundError,
59
+ },
60
+ };
@@ -1,2 +1,40 @@
1
- export declare const errors: {};
1
+ export type ErrorCode = "RemoveServiceGroupNotFoundError" | "AddServiceToGroupGroupNotFoundError" | "RemoveServiceFromGroupGroupNotFoundError" | "RemoveServiceFromGroupServiceNotFoundError" | "UpdateServiceGroupCostNotFoundError";
2
+ export interface ReducerError {
3
+ errorCode: ErrorCode;
4
+ }
5
+ export declare class RemoveServiceGroupNotFoundError extends Error implements ReducerError {
6
+ errorCode: ErrorCode;
7
+ constructor(message?: string);
8
+ }
9
+ export declare class AddServiceToGroupGroupNotFoundError extends Error implements ReducerError {
10
+ errorCode: ErrorCode;
11
+ constructor(message?: string);
12
+ }
13
+ export declare class RemoveServiceFromGroupGroupNotFoundError extends Error implements ReducerError {
14
+ errorCode: ErrorCode;
15
+ constructor(message?: string);
16
+ }
17
+ export declare class RemoveServiceFromGroupServiceNotFoundError extends Error implements ReducerError {
18
+ errorCode: ErrorCode;
19
+ constructor(message?: string);
20
+ }
21
+ export declare class UpdateServiceGroupCostNotFoundError extends Error implements ReducerError {
22
+ errorCode: ErrorCode;
23
+ constructor(message?: string);
24
+ }
25
+ export declare const errors: {
26
+ RemoveServiceGroup: {
27
+ RemoveServiceGroupNotFoundError: typeof RemoveServiceGroupNotFoundError;
28
+ };
29
+ AddServiceToGroup: {
30
+ AddServiceToGroupGroupNotFoundError: typeof AddServiceToGroupGroupNotFoundError;
31
+ };
32
+ RemoveServiceFromGroup: {
33
+ RemoveServiceFromGroupGroupNotFoundError: typeof RemoveServiceFromGroupGroupNotFoundError;
34
+ RemoveServiceFromGroupServiceNotFoundError: typeof RemoveServiceFromGroupServiceNotFoundError;
35
+ };
36
+ UpdateServiceGroupCost: {
37
+ UpdateServiceGroupCostNotFoundError: typeof UpdateServiceGroupCostNotFoundError;
38
+ };
39
+ };
2
40
  //# sourceMappingURL=error.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/gen/service-group/error.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM,IAAK,CAAC"}
1
+ {"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/gen/service-group/error.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GACjB,iCAAiC,GACjC,qCAAqC,GACrC,0CAA0C,GAC1C,4CAA4C,GAC5C,qCAAqC,CAAC;AAE1C,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,qBAAa,+BACX,SAAQ,KACR,YAAW,YAAY;IAEvB,SAAS,EAAwC,SAAS,CAAC;gBAC/C,OAAO,SAAoC;CAGxD;AAED,qBAAa,mCACX,SAAQ,KACR,YAAW,YAAY;IAEvB,SAAS,EAA4C,SAAS,CAAC;gBACnD,OAAO,SAAwC;CAG5D;AAED,qBAAa,wCACX,SAAQ,KACR,YAAW,YAAY;IAEvB,SAAS,EAAiD,SAAS,CAAC;gBACxD,OAAO,SAA6C;CAGjE;AAED,qBAAa,0CACX,SAAQ,KACR,YAAW,YAAY;IAEvB,SAAS,EAAmD,SAAS,CAAC;gBAC1D,OAAO,SAA+C;CAGnE;AAED,qBAAa,mCACX,SAAQ,KACR,YAAW,YAAY;IAEvB,SAAS,EAA4C,SAAS,CAAC;gBACnD,OAAO,SAAwC;CAG5D;AAED,eAAO,MAAM,MAAM;;;;;;;;;;;;;;CAQlB,CAAC"}
@@ -1 +1,39 @@
1
- export const errors = {};
1
+ export class RemoveServiceGroupNotFoundError extends Error {
2
+ errorCode = "RemoveServiceGroupNotFoundError";
3
+ constructor(message = "RemoveServiceGroupNotFoundError") {
4
+ super(message);
5
+ }
6
+ }
7
+ export class AddServiceToGroupGroupNotFoundError extends Error {
8
+ errorCode = "AddServiceToGroupGroupNotFoundError";
9
+ constructor(message = "AddServiceToGroupGroupNotFoundError") {
10
+ super(message);
11
+ }
12
+ }
13
+ export class RemoveServiceFromGroupGroupNotFoundError extends Error {
14
+ errorCode = "RemoveServiceFromGroupGroupNotFoundError";
15
+ constructor(message = "RemoveServiceFromGroupGroupNotFoundError") {
16
+ super(message);
17
+ }
18
+ }
19
+ export class RemoveServiceFromGroupServiceNotFoundError extends Error {
20
+ errorCode = "RemoveServiceFromGroupServiceNotFoundError";
21
+ constructor(message = "RemoveServiceFromGroupServiceNotFoundError") {
22
+ super(message);
23
+ }
24
+ }
25
+ export class UpdateServiceGroupCostNotFoundError extends Error {
26
+ errorCode = "UpdateServiceGroupCostNotFoundError";
27
+ constructor(message = "UpdateServiceGroupCostNotFoundError") {
28
+ super(message);
29
+ }
30
+ }
31
+ export const errors = {
32
+ RemoveServiceGroup: { RemoveServiceGroupNotFoundError },
33
+ AddServiceToGroup: { AddServiceToGroupGroupNotFoundError },
34
+ RemoveServiceFromGroup: {
35
+ RemoveServiceFromGroupGroupNotFoundError,
36
+ RemoveServiceFromGroupServiceNotFoundError,
37
+ },
38
+ UpdateServiceGroupCost: { UpdateServiceGroupCostNotFoundError },
39
+ };
@@ -1,2 +1,56 @@
1
- export declare const errors: {};
1
+ export type ErrorCode = "ActivateNotPendingError" | "PauseNotActiveError" | "SetExpiringNotActiveError" | "CancelAlreadyCancelledError" | "ResumeNotPausedError" | "RenewNotExpiringError" | "RemoveBudgetNotFoundError";
2
+ export interface ReducerError {
3
+ errorCode: ErrorCode;
4
+ }
5
+ export declare class ActivateNotPendingError extends Error implements ReducerError {
6
+ errorCode: ErrorCode;
7
+ constructor(message?: string);
8
+ }
9
+ export declare class PauseNotActiveError extends Error implements ReducerError {
10
+ errorCode: ErrorCode;
11
+ constructor(message?: string);
12
+ }
13
+ export declare class SetExpiringNotActiveError extends Error implements ReducerError {
14
+ errorCode: ErrorCode;
15
+ constructor(message?: string);
16
+ }
17
+ export declare class CancelAlreadyCancelledError extends Error implements ReducerError {
18
+ errorCode: ErrorCode;
19
+ constructor(message?: string);
20
+ }
21
+ export declare class ResumeNotPausedError extends Error implements ReducerError {
22
+ errorCode: ErrorCode;
23
+ constructor(message?: string);
24
+ }
25
+ export declare class RenewNotExpiringError extends Error implements ReducerError {
26
+ errorCode: ErrorCode;
27
+ constructor(message?: string);
28
+ }
29
+ export declare class RemoveBudgetNotFoundError extends Error implements ReducerError {
30
+ errorCode: ErrorCode;
31
+ constructor(message?: string);
32
+ }
33
+ export declare const errors: {
34
+ ActivateSubscription: {
35
+ ActivateNotPendingError: typeof ActivateNotPendingError;
36
+ };
37
+ PauseSubscription: {
38
+ PauseNotActiveError: typeof PauseNotActiveError;
39
+ };
40
+ SetExpiring: {
41
+ SetExpiringNotActiveError: typeof SetExpiringNotActiveError;
42
+ };
43
+ CancelSubscription: {
44
+ CancelAlreadyCancelledError: typeof CancelAlreadyCancelledError;
45
+ };
46
+ ResumeSubscription: {
47
+ ResumeNotPausedError: typeof ResumeNotPausedError;
48
+ };
49
+ RenewExpiringSubscription: {
50
+ RenewNotExpiringError: typeof RenewNotExpiringError;
51
+ };
52
+ RemoveBudgetCategory: {
53
+ RemoveBudgetNotFoundError: typeof RemoveBudgetNotFoundError;
54
+ };
55
+ };
2
56
  //# sourceMappingURL=error.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/gen/subscription/error.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,MAAM,IAAK,CAAC"}
1
+ {"version":3,"file":"error.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/gen/subscription/error.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,SAAS,GACjB,yBAAyB,GACzB,qBAAqB,GACrB,2BAA2B,GAC3B,6BAA6B,GAC7B,sBAAsB,GACtB,uBAAuB,GACvB,2BAA2B,CAAC;AAEhC,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,SAAS,CAAC;CACtB;AAED,qBAAa,uBAAwB,SAAQ,KAAM,YAAW,YAAY;IACxE,SAAS,EAAgC,SAAS,CAAC;gBACvC,OAAO,SAA4B;CAGhD;AAED,qBAAa,mBAAoB,SAAQ,KAAM,YAAW,YAAY;IACpE,SAAS,EAA4B,SAAS,CAAC;gBACnC,OAAO,SAAwB;CAG5C;AAED,qBAAa,yBAA0B,SAAQ,KAAM,YAAW,YAAY;IAC1E,SAAS,EAAkC,SAAS,CAAC;gBACzC,OAAO,SAA8B;CAGlD;AAED,qBAAa,2BAA4B,SAAQ,KAAM,YAAW,YAAY;IAC5E,SAAS,EAAoC,SAAS,CAAC;gBAC3C,OAAO,SAAgC;CAGpD;AAED,qBAAa,oBAAqB,SAAQ,KAAM,YAAW,YAAY;IACrE,SAAS,EAA6B,SAAS,CAAC;gBACpC,OAAO,SAAyB;CAG7C;AAED,qBAAa,qBAAsB,SAAQ,KAAM,YAAW,YAAY;IACtE,SAAS,EAA8B,SAAS,CAAC;gBACrC,OAAO,SAA0B;CAG9C;AAED,qBAAa,yBAA0B,SAAQ,KAAM,YAAW,YAAY;IAC1E,SAAS,EAAkC,SAAS,CAAC;gBACzC,OAAO,SAA8B;CAGlD;AAED,eAAO,MAAM,MAAM;;;;;;;;;;;;;;;;;;;;;;CAQlB,CAAC"}
@@ -1 +1,51 @@
1
- export const errors = {};
1
+ export class ActivateNotPendingError extends Error {
2
+ errorCode = "ActivateNotPendingError";
3
+ constructor(message = "ActivateNotPendingError") {
4
+ super(message);
5
+ }
6
+ }
7
+ export class PauseNotActiveError extends Error {
8
+ errorCode = "PauseNotActiveError";
9
+ constructor(message = "PauseNotActiveError") {
10
+ super(message);
11
+ }
12
+ }
13
+ export class SetExpiringNotActiveError extends Error {
14
+ errorCode = "SetExpiringNotActiveError";
15
+ constructor(message = "SetExpiringNotActiveError") {
16
+ super(message);
17
+ }
18
+ }
19
+ export class CancelAlreadyCancelledError extends Error {
20
+ errorCode = "CancelAlreadyCancelledError";
21
+ constructor(message = "CancelAlreadyCancelledError") {
22
+ super(message);
23
+ }
24
+ }
25
+ export class ResumeNotPausedError extends Error {
26
+ errorCode = "ResumeNotPausedError";
27
+ constructor(message = "ResumeNotPausedError") {
28
+ super(message);
29
+ }
30
+ }
31
+ export class RenewNotExpiringError extends Error {
32
+ errorCode = "RenewNotExpiringError";
33
+ constructor(message = "RenewNotExpiringError") {
34
+ super(message);
35
+ }
36
+ }
37
+ export class RemoveBudgetNotFoundError extends Error {
38
+ errorCode = "RemoveBudgetNotFoundError";
39
+ constructor(message = "RemoveBudgetNotFoundError") {
40
+ super(message);
41
+ }
42
+ }
43
+ export const errors = {
44
+ ActivateSubscription: { ActivateNotPendingError },
45
+ PauseSubscription: { PauseNotActiveError },
46
+ SetExpiring: { SetExpiringNotActiveError },
47
+ CancelSubscription: { CancelAlreadyCancelledError },
48
+ ResumeSubscription: { ResumeNotPausedError },
49
+ RenewExpiringSubscription: { RenewNotExpiringError },
50
+ RemoveBudgetCategory: { RemoveBudgetNotFoundError },
51
+ };
@@ -18,7 +18,7 @@ export const initialGlobalState = {
18
18
  selectedBillingCycle: null,
19
19
  globalCurrency: null,
20
20
  resource: null,
21
- status: "DRAFT",
21
+ status: "PENDING",
22
22
  createdAt: null,
23
23
  activatedSince: null,
24
24
  pausedSince: null,
@@ -37,7 +37,7 @@ export const initialGlobalState = {
37
37
  };
38
38
  export const initialLocalState = {};
39
39
  export const utils = {
40
- fileExtension: "phsi",
40
+ fileExtension: "",
41
41
  createState(state) {
42
42
  return {
43
43
  ...defaultBaseState(),
@@ -1,5 +1,5 @@
1
1
  import type { DocumentModelModule } from "document-model";
2
- import type { SubscriptionInstancePHState } from "@powerhousedao/service-offering/document-models/subscription-instance/v1";
2
+ import type { SubscriptionInstancePHState } from "./gen/types.js";
3
3
  /** Document model module for the SubscriptionInstance document type */
4
4
  export declare const SubscriptionInstance: DocumentModelModule<SubscriptionInstancePHState>;
5
5
  //# sourceMappingURL=module.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../../document-models/subscription-instance/v1/module.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,0EAA0E,CAAC;AAQ5H,uEAAuE;AACvE,eAAO,MAAM,oBAAoB,EAAE,mBAAmB,CAAC,2BAA2B,CAO/E,CAAC"}
1
+ {"version":3,"file":"module.d.ts","sourceRoot":"","sources":["../../../../document-models/subscription-instance/v1/module.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAG1D,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,gBAAgB,CAAC;AAMlE,uEAAuE;AACvE,eAAO,MAAM,oBAAoB,EAAE,mBAAmB,CAAC,2BAA2B,CAO/E,CAAC"}
@@ -1,6 +1,9 @@
1
1
  import { createState } from "document-model";
2
2
  import { defaultBaseState } from "document-model/core";
3
- import { actions, documentModel, reducer, utils, } from "@powerhousedao/service-offering/document-models/subscription-instance/v1";
3
+ import { documentModel } from "./gen/document-model.js";
4
+ import { reducer } from "./gen/reducer.js";
5
+ import { actions } from "./actions.js";
6
+ import { utils } from "./utils.js";
4
7
  /** Document model module for the SubscriptionInstance document type */
5
8
  export const SubscriptionInstance = {
6
9
  version: 1,
@@ -1 +1 @@
1
- {"version":3,"file":"customer.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/customer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sCAAsC,EAAE,MAAM,0EAA0E,CAAC;AAEvI,eAAO,MAAM,sCAAsC,EAAE,sCAQlD,CAAC"}
1
+ {"version":3,"file":"customer.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/customer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,sCAAsC,EAAE,MAAM,0EAA0E,CAAC;AAEvI,eAAO,MAAM,sCAAsC,EAAE,sCASlD,CAAC"}
@@ -1,6 +1,7 @@
1
1
  export const subscriptionInstanceCustomerOperations = {
2
2
  setCustomerTypeOperation(state, action) {
3
3
  state.customerType = action.input.customerType;
4
+ state.teamMemberCount = action.input.teamMemberCount || null;
4
5
  },
5
6
  updateTeamMemberCountOperation(state, action) {
6
7
  state.teamMemberCount = action.input.teamMemberCount;
@@ -1 +1 @@
1
- {"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qCAAqC,EAAE,MAAM,0EAA0E,CAAC;AAEtI,eAAO,MAAM,qCAAqC,EAAE,qCAyEjD,CAAC"}
1
+ {"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/metrics.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qCAAqC,EAAE,MAAM,0EAA0E,CAAC;AAetI,eAAO,MAAM,qCAAqC,EAAE,qCAsHjD,CAAC"}
@@ -1,71 +1,96 @@
1
+ import { AddServiceMetricServiceNotFoundError, UpdateMetricServiceNotFoundError, UpdateMetricNotFoundError, UpdateMetricUsageServiceNotFoundError, UpdateMetricUsageNotFoundError, RemoveServiceMetricServiceNotFoundError, RemoveServiceMetricNotFoundError, IncrementMetricUsageServiceNotFoundError, IncrementMetricUsageNotFoundError, DecrementMetricUsageServiceNotFoundError, DecrementMetricUsageNotFoundError, } from "../../gen/metrics/error.js";
1
2
  export const subscriptionInstanceMetricsOperations = {
2
3
  addServiceMetricOperation(state, action) {
3
4
  const svc = state.services.find((s) => s.id === action.input.serviceId);
4
- if (svc) {
5
- svc.metrics.push({
6
- id: action.input.id,
7
- name: action.input.name,
8
- unitName: action.input.unitName || null,
9
- limit: action.input.limit ?? null,
10
- freeLimit: action.input.freeLimit ?? null,
11
- paidLimit: action.input.paidLimit ?? null,
12
- unitCost: action.input.unitCost ?? null,
13
- currentUsage: 0,
14
- usageResetPeriod: action.input.usageResetPeriod || null,
15
- nextUsageReset: action.input.nextUsageReset || null,
16
- });
5
+ if (!svc) {
6
+ throw new AddServiceMetricServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
17
7
  }
8
+ svc.metrics.push({
9
+ id: action.input.metricId,
10
+ name: action.input.name,
11
+ unitName: action.input.unitName,
12
+ limit: action.input.limit || null,
13
+ freeLimit: action.input.freeLimit || null,
14
+ paidLimit: action.input.paidLimit || null,
15
+ unitCost: action.input.unitCostAmount &&
16
+ action.input.unitCostCurrency &&
17
+ action.input.unitCostBillingCycle
18
+ ? {
19
+ amount: action.input.unitCostAmount,
20
+ currency: action.input.unitCostCurrency,
21
+ billingCycle: action.input.unitCostBillingCycle,
22
+ nextBillingDate: action.input.unitCostNextBillingDate || null,
23
+ lastPaymentDate: action.input.unitCostLastPaymentDate || null,
24
+ discount: null,
25
+ }
26
+ : null,
27
+ currentUsage: action.input.currentUsage,
28
+ usageResetPeriod: action.input.usageResetPeriod || null,
29
+ nextUsageReset: action.input.nextUsageReset || null,
30
+ });
18
31
  },
19
32
  updateMetricOperation(state, action) {
20
33
  const svc = state.services.find((s) => s.id === action.input.serviceId);
21
- const metric = svc?.metrics.find((m) => m.id === action.input.metricId);
22
- if (metric) {
23
- if (action.input.name !== undefined)
24
- metric.name = action.input.name ?? metric.name;
25
- if (action.input.unitName !== undefined)
26
- metric.unitName = action.input.unitName ?? null;
27
- if (action.input.limit !== undefined)
28
- metric.limit = action.input.limit ?? null;
29
- if (action.input.freeLimit !== undefined)
30
- metric.freeLimit = action.input.freeLimit ?? null;
31
- if (action.input.paidLimit !== undefined)
32
- metric.paidLimit = action.input.paidLimit ?? null;
33
- if (action.input.unitCost !== undefined)
34
- metric.unitCost = action.input.unitCost ?? null;
35
- if (action.input.usageResetPeriod !== undefined)
36
- metric.usageResetPeriod = action.input.usageResetPeriod ?? null;
37
- if (action.input.nextUsageReset !== undefined)
38
- metric.nextUsageReset = action.input.nextUsageReset ?? null;
34
+ if (!svc) {
35
+ throw new UpdateMetricServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
39
36
  }
37
+ const metric = svc.metrics.find((m) => m.id === action.input.metricId);
38
+ if (!metric) {
39
+ throw new UpdateMetricNotFoundError(`Metric with ID ${action.input.metricId} not found`);
40
+ }
41
+ if (action.input.name)
42
+ metric.name = action.input.name;
43
+ if (action.input.unitName)
44
+ metric.unitName = action.input.unitName;
45
+ if (action.input.limit !== undefined)
46
+ metric.limit = action.input.limit || null;
47
+ if (action.input.usageResetPeriod !== undefined)
48
+ metric.usageResetPeriod = action.input.usageResetPeriod || null;
49
+ if (action.input.nextUsageReset !== undefined)
50
+ metric.nextUsageReset = action.input.nextUsageReset || null;
40
51
  },
41
52
  updateMetricUsageOperation(state, action) {
42
53
  const svc = state.services.find((s) => s.id === action.input.serviceId);
43
- const metric = svc?.metrics.find((m) => m.id === action.input.metricId);
44
- if (metric) {
45
- metric.currentUsage = action.input.currentUsage;
54
+ if (!svc) {
55
+ throw new UpdateMetricUsageServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
56
+ }
57
+ const metric = svc.metrics.find((m) => m.id === action.input.metricId);
58
+ if (!metric) {
59
+ throw new UpdateMetricUsageNotFoundError(`Metric with ID ${action.input.metricId} not found`);
46
60
  }
61
+ metric.currentUsage = action.input.currentUsage;
47
62
  },
48
63
  removeServiceMetricOperation(state, action) {
49
64
  const svc = state.services.find((s) => s.id === action.input.serviceId);
50
- if (svc) {
51
- const index = svc.metrics.findIndex((m) => m.id === action.input.metricId);
52
- if (index !== -1) {
53
- svc.metrics.splice(index, 1);
54
- }
65
+ if (!svc) {
66
+ throw new RemoveServiceMetricServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
67
+ }
68
+ const index = svc.metrics.findIndex((m) => m.id === action.input.metricId);
69
+ if (index === -1) {
70
+ throw new RemoveServiceMetricNotFoundError(`Metric with ID ${action.input.metricId} not found`);
55
71
  }
72
+ svc.metrics.splice(index, 1);
56
73
  },
57
74
  incrementMetricUsageOperation(state, action) {
58
75
  const svc = state.services.find((s) => s.id === action.input.serviceId);
59
- const metric = svc?.metrics.find((m) => m.id === action.input.metricId);
60
- if (metric) {
61
- metric.currentUsage += action.input.amount;
76
+ if (!svc) {
77
+ throw new IncrementMetricUsageServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
62
78
  }
79
+ const metric = svc.metrics.find((m) => m.id === action.input.metricId);
80
+ if (!metric) {
81
+ throw new IncrementMetricUsageNotFoundError(`Metric with ID ${action.input.metricId} not found`);
82
+ }
83
+ metric.currentUsage += action.input.incrementBy;
63
84
  },
64
85
  decrementMetricUsageOperation(state, action) {
65
86
  const svc = state.services.find((s) => s.id === action.input.serviceId);
66
- const metric = svc?.metrics.find((m) => m.id === action.input.metricId);
67
- if (metric) {
68
- metric.currentUsage -= action.input.amount;
87
+ if (!svc) {
88
+ throw new DecrementMetricUsageServiceNotFoundError(`Service with ID ${action.input.serviceId} not found`);
89
+ }
90
+ const metric = svc.metrics.find((m) => m.id === action.input.metricId);
91
+ if (!metric) {
92
+ throw new DecrementMetricUsageNotFoundError(`Metric with ID ${action.input.metricId} not found`);
69
93
  }
94
+ metric.currentUsage -= action.input.decrementBy;
70
95
  },
71
96
  };
@@ -1 +1 @@
1
- {"version":3,"file":"service-group.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/service-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0CAA0C,EAAE,MAAM,0EAA0E,CAAC;AAE3I,eAAO,MAAM,0CAA0C,EAAE,0CA8DtD,CAAC"}
1
+ {"version":3,"file":"service-group.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/service-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,0CAA0C,EAAE,MAAM,0EAA0E,CAAC;AAS3I,eAAO,MAAM,0CAA0C,EAAE,0CA8JtD,CAAC"}
@@ -1,55 +1,133 @@
1
+ import { RemoveServiceGroupNotFoundError, AddServiceToGroupGroupNotFoundError, RemoveServiceFromGroupGroupNotFoundError, RemoveServiceFromGroupServiceNotFoundError, UpdateServiceGroupCostNotFoundError, } from "../../gen/service-group/error.js";
1
2
  export const subscriptionInstanceServiceGroupOperations = {
2
3
  addServiceGroupOperation(state, action) {
3
4
  state.serviceGroups.push({
4
- id: action.input.id,
5
+ id: action.input.groupId,
5
6
  name: action.input.name,
6
7
  optional: action.input.optional,
7
8
  costType: action.input.costType || null,
8
- setupCost: null,
9
- recurringCost: null,
9
+ setupCost: action.input.setupAmount && action.input.setupCurrency
10
+ ? {
11
+ amount: action.input.setupAmount,
12
+ currency: action.input.setupCurrency,
13
+ billingDate: action.input.setupBillingDate || null,
14
+ paymentDate: null,
15
+ }
16
+ : null,
17
+ recurringCost: action.input.recurringAmount &&
18
+ action.input.recurringCurrency &&
19
+ action.input.recurringBillingCycle
20
+ ? {
21
+ amount: action.input.recurringAmount,
22
+ currency: action.input.recurringCurrency,
23
+ billingCycle: action.input.recurringBillingCycle,
24
+ nextBillingDate: null,
25
+ lastPaymentDate: null,
26
+ discount: action.input.recurringDiscount
27
+ ? {
28
+ originalAmount: action.input.recurringDiscount.originalAmount,
29
+ discountType: action.input.recurringDiscount.discountType,
30
+ discountValue: action.input.recurringDiscount.discountValue,
31
+ source: action.input.recurringDiscount.source,
32
+ }
33
+ : null,
34
+ }
35
+ : null,
10
36
  services: [],
11
37
  });
12
38
  },
13
39
  removeServiceGroupOperation(state, action) {
14
- const index = state.serviceGroups.findIndex((g) => g.id === action.input.id);
15
- if (index !== -1) {
16
- state.serviceGroups.splice(index, 1);
40
+ const index = state.serviceGroups.findIndex((g) => g.id === action.input.groupId);
41
+ if (index === -1) {
42
+ throw new RemoveServiceGroupNotFoundError(`Service group with ID ${action.input.groupId} not found`);
17
43
  }
44
+ state.serviceGroups.splice(index, 1);
18
45
  },
19
46
  addServiceToGroupOperation(state, action) {
20
47
  const group = state.serviceGroups.find((g) => g.id === action.input.groupId);
21
- if (group && !group.services.includes(action.input.serviceId)) {
22
- group.services.push(action.input.serviceId);
48
+ if (!group) {
49
+ throw new AddServiceToGroupGroupNotFoundError(`Service group with ID ${action.input.groupId} not found`);
23
50
  }
51
+ group.services.push({
52
+ id: action.input.serviceId,
53
+ name: action.input.name || null,
54
+ description: action.input.description || null,
55
+ customValue: action.input.customValue || null,
56
+ facetSelections: [],
57
+ setupCost: action.input.setupAmount && action.input.setupCurrency
58
+ ? {
59
+ amount: action.input.setupAmount,
60
+ currency: action.input.setupCurrency,
61
+ billingDate: action.input.setupBillingDate || null,
62
+ paymentDate: action.input.setupPaymentDate || null,
63
+ }
64
+ : null,
65
+ recurringCost: action.input.recurringAmount &&
66
+ action.input.recurringCurrency &&
67
+ action.input.recurringBillingCycle
68
+ ? {
69
+ amount: action.input.recurringAmount,
70
+ currency: action.input.recurringCurrency,
71
+ billingCycle: action.input.recurringBillingCycle,
72
+ nextBillingDate: action.input.recurringNextBillingDate || null,
73
+ lastPaymentDate: action.input.recurringLastPaymentDate || null,
74
+ discount: null,
75
+ }
76
+ : null,
77
+ metrics: [],
78
+ });
24
79
  },
25
80
  removeServiceFromGroupOperation(state, action) {
26
81
  const group = state.serviceGroups.find((g) => g.id === action.input.groupId);
27
- if (group) {
28
- const index = group.services.indexOf(action.input.serviceId);
29
- if (index !== -1) {
30
- group.services.splice(index, 1);
31
- }
82
+ if (!group) {
83
+ throw new RemoveServiceFromGroupGroupNotFoundError(`Service group with ID ${action.input.groupId} not found`);
84
+ }
85
+ const index = group.services.findIndex((s) => s.id === action.input.serviceId);
86
+ if (index === -1) {
87
+ throw new RemoveServiceFromGroupServiceNotFoundError(`Service with ID ${action.input.serviceId} not found in group ${action.input.groupId}`);
32
88
  }
89
+ group.services.splice(index, 1);
33
90
  },
34
91
  updateServiceGroupCostOperation(state, action) {
35
92
  const group = state.serviceGroups.find((g) => g.id === action.input.groupId);
36
- if (group) {
37
- if (action.input.costType === "SETUP") {
38
- group.setupCost = {
39
- amount: action.input.amount,
40
- currency: action.input.currency,
41
- paidAmount: group.setupCost?.paidAmount ?? null,
42
- paidAt: group.setupCost?.paidAt ?? null,
43
- };
44
- }
45
- else {
46
- group.recurringCost = {
47
- amount: action.input.amount,
48
- currency: action.input.currency,
49
- paidAmount: group.recurringCost?.paidAmount ?? null,
50
- paidAt: group.recurringCost?.paidAt ?? null,
51
- };
52
- }
93
+ if (!group) {
94
+ throw new UpdateServiceGroupCostNotFoundError(`Service group with ID ${action.input.groupId} not found`);
95
+ }
96
+ if (action.input.setupAmount && action.input.setupCurrency) {
97
+ group.setupCost = {
98
+ amount: action.input.setupAmount,
99
+ currency: action.input.setupCurrency,
100
+ billingDate: action.input.setupBillingDate || null,
101
+ paymentDate: group.setupCost?.paymentDate || null,
102
+ };
103
+ }
104
+ else if (group.setupCost) {
105
+ if (action.input.setupAmount)
106
+ group.setupCost.amount = action.input.setupAmount;
107
+ if (action.input.setupCurrency)
108
+ group.setupCost.currency = action.input.setupCurrency;
109
+ if (action.input.setupBillingDate !== undefined)
110
+ group.setupCost.billingDate = action.input.setupBillingDate || null;
111
+ }
112
+ if (action.input.recurringAmount &&
113
+ action.input.recurringCurrency &&
114
+ action.input.recurringBillingCycle) {
115
+ group.recurringCost = {
116
+ amount: action.input.recurringAmount,
117
+ currency: action.input.recurringCurrency,
118
+ billingCycle: action.input.recurringBillingCycle,
119
+ nextBillingDate: group.recurringCost?.nextBillingDate || null,
120
+ lastPaymentDate: group.recurringCost?.lastPaymentDate || null,
121
+ discount: group.recurringCost?.discount || null,
122
+ };
123
+ }
124
+ else if (group.recurringCost) {
125
+ if (action.input.recurringAmount)
126
+ group.recurringCost.amount = action.input.recurringAmount;
127
+ if (action.input.recurringCurrency)
128
+ group.recurringCost.currency = action.input.recurringCurrency;
129
+ if (action.input.recurringBillingCycle)
130
+ group.recurringCost.billingCycle = action.input.recurringBillingCycle;
53
131
  }
54
132
  },
55
133
  };
@@ -1 +1 @@
1
- {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qCAAqC,EAAE,MAAM,0EAA0E,CAAC;AAEtI,eAAO,MAAM,qCAAqC,EAAE,qCAwFjD,CAAC"}
1
+ {"version":3,"file":"service.d.ts","sourceRoot":"","sources":["../../../../../../document-models/subscription-instance/v1/src/reducers/service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qCAAqC,EAAE,MAAM,0EAA0E,CAAC;AAYtI,eAAO,MAAM,qCAAqC,EAAE,qCA+KjD,CAAC"}