@widergy/utilitygo-smart-bill-web 1.10.0 → 1.12.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (141) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/dist/components/Advice/index.js +6 -10
  3. package/dist/components/Amount/index.js +21 -26
  4. package/dist/components/Amount/utils.js +5 -1
  5. package/dist/components/Banner/index.js +6 -10
  6. package/dist/components/BarChart/constants.js +3 -3
  7. package/dist/components/BarChart/index.js +25 -28
  8. package/dist/components/BarChart/utils.js +15 -15
  9. package/dist/components/BillCalculation/components/ConceptCard/index.js +48 -47
  10. package/dist/components/BillCalculation/constants.js +1 -1
  11. package/dist/components/BillCalculation/index.js +54 -44
  12. package/dist/components/BillCalculation/utils.js +14 -17
  13. package/dist/components/BillSummary/components/BilledConcepts/components/Concept/index.js +25 -26
  14. package/dist/components/BillSummary/components/BilledConcepts/components/PieChartContainer/constants.js +9 -3
  15. package/dist/components/BillSummary/components/BilledConcepts/components/PieChartContainer/index.js +31 -34
  16. package/dist/components/BillSummary/components/BilledConcepts/components/PieChartContainer/styles.module.scss +2 -2
  17. package/dist/components/BillSummary/components/BilledConcepts/constants.js +14 -12
  18. package/dist/components/BillSummary/components/BilledConcepts/index.js +49 -31
  19. package/dist/components/BillSummary/components/BilledConcepts/utils.js +76 -44
  20. package/dist/components/BillSummary/index.js +78 -76
  21. package/dist/components/ConsumptionComparison/components/ComparisonTable/components/DataLine/index.js +8 -8
  22. package/dist/components/ConsumptionComparison/components/ComparisonTable/components/Season/index.js +12 -17
  23. package/dist/components/ConsumptionComparison/components/ComparisonTable/components/Season/utils.js +1 -1
  24. package/dist/components/ConsumptionComparison/components/ComparisonTable/constants.js +135 -148
  25. package/dist/components/ConsumptionComparison/components/ComparisonTable/index.js +14 -16
  26. package/dist/components/ConsumptionComparison/components/ComparisonTable/utils.js +94 -89
  27. package/dist/components/ConsumptionComparison/components/ConsumptionAdvice/index.js +11 -21
  28. package/dist/components/ConsumptionComparison/components/ConsumptionAdvice/utils.js +1 -1
  29. package/dist/components/ConsumptionComparison/components/PercentageComparison/index.js +16 -21
  30. package/dist/components/ConsumptionComparison/components/PercentageComparison/utils.js +9 -13
  31. package/dist/components/ConsumptionComparison/index.js +56 -42
  32. package/dist/components/ConsumptionEnergyDetails/components/ConsumptionEnergyComparison/index.js +26 -30
  33. package/dist/components/ConsumptionEnergyDetails/components/ConsumptionInDaysLabel/index.js +13 -18
  34. package/dist/components/ConsumptionEnergyDetails/components/EnergyTotalConsumption/index.js +15 -17
  35. package/dist/components/ConsumptionEnergyDetails/components/PercentageComparison/index.js +17 -21
  36. package/dist/components/ConsumptionEnergyDetails/components/PercentageComparison/utils.js +1 -1
  37. package/dist/components/ConsumptionEnergyDetails/index.js +47 -51
  38. package/dist/components/ConsumptionIncluded/components/TimelineRow/components/Card/index.js +65 -66
  39. package/dist/components/ConsumptionIncluded/components/TimelineRow/components/Card/utils.js +13 -11
  40. package/dist/components/ConsumptionIncluded/components/TimelineRow/components/HeaderConsumption/index.js +19 -22
  41. package/dist/components/ConsumptionIncluded/components/TimelineRow/components/HeaderSettlement/index.js +10 -16
  42. package/dist/components/ConsumptionIncluded/components/TimelineRow/index.js +39 -43
  43. package/dist/components/ConsumptionIncluded/index.js +36 -34
  44. package/dist/components/ConsumptionIncluded/utils.js +33 -29
  45. package/dist/components/ConsumptionPeriod/components/ConsumptionSummary/components/ReadingRow/index.js +10 -14
  46. package/dist/components/ConsumptionPeriod/components/ConsumptionSummary/index.js +22 -25
  47. package/dist/components/ConsumptionPeriod/components/HistoryGraph/index.js +34 -18
  48. package/dist/components/ConsumptionPeriod/components/Reading/index.js +34 -37
  49. package/dist/components/ConsumptionPeriod/index.js +8 -12
  50. package/dist/components/ConsumptionPeriod/utils.js +15 -13
  51. package/dist/components/Date/index.js +9 -12
  52. package/dist/components/DebtState/index.js +8 -14
  53. package/dist/components/IconAndDetails/index.js +17 -19
  54. package/dist/components/Magnitude/index.js +12 -15
  55. package/dist/components/Magnitude/utils.js +8 -2
  56. package/dist/components/MainBillData/components/BillAlert/components/BillParticularConditions/index.js +16 -20
  57. package/dist/components/MainBillData/components/BillAlert/index.js +45 -28
  58. package/dist/components/MainBillData/components/BillBody/components/ClientData/index.js +11 -19
  59. package/dist/components/MainBillData/components/BillBody/components/Consumption/index.js +11 -14
  60. package/dist/components/MainBillData/components/BillBody/components/Consumption/utils.js +3 -1
  61. package/dist/components/MainBillData/components/BillBody/components/ReadingDetails/index.js +15 -23
  62. package/dist/components/MainBillData/components/BillBody/components/ReadingDetails/utils.js +1 -1
  63. package/dist/components/MainBillData/components/BillBody/index.js +50 -45
  64. package/dist/components/MainBillData/components/BillHeader/components/TypeAndNumber/index.js +9 -15
  65. package/dist/components/MainBillData/components/BillHeader/index.js +26 -29
  66. package/dist/components/MainBillData/index.js +5 -7
  67. package/dist/components/MainBillData/theme.js +9 -7
  68. package/dist/components/MainBillData/utils.js +5 -1
  69. package/dist/components/Period/index.js +47 -55
  70. package/dist/components/PowerProgresBar/components/PowerConsumption/index.js +11 -15
  71. package/dist/components/PowerProgresBar/index.js +36 -36
  72. package/dist/components/RateAndCategory/index.js +31 -30
  73. package/dist/components/RatesDefinition/components/BillRate/components/RatePrices/index.js +13 -20
  74. package/dist/components/RatesDefinition/components/BillRate/index.js +14 -24
  75. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/Category/index.js +9 -14
  76. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Indicator/components/IndicatorLabel/index.js +21 -26
  77. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Indicator/index.js +13 -19
  78. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Indicator/styles.module.scss +1 -4
  79. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Indicator/utils.js +13 -56
  80. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Legend/index.js +50 -0
  81. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Legend/styles.module.scss +34 -0
  82. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Stages/index.js +65 -0
  83. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Stages/styles.module.scss +88 -0
  84. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/constants.js +6 -37
  85. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/index.js +51 -16
  86. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/styles.module.scss +4 -1
  87. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/utils.js +68 -23
  88. package/dist/components/RatesDefinition/components/CategoryByConsumption/constants.js +42 -0
  89. package/dist/components/RatesDefinition/components/CategoryByConsumption/index.js +45 -36
  90. package/dist/components/RatesDefinition/components/CategoryByConsumption/utils.js +16 -0
  91. package/dist/components/RatesDefinition/components/PurchasedRate/index.js +13 -19
  92. package/dist/components/RatesDefinition/index.js +15 -20
  93. package/dist/components/SmartBillProvider/index.js +47 -12
  94. package/dist/components/StyledAmount/constants.js +1 -1
  95. package/dist/components/StyledAmount/index.js +35 -19
  96. package/dist/components/WithContextApi/index.js +27 -16
  97. package/dist/components/WithContextApi/layout.js +2 -2
  98. package/dist/components/WithSeason/index.js +9 -5
  99. package/dist/constants/deviceSizes.js +17 -27
  100. package/dist/constants/seasons.js +2 -2
  101. package/dist/index.js +16 -14
  102. package/dist/shared/Context/index.js +3 -5
  103. package/dist/shared/constants/aliases.js +550 -683
  104. package/dist/shared/constants/components.js +2 -1
  105. package/dist/shared/constants/consumptions.js +4 -4
  106. package/dist/shared/constants/periodicities.js +1 -1
  107. package/dist/shared/constants/rates.js +1 -1
  108. package/dist/shared/constants/readings.js +2 -2
  109. package/dist/shared/constants/seasons.js +2 -2
  110. package/dist/shared/constants/stagesGraph.js +4 -4
  111. package/dist/shared/types/assetsTypes.js +1 -1
  112. package/dist/shared/types/billDataTypes.js +4 -4
  113. package/dist/shared/types/componentsTypes.js +13 -18
  114. package/dist/shared/types/formattersTypes.js +1 -1
  115. package/dist/shared/types/rateStagesTypes.js +4 -4
  116. package/dist/shared/types/smartBillTypes.js +10 -5
  117. package/dist/shared/types/textsTypes.js +1 -1
  118. package/dist/shared/utils/billCalculation.js +9 -9
  119. package/dist/shared/utils/consumptions.js +62 -28
  120. package/dist/shared/utils/context.js +8 -7
  121. package/dist/shared/utils/expirations.js +5 -1
  122. package/dist/shared/utils/periods.js +20 -14
  123. package/dist/shared/utils/rates.js +5 -1
  124. package/dist/shared/utils/readings.js +10 -2
  125. package/dist/shared/utils/season.js +5 -1
  126. package/dist/shared/utils/stagesGraph.js +15 -11
  127. package/dist/utils/hooks.js +5 -37
  128. package/dist/utils.js +8 -4
  129. package/package.json +2 -2
  130. package/dist/components/BillSummary/components/BilledConcepts/components/PieChartContainer/utils.js +0 -27
  131. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/components/LimitsLine/index.js +0 -21
  132. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/components/LimitsLine/styles.module.scss +0 -15
  133. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/components/SubStage/index.js +0 -69
  134. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/components/SubStage/styles.module.scss +0 -5
  135. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/components/SubStage/utils.js +0 -12
  136. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/index.js +0 -68
  137. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/components/Stage/styles.module.scss +0 -32
  138. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/index.js +0 -59
  139. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/Bars/styles.module.scss +0 -3
  140. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/LegendItem/index.js +0 -83
  141. package/dist/components/RatesDefinition/components/CategoryByConsumption/components/RateStagesGraph/components/LegendItem/styles.module.scss +0 -57
@@ -25,32 +25,31 @@ var _stylesModule = _interopRequireDefault(require("./styles.module.scss"));
25
25
 
26
26
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
27
 
28
- const Concept = _ref => {
29
- let {
30
- contextApiInfo,
31
- isFirst,
32
- title,
33
- percentage,
34
- progressBarPercentage,
35
- value,
36
- showPercentage,
37
- negativeAmmount,
38
- showProgressBar,
39
- color
40
- } = _ref;
41
- const {
42
- Label,
43
- ProgressBar
44
- } = contextApiInfo;
45
- const {
46
- isDesktopSize
47
- } = (0, _hooks.useScreenSize)();
48
- const alias = isFirst ? _aliases.CONCEPT_FIRST_AMOUNT : _aliases.CONCEPT_SECONDARY_AMOUNT;
49
- const aliasDecimal = isFirst ? _aliases.CONCEPT_FIRST_AMOUNT_DECIMAL : _aliases.CONCEPT_SECONDARY_AMOUNT_DECIMAL;
50
- const aliasName = isFirst ? _aliases.CONCEPT_FIRST_NAME : _aliases.CONCEPT_SECONDARY_NAME;
51
- const percentageValue = "".concat((0, _numeral.default)(percentage).format('0,0.0'), "%");
52
-
53
- const renderPercentageValidation = withProgresBar => showPercentage && percentage && (withProgresBar ? showProgressBar : !showProgressBar);
28
+ var Concept = function Concept(_ref) {
29
+ var contextApiInfo = _ref.contextApiInfo,
30
+ isFirst = _ref.isFirst,
31
+ title = _ref.title,
32
+ percentage = _ref.percentage,
33
+ progressBarPercentage = _ref.progressBarPercentage,
34
+ value = _ref.value,
35
+ showPercentage = _ref.showPercentage,
36
+ negativeAmmount = _ref.negativeAmmount,
37
+ showProgressBar = _ref.showProgressBar,
38
+ color = _ref.color;
39
+ var Label = contextApiInfo.Label,
40
+ ProgressBar = contextApiInfo.ProgressBar;
41
+
42
+ var _useScreenSize = (0, _hooks.useScreenSize)(),
43
+ isDesktopSize = _useScreenSize.isDesktopSize;
44
+
45
+ var alias = isFirst ? _aliases.CONCEPT_FIRST_AMOUNT : _aliases.CONCEPT_SECONDARY_AMOUNT;
46
+ var aliasDecimal = isFirst ? _aliases.CONCEPT_FIRST_AMOUNT_DECIMAL : _aliases.CONCEPT_SECONDARY_AMOUNT_DECIMAL;
47
+ var aliasName = isFirst ? _aliases.CONCEPT_FIRST_NAME : _aliases.CONCEPT_SECONDARY_NAME;
48
+ var percentageValue = "".concat((0, _numeral.default)(percentage).format('0,0.0'), "%");
49
+
50
+ var renderPercentageValidation = function renderPercentageValidation(withProgresBar) {
51
+ return showPercentage && percentage && (withProgresBar ? showProgressBar : !showProgressBar);
52
+ };
54
53
 
55
54
  return /*#__PURE__*/_react.default.createElement("div", {
56
55
  className: _stylesModule.default.container
@@ -3,6 +3,12 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.RADIAN = void 0;
7
- const RADIAN = Math.PI / 180;
8
- exports.RADIAN = RADIAN;
6
+ exports.PIE_CHART_CUSTOMIZATION = void 0;
7
+ var PIE_CHART_CUSTOMIZATION = {
8
+ animationLength: 800,
9
+ height: 200,
10
+ minAngle: 0.1,
11
+ outerRadius: 100,
12
+ width: 200
13
+ };
14
+ exports.PIE_CHART_CUSTOMIZATION = PIE_CHART_CUSTOMIZATION;
@@ -7,55 +7,52 @@ exports.default = void 0;
7
7
 
8
8
  var _react = _interopRequireDefault(require("react"));
9
9
 
10
- var _recharts = require("recharts");
11
-
12
10
  var _propTypes = require("prop-types");
13
11
 
12
+ var _smartBillTypes = require("../../../../../../shared/types/smartBillTypes");
13
+
14
+ var _WithContextApi = _interopRequireDefault(require("../../../../../WithContextApi"));
15
+
14
16
  var _utils = require("../../utils");
15
17
 
16
- var _utils2 = require("./utils");
18
+ var _constants = require("./constants");
17
19
 
18
20
  var _stylesModule = _interopRequireDefault(require("./styles.module.scss"));
19
21
 
20
22
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
23
 
22
- const PieChartContainer = _ref => {
23
- let {
24
- concepts,
25
- additionalInfo
26
- } = _ref;
27
- const pieConceptsData = concepts.map(concept => ({
28
- color: concept.color,
29
- name: concept.title,
30
- value: concept.total
31
- }));
24
+ function _extends() { _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
25
+
26
+ var PieChartContainer = function PieChartContainer(_ref) {
27
+ var concepts = _ref.concepts,
28
+ additionalInfo = _ref.additionalInfo,
29
+ contextApiInfo = _ref.contextApiInfo;
30
+ var PieChart = contextApiInfo.PieChart;
31
+ var pieConceptsData = concepts.map(function (concept) {
32
+ return {
33
+ color: concept.color,
34
+ name: concept.title,
35
+ value: concept.total
36
+ };
37
+ });
32
38
  return /*#__PURE__*/_react.default.createElement("div", {
33
39
  className: _stylesModule.default.container
34
- }, /*#__PURE__*/_react.default.createElement("div", {
35
- className: _stylesModule.default.graphContainer
36
- }, !additionalInfo.negativeAmmount && /*#__PURE__*/_react.default.createElement(_recharts.ResponsiveContainer, {
37
- height: 250
38
- }, /*#__PURE__*/_react.default.createElement(_recharts.PieChart, {
39
- width: 400,
40
- height: 250
41
- }, /*#__PURE__*/_react.default.createElement(_recharts.Pie, {
40
+ }, !additionalInfo.negativeAmmount && /*#__PURE__*/_react.default.createElement(PieChart, _extends({
41
+ className: _stylesModule.default.pie,
42
42
  data: pieConceptsData,
43
- cx: "50%",
44
- cy: "50%",
45
- labelLine: false,
46
- label: _utils2.renderCustomizedLabel,
47
- outerRadius: 100,
48
- fill: "#8884d8",
49
- dataKey: "value"
50
- }, concepts === null || concepts === void 0 ? void 0 : concepts.map(concept => /*#__PURE__*/_react.default.createElement(_recharts.Cell, {
51
- fill: concept.color,
52
- stroke: "none"
53
- })))))), concepts.map((concept, index) => (0, _utils.renderConcept)(concept, additionalInfo, index === 0)));
43
+ withLabels: false,
44
+ withLegend: false
45
+ }, _constants.PIE_CHART_CUSTOMIZATION)), concepts.map(function (concept, index) {
46
+ return (0, _utils.renderConcept)(concept, additionalInfo, index === 0);
47
+ }));
54
48
  };
55
49
 
56
50
  PieChartContainer.propTypes = {
51
+ additionalInfo: (0, _propTypes.shape)((0, _propTypes.objectOf)(_propTypes.any)),
57
52
  concepts: (0, _propTypes.shape)((0, _propTypes.objectOf)(_propTypes.any)),
58
- additionalInfo: (0, _propTypes.shape)((0, _propTypes.objectOf)(_propTypes.any))
53
+ contextApiInfo: _smartBillTypes.contextApiInfoTypes
59
54
  };
60
- var _default = PieChartContainer;
55
+
56
+ var _default = (0, _WithContextApi.default)()(PieChartContainer);
57
+
61
58
  exports.default = _default;
@@ -5,6 +5,6 @@
5
5
  flex-direction: column;
6
6
  }
7
7
 
8
- .graphContainer {
9
- margin-bottom: 20px;
8
+ .pie {
9
+ margin: auto auto 20px auto;
10
10
  }
@@ -7,21 +7,23 @@ exports.toggleOptions = exports.progressBar = exports.pieChart = exports.COLORS
7
7
 
8
8
  var _colorsExport = require("../../../../scss/variables/_colorsExport.scss");
9
9
 
10
- const pieChart = 'pieChart';
10
+ var pieChart = 'pieChart';
11
11
  exports.pieChart = pieChart;
12
- const progressBar = 'progressBar';
12
+ var progressBar = 'progressBar';
13
13
  exports.progressBar = progressBar;
14
14
 
15
- const toggleOptions = assets => [{
16
- value: progressBar,
17
- Icon: assets.ListGrayIcon,
18
- SelectedIcon: assets.ListWhiteIcon
19
- }, {
20
- value: pieChart,
21
- Icon: assets.PieGrayIcon,
22
- SelectedIcon: assets.PieWhiteIcon
23
- }];
15
+ var toggleOptions = function toggleOptions(assets) {
16
+ return [{
17
+ value: progressBar,
18
+ Icon: assets.ListGrayIcon,
19
+ SelectedIcon: assets.ListWhiteIcon
20
+ }, {
21
+ value: pieChart,
22
+ Icon: assets.PieGrayIcon,
23
+ SelectedIcon: assets.PieWhiteIcon
24
+ }];
25
+ };
24
26
 
25
27
  exports.toggleOptions = toggleOptions;
26
- const COLORS = [_colorsExport.primary, _colorsExport.darkGray, _colorsExport.pieChartGray, _colorsExport.pieChartLightGray];
28
+ var COLORS = [_colorsExport.primary, _colorsExport.darkGray, _colorsExport.pieChartGray, _colorsExport.pieChartLightGray];
27
29
  exports.COLORS = COLORS;
@@ -1,5 +1,7 @@
1
1
  "use strict";
2
2
 
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+
3
5
  Object.defineProperty(exports, "__esModule", {
4
6
  value: true
5
7
  });
@@ -25,45 +27,59 @@ var _utils = require("./utils");
25
27
 
26
28
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
29
 
28
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
30
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
31
+
32
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
33
+
34
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
35
+
36
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
37
+
38
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
29
39
 
30
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
40
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
31
41
 
32
- const BilledConcepts = _ref => {
42
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
43
+
44
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
45
+
46
+ var BilledConcepts = function BilledConcepts(_ref) {
33
47
  var _billData$detail;
34
48
 
35
- let {
36
- contextApiInfo,
37
- billData
38
- } = _ref;
39
- const {
40
- config,
41
- Label,
42
- Toggle,
43
- assets
44
- } = contextApiInfo;
45
- const {
46
- showZeroConcepts,
47
- colors
48
- } = config;
49
- const {
50
- billedConceptsTitle
51
- } = config.texts.billSummary;
52
- const [toggleOption, setToggleOption] = (0, _react.useState)(_constants.progressBar);
53
-
54
- const handleChangeToggleOption = newOption => setToggleOption(newOption);
55
-
56
- const totalAmount = billData === null || billData === void 0 ? void 0 : (_billData$detail = billData.detail) === null || _billData$detail === void 0 ? void 0 : _billData$detail.total_amount;
57
- const concepts = (0, _react.useMemo)(() => {
49
+ var contextApiInfo = _ref.contextApiInfo,
50
+ billData = _ref.billData;
51
+ var config = contextApiInfo.config,
52
+ Label = contextApiInfo.Label,
53
+ Toggle = contextApiInfo.Toggle,
54
+ assets = contextApiInfo.assets;
55
+ var showZeroConcepts = config.showZeroConcepts,
56
+ colors = config.colors;
57
+ var billedConceptsTitle = config.texts.billSummary.billedConceptsTitle;
58
+
59
+ var _useState = (0, _react.useState)(_constants.progressBar),
60
+ _useState2 = _slicedToArray(_useState, 2),
61
+ toggleOption = _useState2[0],
62
+ setToggleOption = _useState2[1];
63
+
64
+ var handleChangeToggleOption = function handleChangeToggleOption(newOption) {
65
+ return setToggleOption(newOption);
66
+ };
67
+
68
+ var totalAmount = billData === null || billData === void 0 ? void 0 : (_billData$detail = billData.detail) === null || _billData$detail === void 0 ? void 0 : _billData$detail.total_amount;
69
+ var concepts = (0, _react.useMemo)(function () {
58
70
  var _billData$detail2;
59
71
 
60
72
  return (0, _utils.getOrderedAndColoredConcepts)(billData === null || billData === void 0 ? void 0 : (_billData$detail2 = billData.detail) === null || _billData$detail2 === void 0 ? void 0 : _billData$detail2.concepts, totalAmount, showZeroConcepts, (0, _utils.getColorsDefinition)(colors));
61
73
  }, []);
62
- const negativeAmmount = concepts.some(concept => concept.total < 0);
63
- const additionalInfo = {
74
+ var negativeAmmount = concepts.some(function (concept) {
75
+ return concept.total < 0;
76
+ });
77
+ var additionalInfo = {
64
78
  showProgressBar: toggleOption === _constants.progressBar,
65
- negativeAmmount: concepts.some(concept => concept.total < 0),
66
- totalAmount
79
+ negativeAmmount: concepts.some(function (concept) {
80
+ return concept.total < 0;
81
+ }),
82
+ totalAmount: totalAmount
67
83
  };
68
84
  return /*#__PURE__*/_react.default.createElement("div", {
69
85
  className: _stylesModule.default.container
@@ -79,7 +95,9 @@ const BilledConcepts = _ref => {
79
95
  className: _stylesModule.default.toggle,
80
96
  optionClassName: _stylesModule.default.toggleOption,
81
97
  orientation: "horizontal"
82
- })), !negativeAmmount && toggleOption === _constants.progressBar ? concepts.map((concept, index) => (0, _utils.renderConcept)(concept, additionalInfo, index === 0)) : /*#__PURE__*/_react.default.createElement(_PieChartContainer.default, {
98
+ })), !negativeAmmount && toggleOption === _constants.progressBar ? concepts.map(function (concept, index) {
99
+ return (0, _utils.renderConcept)(concept, additionalInfo, index === 0);
100
+ }) : /*#__PURE__*/_react.default.createElement(_PieChartContainer.default, {
83
101
  concepts: concepts,
84
102
  additionalInfo: additionalInfo
85
103
  }));
@@ -13,32 +13,56 @@ var _Concept = _interopRequireDefault(require("./components/Concept"));
13
13
 
14
14
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
15
15
 
16
- const roundPercentage = value => Math.round(value * 10) / 10;
16
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
17
17
 
18
- const calculatePercentages = (billConcepts, totalAmount) => {
19
- const indexToAdjust = billConcepts.findIndex(concept => concept.total !== 0);
20
- const adjustValue = 100 - billConcepts.reduce((accum, concept) => accum + roundPercentage(concept.total / totalAmount * 100), 0);
21
- return billConcepts.map((concept, index) => roundPercentage(concept.total / totalAmount * 100 + (index === indexToAdjust ? adjustValue : 0)));
18
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
19
+
20
+ function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
21
+
22
+ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
23
+
24
+ function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
25
+
26
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
27
+
28
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
29
+
30
+ function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
31
+
32
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
33
+
34
+ var roundPercentage = function roundPercentage(value) {
35
+ return Math.round(value * 10) / 10;
36
+ };
37
+
38
+ var calculatePercentages = function calculatePercentages(billConcepts, totalAmount) {
39
+ var indexToAdjust = billConcepts.findIndex(function (concept) {
40
+ return concept.total !== 0;
41
+ });
42
+ var adjustValue = 100 - billConcepts.reduce(function (accum, concept) {
43
+ return accum + roundPercentage(concept.total / totalAmount * 100);
44
+ }, 0);
45
+ return billConcepts.map(function (concept, index) {
46
+ return roundPercentage(concept.total / totalAmount * 100 + (index === indexToAdjust ? adjustValue : 0));
47
+ });
22
48
  };
23
49
 
24
50
  exports.calculatePercentages = calculatePercentages;
25
51
 
26
- const getProgressBarPercentage = (maxPercentage, percentage) => percentage / maxPercentage * 100;
27
-
28
- const renderConcept = (conceptData, additionalInfo, isFirst) => {
29
- const {
30
- title,
31
- total,
32
- color,
33
- percentage,
34
- progressBarPercentage
35
- } = conceptData;
36
- const {
37
- showProgressBar,
38
- negativeAmmount,
39
- totalAmount
40
- } = additionalInfo;
41
- const showPercentage = !(percentage === 0);
52
+ var getProgressBarPercentage = function getProgressBarPercentage(maxPercentage, percentage) {
53
+ return percentage / maxPercentage * 100;
54
+ };
55
+
56
+ var renderConcept = function renderConcept(conceptData, additionalInfo, isFirst) {
57
+ var title = conceptData.title,
58
+ total = conceptData.total,
59
+ color = conceptData.color,
60
+ percentage = conceptData.percentage,
61
+ progressBarPercentage = conceptData.progressBarPercentage;
62
+ var showProgressBar = additionalInfo.showProgressBar,
63
+ negativeAmmount = additionalInfo.negativeAmmount,
64
+ totalAmount = additionalInfo.totalAmount;
65
+ var showPercentage = !(percentage === 0);
42
66
  return /*#__PURE__*/_react.default.createElement(_Concept.default, {
43
67
  key: title,
44
68
  title: title,
@@ -56,43 +80,51 @@ const renderConcept = (conceptData, additionalInfo, isFirst) => {
56
80
 
57
81
  exports.renderConcept = renderConcept;
58
82
 
59
- const isZeroConcept = concept => concept.total === 0;
83
+ var isZeroConcept = function isZeroConcept(concept) {
84
+ return concept.total === 0;
85
+ };
60
86
 
61
- const getSortedData = (concepts, showZeroConcepts) => {
62
- const nonZeroConcepts = concepts === null || concepts === void 0 ? void 0 : concepts.filter(concept => !isZeroConcept(concept));
63
- const zeroConcepts = showZeroConcepts && (concepts === null || concepts === void 0 ? void 0 : concepts.filter(isZeroConcept)) || [];
87
+ var getSortedData = function getSortedData(concepts, showZeroConcepts) {
88
+ var nonZeroConcepts = concepts === null || concepts === void 0 ? void 0 : concepts.filter(function (concept) {
89
+ return !isZeroConcept(concept);
90
+ });
91
+ var zeroConcepts = showZeroConcepts && (concepts === null || concepts === void 0 ? void 0 : concepts.filter(isZeroConcept)) || [];
64
92
  return {
65
- sortedConcepts: [...nonZeroConcepts, ...zeroConcepts],
93
+ sortedConcepts: [].concat(_toConsumableArray(nonZeroConcepts), _toConsumableArray(zeroConcepts)),
66
94
  nonZeroLength: nonZeroConcepts.length
67
95
  };
68
96
  };
69
97
 
70
- const getColorsDefinition = externalColors => [externalColors.primary || _constants.COLORS.primary, ..._constants.COLORS.slice(1)];
98
+ var getColorsDefinition = function getColorsDefinition(externalColors) {
99
+ return [externalColors.primary || _constants.COLORS.primary].concat(_toConsumableArray(_constants.COLORS.slice(1)));
100
+ };
71
101
 
72
102
  exports.getColorsDefinition = getColorsDefinition;
73
103
 
74
- const getItemColor = (index, nonZeroLength, colorsDefinition) => {
75
- const colorsLen = _constants.COLORS.length;
76
- const colorIndex = index % colorsLen;
77
- const isLastNonZero = index === nonZeroLength - 1;
78
- const nextColorIndex = (index + 1) % colorsLen;
104
+ var getItemColor = function getItemColor(index, nonZeroLength, colorsDefinition) {
105
+ var colorsLen = _constants.COLORS.length;
106
+ var colorIndex = index % colorsLen;
107
+ var isLastNonZero = index === nonZeroLength - 1;
108
+ var nextColorIndex = (index + 1) % colorsLen;
79
109
  return colorsDefinition[isLastNonZero && colorsDefinition[colorIndex] === colorsDefinition[0] ? nextColorIndex : colorIndex];
80
110
  };
81
111
 
82
112
  exports.getItemColor = getItemColor;
83
113
 
84
- const getOrderedAndColoredConcepts = (concepts, totalAmount, showZeroConcepts, colorsDefinition) => {
85
- const {
86
- sortedConcepts,
87
- nonZeroLength
88
- } = getSortedData(concepts, showZeroConcepts);
89
- const percentages = calculatePercentages(sortedConcepts, totalAmount);
90
- const maxPercentage = Math.max(...percentages);
91
- return sortedConcepts.map((concept, index) => ({ ...concept,
92
- percentage: percentages[index],
93
- progressBarPercentage: getProgressBarPercentage(maxPercentage, percentages[index]),
94
- color: !isZeroConcept(concept) && getItemColor(index, nonZeroLength, colorsDefinition)
95
- }));
114
+ var getOrderedAndColoredConcepts = function getOrderedAndColoredConcepts(concepts, totalAmount, showZeroConcepts, colorsDefinition) {
115
+ var _getSortedData = getSortedData(concepts, showZeroConcepts),
116
+ sortedConcepts = _getSortedData.sortedConcepts,
117
+ nonZeroLength = _getSortedData.nonZeroLength;
118
+
119
+ var percentages = calculatePercentages(sortedConcepts, totalAmount);
120
+ var maxPercentage = Math.max.apply(Math, _toConsumableArray(percentages));
121
+ return sortedConcepts.map(function (concept, index) {
122
+ return _objectSpread(_objectSpread({}, concept), {}, {
123
+ percentage: percentages[index],
124
+ progressBarPercentage: getProgressBarPercentage(maxPercentage, percentages[index]),
125
+ color: !isZeroConcept(concept) && getItemColor(index, nonZeroLength, colorsDefinition)
126
+ });
127
+ });
96
128
  };
97
129
 
98
130
  exports.getOrderedAndColoredConcepts = getOrderedAndColoredConcepts;