diff --git a/3/ecolyo.dc7b4fa6e755df72417e.js b/3/ecolyo.eff4cc1e75bcc37e8fed.js
similarity index 86%
rename from 3/ecolyo.dc7b4fa6e755df72417e.js
rename to 3/ecolyo.eff4cc1e75bcc37e8fed.js
index bed6ed37fb0774f1fda30f9f57ab1c62917128b3..2ff7bf2ecb8bd3827b6e719f43ef591e357ae570 100644
--- a/3/ecolyo.dc7b4fa6e755df72417e.js
+++ b/3/ecolyo.eff4cc1e75bcc37e8fed.js
@@ -137,7 +137,8 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
 
 var AnalysisConsumption = function AnalysisConsumption(_ref) {
   var aggregatedPerformanceIndicator = _ref.aggregatedPerformanceIndicator,
-      performanceIndicators = _ref.performanceIndicators;
+      performanceIndicators = _ref.performanceIndicators,
+      analysisDate = _ref.analysisDate;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
@@ -149,7 +150,6 @@ var AnalysisConsumption = function AnalysisConsumption(_ref) {
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
     return state.ecolyo;
   }),
-      analysisMonth = _useSelector.analysis.analysisMonth,
       fluidTypes = _useSelector.global.fluidTypes,
       profile = _useSelector.profile;
 
@@ -238,7 +238,7 @@ var AnalysisConsumption = function AnalysisConsumption(_ref) {
               case 0:
                 profileTypeEntityService = new _profileTypeEntity.default(client);
                 _context.next = 3;
-                return profileTypeEntityService.getProfileType(analysisMonth.minus({
+                return profileTypeEntityService.getProfileType(analysisDate.minus({
                   month: 1
                 }).startOf('month'));
 
@@ -250,11 +250,9 @@ var AnalysisConsumption = function AnalysisConsumption(_ref) {
                   break;
                 }
 
-                profileTypeService = new _profileType.default(profileType, client, analysisMonth.minus({
-                  month: 1
-                }).year);
+                profileTypeService = new _profileType.default(profileType, client, analysisDate.year);
                 _context.next = 8;
-                return profileTypeService.getMonthlyForecast(analysisMonth.minus({
+                return profileTypeService.getMonthlyForecast(analysisDate.minus({
                   month: 1
                 }).startOf('month').month);
 
@@ -285,7 +283,7 @@ var AnalysisConsumption = function AnalysisConsumption(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [profile.monthlyAnalysisDate.month, getTotalValueWithConnectedFluids, client, analysisMonth.month, analysisMonth]);
+  }, [profile.monthlyAnalysisDate.month, getTotalValueWithConnectedFluids, client, analysisDate.month, analysisDate]);
 
   var profileNotCompleted = /*#__PURE__*/_react.default.createElement("div", {
     className: "no-profile"
@@ -464,7 +462,8 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 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; }
 
 var ComparisonView = function ComparisonView(_ref) {
-  var fluidConfig = _ref.fluidConfig;
+  var analysisDate = _ref.analysisDate,
+      fluidConfig = _ref.fluidConfig;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
@@ -475,9 +474,7 @@ var ComparisonView = function ComparisonView(_ref) {
     return state.ecolyo;
   }),
       fluidTypes = _useSelector.global.fluidTypes,
-      _useSelector$analysis = _useSelector.analysis,
-      period = _useSelector$analysis.period,
-      analysisMonth = _useSelector$analysis.analysisMonth;
+      period = _useSelector.analysis.period;
 
   var dispatch = (0, _reactRedux.useDispatch)();
 
@@ -501,36 +498,36 @@ var ComparisonView = function ComparisonView(_ref) {
   }, [client]);
   var monthPeriod = (0, _react.useMemo)(function () {
     return {
-      startDate: analysisMonth.minus({
+      startDate: analysisDate.minus({
         month: 1
       }).startOf('month'),
-      endDate: analysisMonth.minus({
+      endDate: analysisDate.minus({
         month: 1
       }).endOf('month')
     };
-  }, [analysisMonth]);
+  }, [analysisDate]);
   var previousMonthPeriod = (0, _react.useMemo)(function () {
     return {
-      startDate: analysisMonth.minus({
+      startDate: analysisDate.minus({
         month: 2
       }).startOf('month'),
-      endDate: analysisMonth.minus({
+      endDate: analysisDate.minus({
         month: 2
       }).endOf('month')
     };
-  }, [analysisMonth]);
+  }, [analysisDate]);
   var previousYearPeriod = (0, _react.useMemo)(function () {
     return {
-      startDate: analysisMonth.minus({
+      startDate: analysisDate.minus({
         year: 1,
         month: 1
       }).startOf('month'),
-      endDate: analysisMonth.minus({
+      endDate: analysisDate.minus({
         year: 1,
         month: 1
       }).endOf('month')
     };
-  }, [analysisMonth]);
+  }, [analysisDate]);
   var loaderPlaceholderHeight = fluidTypes.length * 84 + (fluidTypes.length - 1) * 10;
   (0, _react.useEffect)(function () {
     var subscribed = true;
@@ -586,7 +583,7 @@ var ComparisonView = function ComparisonView(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [client, fluidTypes, analysisMonth, consumptionService, monthPeriod, previousMonthPeriod, previousYearPeriod]);
+  }, [client, fluidTypes, analysisDate, consumptionService, monthPeriod, previousMonthPeriod, previousYearPeriod]);
   return /*#__PURE__*/_react.default.createElement("div", {
     className: "comparisonView"
   }, /*#__PURE__*/_react.default.createElement("div", {
@@ -647,6 +644,8 @@ var d3 = _interopRequireWildcard(__webpack_require__("VphZ"));
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
+var _date = __webpack_require__("XrP9");
+
 var _utils = __webpack_require__("c+yx");
 
 __webpack_require__("0oKQ");
@@ -736,9 +735,7 @@ var PieChart = function PieChart(_ref) {
     className: "euro-unit"
   }, "".concat(t('FLUID.MULTIFLUID.UNIT')))), /*#__PURE__*/_react.default.createElement("div", {
     className: "text-16-normal date"
-  }, t('analysis_pie.month') + (0, _utils.getMonthNameWithPrep)(currentAnalysisDate.minus({
-    month: 1
-  }))), /*#__PURE__*/_react.default.createElement("div", {
+  }, t('analysis_pie.month') + (0, _date.convertDateToMonthString)(currentAnalysisDate).substring(3)), /*#__PURE__*/_react.default.createElement("div", {
     className: "text-14-normal estimation-text",
     onClick: toggleEstimationModal
   }, /*#__PURE__*/_react.default.createElement("span", {
@@ -847,18 +844,16 @@ var _timeStep = __webpack_require__("cKQ8");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 var _consumption = _interopRequireDefault(__webpack_require__("AVq/"));
 
 var _picto = __webpack_require__("6DBe");
 
 var _utils = __webpack_require__("c+yx");
 
-var _PieChart = _interopRequireDefault(__webpack_require__("6eOr"));
-
 __webpack_require__("/Sqe");
 
+var _PieChart = _interopRequireDefault(__webpack_require__("6eOr"));
+
 __webpack_require__("0oKQ");
 
 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); }
@@ -866,12 +861,8 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 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; }
 
 var TotalAnalysisChart = function TotalAnalysisChart(_ref) {
-  var fluidTypes = _ref.fluidTypes;
-
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.analysis;
-  }),
-      analysisMonth = _useSelector.analysisMonth;
+  var analysisDate = _ref.analysisDate,
+      fluidTypes = _ref.fluidTypes;
 
   var _useState = (0, _react.useState)(null),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
@@ -907,10 +898,10 @@ var TotalAnalysisChart = function TotalAnalysisChart(_ref) {
             switch (_context.prev = _context.next) {
               case 0:
                 timePeriod = {
-                  startDate: analysisMonth.minus({
+                  startDate: analysisDate.minus({
                     month: 1
                   }).startOf('month'),
-                  endDate: analysisMonth.minus({
+                  endDate: analysisDate.minus({
                     month: 1
                   }).endOf('month')
                 };
@@ -943,7 +934,7 @@ var TotalAnalysisChart = function TotalAnalysisChart(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [analysisMonth, client, fluidTypes]);
+  }, [analysisDate, client, fluidTypes]);
   return /*#__PURE__*/_react.default.createElement("div", {
     className: "totalAnalysis-container",
     style: {
@@ -958,7 +949,9 @@ var TotalAnalysisChart = function TotalAnalysisChart(_ref) {
     height: radius,
     innerRadius: innerRadius,
     outerRadius: outerRadius,
-    currentAnalysisDate: analysisMonth
+    currentAnalysisDate: analysisDate.minus({
+      month: 1
+    }).startOf('month')
   }), dataLoadValueDetailArray && fluidTypes.length > 1 && /*#__PURE__*/_react.default.createElement("div", {
     className: "total-card-container"
   }, dataLoadValueDetailArray.map(function (dataload, index) {
@@ -1009,14 +1002,8 @@ var _leftArrow = _interopRequireDefault(__webpack_require__("bZGv"));
 
 var _rightArrow = _interopRequireDefault(__webpack_require__("fZGW"));
 
-var _BarChart = _interopRequireDefault(__webpack_require__("CPpy"));
-
 var _StyledIcon = _interopRequireDefault(__webpack_require__("I07j"));
 
-var _DataloadSection = _interopRequireDefault(__webpack_require__("nGEn"));
-
-var _useChartResize2 = __webpack_require__("tWvI");
-
 var _Loader = _interopRequireDefault(__webpack_require__("Ra/y"));
 
 var _cozyClient = __webpack_require__("SH7X");
@@ -1025,8 +1012,6 @@ var _I18n = __webpack_require__("buk/");
 
 var _Icon = _interopRequireDefault(__webpack_require__("y6ex"));
 
-var _dataload = __webpack_require__("D5WE");
-
 var _fluid = __webpack_require__("5Wkc");
 
 var _timeStep = __webpack_require__("cKQ8");
@@ -1037,7 +1022,9 @@ var _reactRedux = __webpack_require__("/MKj");
 
 var _consumption = _interopRequireDefault(__webpack_require__("AVq/"));
 
-var _chart = __webpack_require__("idK9");
+var _picto = __webpack_require__("6DBe");
+
+var _utils = __webpack_require__("c+yx");
 
 __webpack_require__("Ydja");
 
@@ -1045,64 +1032,56 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 
 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; }
 
-var MaxConsumptionCard = function MaxConsumptionCard() {
+var MaxConsumptionCard = function MaxConsumptionCard(_ref) {
+  var analysisDate = _ref.analysisDate;
+
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
   var client = (0, _cozyClient.useClient)();
-  var dispatch = (0, _reactRedux.useDispatch)();
 
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo;
+    return state.ecolyo.global;
   }),
-      fluidTypes = _useSelector.global.fluidTypes,
-      analysisMonth = _useSelector.analysis.analysisMonth;
+      fluidTypes = _useSelector.fluidTypes;
 
   var _useState = (0, _react.useState)(0),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       index = _useState2[0],
       setIndex = _useState2[1];
 
-  var _useState3 = (0, _react.useState)(true),
+  var _useState3 = (0, _react.useState)(null),
       _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      isLoading = _useState4[0],
-      setIsLoading = _useState4[1];
+      maxDayData = _useState4[0],
+      setMaxDayData = _useState4[1];
 
-  var _useState5 = (0, _react.useState)(null),
+  var _useState5 = (0, _react.useState)(false),
       _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
-      maxDayData = _useState6[0],
-      setMaxDayData = _useState6[1];
-
-  var _useState7 = (0, _react.useState)({
-    actualData: [],
-    comparisonData: null
-  }),
-      _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
-      chartData = _useState8[0],
-      setChartData = _useState8[1];
-
-  var containerRef = (0, _react.useRef)(null);
-
-  var _useChartResize = (0, _useChartResize2.useChartResize)(containerRef, isLoading, 250, 940),
-      height = _useChartResize.height,
-      width = _useChartResize.width;
-
-  var currentFluidType = _fluid.FluidType[fluidTypes[index]];
-  var fluidColor = currentFluidType.toLowerCase();
+      isLoading = _useState6[0],
+      setIsLoading = _useState6[1];
 
-  var handleFluidChange = function handleFluidChange(direction) {
+  var handleChangePrevFluid = (0, _react.useCallback)(function () {
     setIsLoading(true);
-    var newIndex = index + direction;
 
-    if (newIndex >= fluidTypes.length) {
-      newIndex = 0;
-    } else if (newIndex < 0) {
-      newIndex = fluidTypes.length - 1;
+    if (index === 0) {
+      setIndex(fluidTypes.length - 1);
+    } else {
+      setIndex(function (prev) {
+        return prev - 1;
+      });
     }
+  }, [fluidTypes, index]);
+  var handleChangeNextFluid = (0, _react.useCallback)(function () {
+    setIsLoading(true);
 
-    setIndex(newIndex);
-  };
-
+    if (index === fluidTypes.length - 1) {
+      setIndex(0);
+    } else {
+      setIndex(function (prev) {
+        return prev + 1;
+      });
+    }
+  }, [fluidTypes, index]);
   (0, _react.useEffect)(function () {
     var subscribed = true;
 
@@ -1112,37 +1091,31 @@ var MaxConsumptionCard = function MaxConsumptionCard() {
 
     function _getMaxLoadData() {
       _getMaxLoadData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
-        var timePeriod, consumptionService, monthlyData, maxDay;
+        var timePeriod, consumptionService, monthMaxData;
         return _regenerator.default.wrap(function _callee$(_context) {
           while (1) {
             switch (_context.prev = _context.next) {
               case 0:
                 setIsLoading(true);
                 timePeriod = {
-                  startDate: analysisMonth.minus({
+                  startDate: analysisDate.minus({
                     month: 1
                   }).startOf('month'),
-                  endDate: analysisMonth.minus({
+                  endDate: analysisDate.minus({
                     month: 1
                   }).endOf('month')
                 };
                 consumptionService = new _consumption.default(client);
                 _context.next = 5;
-                return consumptionService.getGraphData(timePeriod, _timeStep.TimeStep.DAY, [fluidTypes[index]]);
+                return consumptionService.getMaxLoad(timePeriod, _timeStep.TimeStep.DAY, [fluidTypes[index]], undefined, false, true);
 
               case 5:
-                monthlyData = _context.sent;
-
-                if (monthlyData && (monthlyData === null || monthlyData === void 0 ? void 0 : monthlyData.actualData.length) > 0) {
-                  setChartData(monthlyData);
-                  maxDay = getMaxConsumptionDay(monthlyData.actualData);
+                monthMaxData = _context.sent;
 
-                  if (maxDay) {
-                    setMaxDayData(maxDay);
-                    dispatch((0, _chart.setSelectedDate)(maxDay.date));
-                  } else {
-                    setMaxDayData(null);
-                  }
+                if (monthMaxData) {
+                  setMaxDayData(monthMaxData);
+                } else {
+                  setMaxDayData(null);
                 }
 
                 setIsLoading(false);
@@ -1164,50 +1137,9 @@ var MaxConsumptionCard = function MaxConsumptionCard() {
     return function () {
       subscribed = false;
     };
-  }, [analysisMonth, client, fluidTypes, index, dispatch]);
-
-  var getMaxConsumptionDay = function getMaxConsumptionDay(dataload) {
-    var maxIndex = -1;
-    var maxValue = -1;
-    dataload.forEach(function (day, index) {
-      if (day.value > 0 && day.value > maxValue) {
-        maxValue = day.value;
-        maxIndex = index;
-      }
-    });
-    if (maxIndex === -1) return null;
-    return dataload[maxIndex];
-  };
-
-  var buttonPrev = function buttonPrev() {
-    return /*#__PURE__*/_react.default.createElement(_IconButton.default, {
-      "aria-label": t('consumption.accessibility.button_previous_value'),
-      onClick: function onClick() {
-        return handleFluidChange(-1);
-      },
-      className: "arrow-prev"
-    }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
-      icon: _leftArrow.default,
-      size: 24
-    }));
-  };
-
-  var buttonNext = function buttonNext() {
-    return /*#__PURE__*/_react.default.createElement(_IconButton.default, {
-      "aria-label": t('consumption.accessibility.button_next_value'),
-      onClick: function onClick() {
-        return handleFluidChange(1);
-      },
-      className: "arrow-next"
-    }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
-      icon: _rightArrow.default,
-      size: 24
-    }));
-  };
-
+  }, [analysisDate, client, fluidTypes, index]);
   return /*#__PURE__*/_react.default.createElement("div", {
-    className: "max-consumption-container",
-    ref: containerRef
+    className: "max-consumption-container"
   }, /*#__PURE__*/_react.default.createElement(_StyledIcon.default, {
     icon: _graphIcon.default,
     size: 38
@@ -1215,34 +1147,37 @@ var MaxConsumptionCard = function MaxConsumptionCard() {
     className: "text-16-normal title"
   }, t('analysis.max_day')), /*#__PURE__*/_react.default.createElement("div", {
     className: "fluid-navigation"
-  }, fluidTypes.length > 1 && buttonPrev(), /*#__PURE__*/_react.default.createElement("div", {
-    className: "text-20-bold fluid ".concat(fluidColor)
-  }, t("FLUID.".concat(currentFluidType, ".LABEL"))), fluidTypes.length > 1 && buttonNext()), /*#__PURE__*/_react.default.createElement("div", {
+  }, fluidTypes.length > 1 && /*#__PURE__*/_react.default.createElement(_IconButton.default, {
+    "aria-label": t('consumption.accessibility.button_previous_value'),
+    onClick: handleChangePrevFluid,
+    className: "arrow-prev"
+  }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
+    icon: _leftArrow.default,
+    size: 24
+  })), /*#__PURE__*/_react.default.createElement("div", {
+    className: "text-20-bold fluid ".concat(_fluid.FluidType[fluidTypes[index]].toLowerCase())
+  }, "".concat(t('FLUID.' + _fluid.FluidType[fluidTypes[index]] + '.LABEL'))), fluidTypes.length > 1 && /*#__PURE__*/_react.default.createElement(_IconButton.default, {
+    "aria-label": t('consumption.accessibility.button_previous_value'),
+    onClick: handleChangeNextFluid,
+    className: "arrow-next"
+  }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
+    icon: _rightArrow.default,
+    size: 24
+  }))), /*#__PURE__*/_react.default.createElement("div", {
     className: "data-container"
-  }, isLoading && /*#__PURE__*/_react.default.createElement("div", {
-    className: "loaderContainer"
-  }, /*#__PURE__*/_react.default.createElement(_Loader.default, {
+  }, isLoading && /*#__PURE__*/_react.default.createElement(_Loader.default, {
     fluidType: fluidTypes[index]
-  })), !isLoading && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !maxDayData && /*#__PURE__*/_react.default.createElement("p", {
+  }), !isLoading && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !maxDayData && /*#__PURE__*/_react.default.createElement("p", {
     className: "text-20-bold no_data"
   }, t('analysis.no_data')), maxDayData && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: "text-24-bold maxDay-date"
-  }, maxDayData.date.setLocale('fr').toFormat('cccc dd LLLL')), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_DataloadSection.default, {
-    dataload: maxDayData,
-    fluidType: fluidTypes[index],
-    dataloadSectionType: _dataload.DataloadSectionType.NO_COMPARE,
-    toggleEstimationModal: function toggleEstimationModal() {
-      return null;
-    }
-  })), /*#__PURE__*/_react.default.createElement(_BarChart.default, {
-    chartData: chartData,
-    fluidType: fluidTypes[index],
-    timeStep: _timeStep.TimeStep.DAY,
-    height: height,
-    width: width,
-    isSwitching: false,
-    clickable: false
-  })))));
+  }, maxDayData.date.setLocale('fr').toFormat('cccc dd LLLL')), /*#__PURE__*/_react.default.createElement(_Icon.default, {
+    className: "dataloadvisualizer-euro-fluid-icon",
+    icon: (0, _picto.getNavPicto)(fluidTypes[index], true, true),
+    size: 38
+  }), /*#__PURE__*/_react.default.createElement("div", {
+    className: "maxDay-load"
+  }, (0, _utils.formatNumberValues)(maxDayData.value, _fluid.FluidType[fluidTypes[index]]), ' ', t("FLUID.".concat(_fluid.FluidType[fluidTypes[index]], ".").concat(maxDayData.value >= 1000 ? 'MEGAUNIT' : 'UNIT')))))));
 };
 
 var _default = MaxConsumptionCard;
@@ -1369,13 +1304,17 @@ var AnalysisView = function AnalysisView() {
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
     return state.ecolyo;
   }),
-      analysisMonth = _useSelector.analysis.analysisMonth,
       selectedDate = _useSelector.chart.selectedDate,
       analysisNotification = _useSelector.global.analysisNotification,
       _useSelector$profile = _useSelector.profile,
       monthlyAnalysisDate = _useSelector$profile.monthlyAnalysisDate,
       mailToken = _useSelector$profile.mailToken;
 
+  var _useState3 = (0, _react.useState)(monthlyAnalysisDate),
+      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
+      currentAnalysisDate = _useState4[0],
+      setCurrentAnalysisDate = _useState4[1];
+
   var dispatch = (0, _reactRedux.useDispatch)();
   var defineHeaderHeight = (0, _react.useCallback)(function (height) {
     setHeaderHeight(height);
@@ -1388,10 +1327,10 @@ var AnalysisView = function AnalysisView() {
   var paramToken = query.get('token');
   var app = document.querySelector('.app-content');
 
-  var _useState3 = (0, _react.useState)(0),
-      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      scrollPosition = _useState4[0],
-      setScrollPosition = _useState4[1];
+  var _useState5 = (0, _react.useState)(0),
+      _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
+      scrollPosition = _useState6[0],
+      setScrollPosition = _useState6[1];
   /** Scroll handling for switching months and staying on the same scroll position */
 
 
@@ -1438,11 +1377,13 @@ var AnalysisView = function AnalysisView() {
     setHeaderHeight: defineHeaderHeight,
     desktopTitleKey: 'common.title_analysis'
   }, /*#__PURE__*/_react.default.createElement(_DateNavigator.default, {
-    currentAnalysisDate: analysisMonth,
+    currentAnalysisDate: currentAnalysisDate,
+    setCurrentAnalysisDate: setCurrentAnalysisDate,
     inlineDateDisplay: true
   })), /*#__PURE__*/_react.default.createElement(_Content.default, {
     height: headerHeight
   }, /*#__PURE__*/_react.default.createElement(_MonthlyAnalysis.default, {
+    analysisDate: currentAnalysisDate,
     saveLastScrollPosition: saveLastScrollPosition,
     scrollPosition: scrollPosition
   })));
@@ -1475,6 +1416,329 @@ var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WE
 
 /***/ }),
 
+/***/ "GrKv":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = void 0;
+
+var _regenerator = _interopRequireDefault(__webpack_require__("o0o1"));
+
+var _asyncToGenerator2 = _interopRequireDefault(__webpack_require__("yXPU"));
+
+var _classCallCheck2 = _interopRequireDefault(__webpack_require__("lwsE"));
+
+var _createClass2 = _interopRequireDefault(__webpack_require__("W8MJ"));
+
+var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
+
+var Sentry = _interopRequireWildcard(__webpack_require__("agHs"));
+
+var _cozyClient = __webpack_require__("SH7X");
+
+var _cozyLogger = _interopRequireDefault(__webpack_require__("Vggm"));
+
+var _doctypes = __webpack_require__("D2hQ");
+
+var _dataload = __webpack_require__("D5WE");
+
+var _luxon = __webpack_require__("ExVU");
+
+var _logger = _interopRequireDefault(__webpack_require__("gjtA"));
+
+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); }
+
+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; }
+
+var logStack = _cozyLogger.default.namespace('enedisMonthlyAnalysisDataService');
+
+var EnedisMonthlyAnalysisDataService = /*#__PURE__*/function () {
+  function EnedisMonthlyAnalysisDataService(_client) {
+    (0, _classCallCheck2.default)(this, EnedisMonthlyAnalysisDataService);
+    (0, _defineProperty2.default)(this, "_client", void 0);
+    (0, _defineProperty2.default)(this, "aggregateValuesToDataLoad", function (data) {
+      var dataLoadWeekDays = [];
+      var dataLoadWeekEndDays = [];
+      data.weekDaysHalfHourAverageValues.forEach(function (value, index) {
+        dataLoadWeekDays.push({
+          value: value,
+          state: _dataload.DataloadState.VALID,
+          valueDetail: null,
+          date: _luxon.DateTime.fromObject({
+            year: data.year,
+            month: data.month,
+            minute: 0
+          }).setZone('utc', {
+            keepLocalTime: true
+          }).plus({
+            minute: 30 * index
+          })
+        });
+      });
+      data.weekEndDaysHalfHourAverageValues.forEach(function (value, index) {
+        dataLoadWeekEndDays.push({
+          value: value,
+          state: _dataload.DataloadState.VALID,
+          valueDetail: null,
+          date: _luxon.DateTime.fromObject({
+            year: data.year,
+            month: data.month,
+            minute: 0
+          }).setZone('utc', {
+            keepLocalTime: true
+          }).plus({
+            minute: 30 * index
+          })
+        });
+      });
+      return {
+        week: dataLoadWeekDays,
+        weekend: dataLoadWeekEndDays
+      };
+    });
+    this._client = _client;
+  }
+  /**
+   * Retrieve all exploration entities from db
+   * @returns {EnedisMonthlyAnalysisData[]}
+   */
+
+
+  (0, _createClass2.default)(EnedisMonthlyAnalysisDataService, [{
+    key: "getAllEnedisMonthlyAnalysisData",
+    value: function () {
+      var _getAllEnedisMonthlyAnalysisData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
+        var query, _yield$this$_client$q, enedisMonthlyAnalysisData;
+
+        return _regenerator.default.wrap(function _callee$(_context) {
+          while (1) {
+            switch (_context.prev = _context.next) {
+              case 0:
+                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE);
+                _context.next = 3;
+                return this._client.query(query);
+
+              case 3:
+                _yield$this$_client$q = _context.sent;
+                enedisMonthlyAnalysisData = _yield$this$_client$q.data;
+                return _context.abrupt("return", enedisMonthlyAnalysisData);
+
+              case 6:
+              case "end":
+                return _context.stop();
+            }
+          }
+        }, _callee, this);
+      }));
+
+      function getAllEnedisMonthlyAnalysisData() {
+        return _getAllEnedisMonthlyAnalysisData.apply(this, arguments);
+      }
+
+      return getAllEnedisMonthlyAnalysisData;
+    }()
+    /**
+     * getLastEnedisMonthlyAnalysis
+     * @param {Client} client
+     * @returns {Promise<EnedisMonthlyAnalysisData[]>}
+     */
+
+  }, {
+    key: "getLastEnedisMonthlyAnalysis",
+    value: function () {
+      var _getLastEnedisMonthlyAnalysis = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
+        var query, data;
+        return _regenerator.default.wrap(function _callee2$(_context2) {
+          while (1) {
+            switch (_context2.prev = _context2.next) {
+              case 0:
+                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({}).sortBy([{
+                  year: 'desc'
+                }, {
+                  month: 'desc'
+                }]).limitBy(1);
+                _context2.next = 3;
+                return this._client.query(query);
+
+              case 3:
+                data = _context2.sent;
+                return _context2.abrupt("return", data.data);
+
+              case 5:
+              case "end":
+                return _context2.stop();
+            }
+          }
+        }, _callee2, this);
+      }));
+
+      function getLastEnedisMonthlyAnalysis() {
+        return _getLastEnedisMonthlyAnalysis.apply(this, arguments);
+      }
+
+      return getLastEnedisMonthlyAnalysis;
+    }()
+    /**
+     * Aggregates Enedis Analysis data in order to create Dataload injectable in graph component
+     * @param {EnedisMonthlyAnalysisData} data
+     * @returns {AggregatedEnedisMonthlyDataloads}
+     */
+
+  }, {
+    key: "getEnedisMonthlyAnalysisByDate",
+    value:
+    /**
+     * Get an enedis monthly analysis for given month and year
+     * @param {number} year
+     * @param {number} month
+     * @returns {Promise<EnedisMonthlyAnalysisData[]>}
+     */
+    function () {
+      var _getEnedisMonthlyAnalysisByDate = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(year, month) {
+        var query, data;
+        return _regenerator.default.wrap(function _callee3$(_context3) {
+          while (1) {
+            switch (_context3.prev = _context3.next) {
+              case 0:
+                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({
+                  year: year,
+                  month: month
+                }).sortBy([{
+                  year: 'desc'
+                }, {
+                  month: 'desc'
+                }]).limitBy(1);
+                _context3.next = 3;
+                return this._client.query(query);
+
+              case 3:
+                data = _context3.sent;
+                return _context3.abrupt("return", data.data);
+
+              case 5:
+              case "end":
+                return _context3.stop();
+            }
+          }
+        }, _callee3, this);
+      }));
+
+      function getEnedisMonthlyAnalysisByDate(_x, _x2) {
+        return _getEnedisMonthlyAnalysisByDate.apply(this, arguments);
+      }
+
+      return getEnedisMonthlyAnalysisByDate;
+    }()
+    /**
+     * Creates a new EnedisMonthlyAnalysis
+     * @param {EnedisMonthlyAnalysisData} newEnedisMonthlyAnalysisData
+     * @returns {Promise<EnedisMonthlyAnalysisData | null>}
+     */
+
+  }, {
+    key: "createEnedisMonthlyAnalysisData",
+    value: function () {
+      var _createEnedisMonthlyAnalysisData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(newEnedisMonthlyAnalysisData) {
+        var _yield$this$_client$c, EnedisMonthlyAnalysis, errorMessage;
+
+        return _regenerator.default.wrap(function _callee4$(_context4) {
+          while (1) {
+            switch (_context4.prev = _context4.next) {
+              case 0:
+                _context4.prev = 0;
+                _context4.next = 3;
+                return this._client.create(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE, newEnedisMonthlyAnalysisData);
+
+              case 3:
+                _yield$this$_client$c = _context4.sent;
+                EnedisMonthlyAnalysis = _yield$this$_client$c.data;
+                return _context4.abrupt("return", EnedisMonthlyAnalysis);
+
+              case 8:
+                _context4.prev = 8;
+                _context4.t0 = _context4["catch"](0);
+                errorMessage = "Error creating new EnedisMonthlyAnalysis: ".concat(JSON.stringify(_context4.t0));
+                logStack('error', errorMessage);
+
+                _logger.default.error(errorMessage);
+
+                Sentry.captureException(errorMessage);
+                throw _context4.t0;
+
+              case 15:
+              case "end":
+                return _context4.stop();
+            }
+          }
+        }, _callee4, this, [[0, 8]]);
+      }));
+
+      function createEnedisMonthlyAnalysisData(_x3) {
+        return _createEnedisMonthlyAnalysisData.apply(this, arguments);
+      }
+
+      return createEnedisMonthlyAnalysisData;
+    }()
+    /**
+     * Get Max power for a given month and year
+     * @param {number} year
+     * @param {number} month
+     * @returns {Promise<MaxPowerEntity[]>}
+     */
+
+  }, {
+    key: "getMaxPowerByDate",
+    value: function () {
+      var _getMaxPowerByDate = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(year, month) {
+        var query, data;
+        return _regenerator.default.wrap(function _callee5$(_context5) {
+          while (1) {
+            switch (_context5.prev = _context5.next) {
+              case 0:
+                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MAXPOWER_DOCTYPE).where({
+                  year: year,
+                  month: month
+                }).sortBy([{
+                  year: 'desc'
+                }, {
+                  month: 'desc'
+                }]);
+                _context5.next = 3;
+                return this._client.query(query);
+
+              case 3:
+                data = _context5.sent;
+                return _context5.abrupt("return", data.data);
+
+              case 5:
+              case "end":
+                return _context5.stop();
+            }
+          }
+        }, _callee5, this);
+      }));
+
+      function getMaxPowerByDate(_x4, _x5) {
+        return _getMaxPowerByDate.apply(this, arguments);
+      }
+
+      return getMaxPowerByDate;
+    }()
+  }]);
+  return EnedisMonthlyAnalysisDataService;
+}();
+
+exports.default = EnedisMonthlyAnalysisDataService;
+
+/***/ }),
+
 /***/ "JvyT":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -1531,8 +1795,6 @@ var _timeStep = __webpack_require__("cKQ8");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 var _consumption = _interopRequireDefault(__webpack_require__("AVq/"));
 
 var _enedisMonthlyAnalysisData = _interopRequireDefault(__webpack_require__("GrKv"));
@@ -1550,18 +1812,14 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 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; }
 
 var ElecHalfHourMonthlyAnalysis = function ElecHalfHourMonthlyAnalysis(_ref) {
-  var perfIndicator = _ref.perfIndicator;
+  var analysisDate = _ref.analysisDate,
+      perfIndicator = _ref.perfIndicator;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
   var client = (0, _cozyClient.useClient)();
 
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.analysis;
-  }),
-      analysisMonth = _useSelector.analysisMonth;
-
   var _useState = (0, _react.useState)(true),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       isWeekend = _useState2[0],
@@ -1666,7 +1924,7 @@ var ElecHalfHourMonthlyAnalysis = function ElecHalfHourMonthlyAnalysis(_ref) {
                 }
 
                 emas = new _enedisMonthlyAnalysisData.default(client);
-                aggregatedDate = analysisMonth.minus({
+                aggregatedDate = analysisDate.minus({
                   month: 1
                 });
                 _context.next = 11;
@@ -1709,7 +1967,7 @@ var ElecHalfHourMonthlyAnalysis = function ElecHalfHourMonthlyAnalysis(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [analysisMonth, client, perfIndicator]);
+  }, [analysisDate, client, perfIndicator]);
   (0, _react.useEffect)(function () {
     var subscribed = true;
     var fluidsPricesService = new _fluidsPrices.default(client);
@@ -1726,7 +1984,7 @@ var ElecHalfHourMonthlyAnalysis = function ElecHalfHourMonthlyAnalysis(_ref) {
             switch (_context2.prev = _context2.next) {
               case 0:
                 _context2.next = 2;
-                return fluidsPricesService.getPrices(_fluid.FluidType.ELECTRICITY, analysisMonth.minus({
+                return fluidsPricesService.getPrices(_fluid.FluidType.ELECTRICITY, analysisDate.minus({
                   month: 1
                 }));
 
@@ -1751,7 +2009,7 @@ var ElecHalfHourMonthlyAnalysis = function ElecHalfHourMonthlyAnalysis(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [analysisMonth, client]);
+  }, [analysisDate, client]);
   return /*#__PURE__*/_react.default.createElement("div", {
     className: "special-elec-container"
   }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
@@ -1898,37 +2156,43 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 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; }
 
 var MonthlyAnalysis = function MonthlyAnalysis(_ref) {
-  var saveLastScrollPosition = _ref.saveLastScrollPosition,
+  var analysisDate = _ref.analysisDate,
+      saveLastScrollPosition = _ref.saveLastScrollPosition,
       scrollPosition = _ref.scrollPosition;
   var client = (0, _cozyClient.useClient)();
 
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo;
+    return state.ecolyo.global;
   }),
-      analysisMonth = _useSelector.analysis.analysisMonth,
-      fluidTypes = _useSelector.global.fluidTypes;
+      fluidTypes = _useSelector.fluidTypes;
 
   var _useState = (0, _react.useState)([]),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       performanceIndicators = _useState2[0],
       setPerformanceIndicators = _useState2[1];
 
-  var _useState3 = (0, _react.useState)({
+  var _useState3 = (0, _react.useState)(false),
+      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
+      loadAnalysis = _useState4[0],
+      setLoadAnalysis = _useState4[1];
+
+  var _useState5 = (0, _react.useState)({
     value: 0,
     compareValue: 0,
     percentageVariation: 0
   }),
-      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      aggregatedPerformanceIndicators = _useState4[0],
-      setAggregatedPerformanceIndicators = _useState4[1];
-
-  var _useState5 = (0, _react.useState)(true),
       _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
-      loadAnalysis = _useState6[0],
-      setLoadAnalysis = _useState6[1];
+      aggregatedPerformanceIndicators = _useState6[0],
+      setAggregatedPerformanceIndicators = _useState6[1];
+
+  var _useState7 = (0, _react.useState)(true),
+      _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
+      isLoading = _useState8[0],
+      setIsLoading = _useState8[1];
 
   var configService = new _fluidConfig.default();
   var fluidConfig = configService.getFluidConfig();
+  var timeStep = _timeStep.TimeStep.MONTH;
   (0, _react.useEffect)(function () {
     var subscribed = true;
 
@@ -1943,29 +2207,29 @@ var MonthlyAnalysis = function MonthlyAnalysis(_ref) {
           while (1) {
             switch (_context.prev = _context.next) {
               case 0:
-                setLoadAnalysis(true);
+                setIsLoading(true);
                 consumptionService = new _consumption.default(client);
                 performanceIndicatorService = new _performanceIndicator.default();
                 periods = {
                   timePeriod: {
-                    startDate: analysisMonth.minus({
+                    startDate: analysisDate.minus({
                       month: 1
                     }).startOf('month'),
-                    endDate: analysisMonth.minus({
+                    endDate: analysisDate.minus({
                       month: 1
                     }).endOf('month')
                   },
                   comparisonTimePeriod: {
-                    startDate: analysisMonth.minus({
+                    startDate: analysisDate.minus({
                       month: 2
                     }).startOf('month'),
-                    endDate: analysisMonth.minus({
+                    endDate: analysisDate.minus({
                       month: 2
                     }).endOf('month')
                   }
                 };
                 _context.next = 6;
-                return consumptionService.getPerformanceIndicators(periods.timePeriod, _timeStep.TimeStep.MONTH, fluidTypes, periods.comparisonTimePeriod);
+                return consumptionService.getPerformanceIndicators(periods.timePeriod, timeStep, fluidTypes, periods.comparisonTimePeriod);
 
               case 6:
                 fetchedPerformanceIndicators = _context.sent;
@@ -1981,7 +2245,7 @@ var MonthlyAnalysis = function MonthlyAnalysis(_ref) {
                     setAggregatedPerformanceIndicators(performanceIndicatorService.aggregatePerformanceIndicators(fetchedPerformanceIndicators));
                   }
 
-                  setLoadAnalysis(false);
+                  setIsLoading(false);
                 }
 
               case 8:
@@ -1999,47 +2263,53 @@ var MonthlyAnalysis = function MonthlyAnalysis(_ref) {
       saveLastScrollPosition();
       subscribed = false;
     };
-  }, [client, fluidTypes, analysisMonth, saveLastScrollPosition]);
+  }, [client, timeStep, fluidTypes, analysisDate, saveLastScrollPosition]);
   (0, _react.useEffect)(function () {
-    if (!loadAnalysis) {
+    if (!isLoading) {
       var app = document.querySelector('.app-content');
       window.scrollTo(0, scrollPosition);
       app === null || app === void 0 ? void 0 : app.scrollTo(0, scrollPosition);
     }
-  }, [loadAnalysis, scrollPosition]);
-  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, loadAnalysis && /*#__PURE__*/_react.default.createElement("div", {
+  }, [isLoading, scrollPosition]);
+  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isLoading && /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-container-spinner",
     "aria-busy": "true"
-  }, /*#__PURE__*/_react.default.createElement(_Loader.default, null)), !loadAnalysis && /*#__PURE__*/_react.default.createElement("div", {
+  }, /*#__PURE__*/_react.default.createElement(_Loader.default, null)), !isLoading && /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-root black"
   }, fluidTypes.length >= 1 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-content"
   }, /*#__PURE__*/_react.default.createElement(_ComparisonView.default, {
+    analysisDate: analysisDate,
     fluidConfig: fluidConfig
-  })), /*#__PURE__*/_react.default.createElement("div", {
+  })), loadAnalysis && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-content"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: "card rich-card"
   }, /*#__PURE__*/_react.default.createElement(_TotalAnalysisChart.default, {
+    analysisDate: analysisDate,
     fluidTypes: fluidTypes
   }))), /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-content"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: "card rich-card"
-  }, /*#__PURE__*/_react.default.createElement(_MaxConsumptionCard.default, null))), /*#__PURE__*/_react.default.createElement("div", {
+  }, /*#__PURE__*/_react.default.createElement(_MaxConsumptionCard.default, {
+    analysisDate: analysisDate
+  }))), /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-content"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: "card rich-card"
   }, /*#__PURE__*/_react.default.createElement(_AnalysisConsumption.default, {
     aggregatedPerformanceIndicator: aggregatedPerformanceIndicators,
-    performanceIndicators: performanceIndicators
+    performanceIndicators: performanceIndicators,
+    analysisDate: analysisDate
   }))), fluidTypes.includes(_fluid.FluidType.ELECTRICITY) && /*#__PURE__*/_react.default.createElement("div", {
     className: "analysis-content"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: "card"
   }, /*#__PURE__*/_react.default.createElement(_ElecHalfHourMonthlyAnalysis.default, {
+    analysisDate: analysisDate,
     perfIndicator: performanceIndicators[_fluid.FluidType.ELECTRICITY]
-  })))) : /*#__PURE__*/_react.default.createElement(_AnalysisErrorModal.default, null)));
+  }))))) : /*#__PURE__*/_react.default.createElement(_AnalysisErrorModal.default, null)));
 };
 
 var _default = MonthlyAnalysis;
@@ -2587,7 +2857,7 @@ var ElecHalfHourChart = function ElecHalfHourChart(_ref) {
       isWeekend = _ref.isWeekend;
   var chartContainer = (0, _react.useRef)(null);
 
-  var _useChartResize = (0, _useChartResize2.useChartResize)(chartContainer, false, 170, 940),
+  var _useChartResize = (0, _useChartResize2.useChartResize)(chartContainer, 170, 940),
       height = _useChartResize.height,
       width = _useChartResize.width;
 
@@ -2838,7 +3108,7 @@ exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.max-consumption-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  color: #ffffff;\n}\n.max-consumption-container .title {\n  color: #e0e0e0;\n  margin: 1rem 0 0.7rem 0;\n  text-align: center;\n}\n.max-consumption-container .fluid-navigation {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n}\n.max-consumption-container .fluid-navigation div {\n  font-weight: 900;\n}\n.max-consumption-container .fluid {\n  min-width: 120px;\n  text-align: center;\n  margin: auto;\n}\n.max-consumption-container .electricity {\n  color: #d87b39;\n}\n.max-consumption-container .water {\n  color: #3a98ec;\n}\n.max-consumption-container .gas {\n  color: #45d1b8;\n}\n.max-consumption-container .no_data {\n  color: white;\n}\n.max-consumption-container .data-container {\n  min-height: 130px;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: center;\n}\n.max-consumption-container .data-container .loaderContainer {\n  height: 22rem;\n  display: flex;\n}\n.max-consumption-container .data-container .maxDay-date {\n  text-transform: capitalize;\n  margin: 0.5rem 0;\n  text-align: center;\n}\n.max-consumption-container .data-container .maxDay-load span {\n  font-size: 2rem;\n  font-weight: 700;\n}\n\n.dataloadvisualizer-section {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.max-consumption-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  color: #ffffff;\n}\n.max-consumption-container .title {\n  color: #e0e0e0;\n  margin: 1rem 0 0.7rem 0;\n  text-align: center;\n}\n.max-consumption-container .fluid-navigation {\n  display: flex;\n  justify-content: space-between;\n  align-items: center;\n  width: 100%;\n}\n.max-consumption-container .fluid {\n  min-width: 120px;\n  text-align: center;\n  margin: auto;\n}\n.max-consumption-container .electricity {\n  color: #d87b39;\n}\n.max-consumption-container .water {\n  color: #3a98ec;\n}\n.max-consumption-container .gas {\n  color: #45d1b8;\n}\n.max-consumption-container .no_data {\n  color: white;\n}\n.max-consumption-container .data-container {\n  min-height: 130px;\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: center;\n}\n.max-consumption-container .data-container .maxDay-date {\n  text-transform: capitalize;\n  margin: 0.8rem;\n  text-align: center;\n}", ""]);
 
 
 
diff --git a/4/ecolyo.f22d2e8508212a56cb53.js b/4/ecolyo.4bdc1836bb506dfd5fea.js
similarity index 92%
rename from 4/ecolyo.f22d2e8508212a56cb53.js
rename to 4/ecolyo.4bdc1836bb506dfd5fea.js
index debf88d5c257f40c5cd7d0f1add0dad7430712ac..8484462a5fda2fdd74075ebfe42b2b0d044de178 100644
--- a/4/ecolyo.f22d2e8508212a56cb53.js
+++ b/4/ecolyo.4bdc1836bb506dfd5fea.js
@@ -16,7 +16,7 @@ exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.expansion-panel-root,\ndiv.expansion-panel-root.Mui-expanded:last-child {\n  margin: 0.2rem 0;\n}\n\n.export-option-root {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  margin-top: 0.5rem;\n  padding: 0 1.5rem;\n}\n\n.export-option-content {\n  width: 45.75rem;\n}\n@media only screen and (max-width : 768px) {\n  .export-option-content {\n    width: 100%;\n  }\n}\n.export-option-content .MuiAccordionSummary-content {\n  margin: 0;\n}\n.export-option-content .MuiIconButton-edgeEnd {\n  margin: 0;\n}\n.export-option-content .accordion-title {\n  color: #ffffff;\n}\n.export-option-content .expansion-panel-details {\n  flex-direction: column;\n}\n.export-option-content .expansion-panel-details .content {\n  padding-bottom: 16px;\n}\n.export-option-content .expansion-panel-details .intro {\n  color: #a0a0a0;\n}\n.export-option-content .expansion-panel-details .btn-secondary-negative {\n  border-color: #e0e0e0 !important;\n  height: 40px;\n}\n.export-option-content .expansion-panel-details .checkbox {\n  margin: 0;\n}\n.export-option-content .expansion-panel-details .checkbox input {\n  margin: 0.5rem;\n  border: 1px solid #a0a0a0;\n  border-radius: 2px;\n}\n.export-option-content .expansion-panel-details .answer-checked input:before,\n.export-option-content .expansion-panel-details .answer-checked input:after {\n  background: black;\n}\n.export-option-content .expansion-panel-details .answer-checked input {\n  background: #e3b82a;\n  border: 2px solid #e3b82a;\n}\n.export-option-content .expansion-panel-details .answer-checked input:before {\n  height: 13px;\n  left: 11px;\n  top: 3px;\n}\n.export-option-content .expansion-panel-details .answer-checked input:after {\n  height: 9px;\n  left: 4px;\n}\n.export-option-content div.expansion-panel-summary {\n  padding: 0 0.25rem 0 1rem;\n}\n.export-option-content div.expansion-panel-summary .expansion-panel-content {\n  gap: 1rem;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.expansion-panel-root,\ndiv.expansion-panel-root.Mui-expanded:last-child {\n  margin: 0.2rem 0;\n}\n\n.export-option-root {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  margin-top: 0.5rem;\n  padding: 0 1.5rem;\n}\n\n.export-option-content {\n  width: 45.75rem;\n}\n@media only screen and (max-width : 768px) {\n  .export-option-content {\n    width: 100%;\n  }\n}\n.export-option-content .MuiAccordionSummary-content {\n  margin: 0;\n}\n.export-option-content .MuiIconButton-edgeEnd {\n  margin: 0;\n}\n.export-option-content .accordion-title {\n  padding-left: 1rem;\n  color: #ffffff;\n}\n.export-option-content .expansion-panel-details {\n  flex-direction: column;\n}\n.export-option-content .expansion-panel-details .content {\n  padding-bottom: 16px;\n}\n.export-option-content .expansion-panel-details .intro {\n  color: #a0a0a0;\n}\n.export-option-content .expansion-panel-details .btn-secondary-negative {\n  border-color: #e0e0e0 !important;\n  height: 40px;\n}\n.export-option-content .expansion-panel-details .checkbox {\n  margin: 0;\n}\n.export-option-content .expansion-panel-details .checkbox input {\n  margin: 0.5rem;\n  border: 1px solid #a0a0a0;\n  border-radius: 2px;\n}\n.export-option-content .expansion-panel-details .answer-checked input:before,\n.export-option-content .expansion-panel-details .answer-checked input:after {\n  background: black;\n}\n.export-option-content .expansion-panel-details .answer-checked input {\n  background: #e3b82a;\n  border: 2px solid #e3b82a;\n}\n.export-option-content .expansion-panel-details .answer-checked input:before {\n  height: 13px;\n  left: 11px;\n  top: 3px;\n}\n.export-option-content .expansion-panel-details .answer-checked input:after {\n  height: 9px;\n  left: 4px;\n}\n.export-option-content div.expansion-panel-summary {\n  padding: 0 0.25rem 0 1rem;\n}", ""]);
 
 
 
@@ -1145,29 +1145,27 @@ var _core = __webpack_require__("TTf+");
 
 var _Dialog = _interopRequireDefault(__webpack_require__("HhgX"));
 
+var _close = _interopRequireDefault(__webpack_require__("aodS"));
+
+var _Loader = _interopRequireDefault(__webpack_require__("Ra/y"));
+
 var _cozyClient = __webpack_require__("SH7X");
 
 var _I18n = __webpack_require__("buk/");
 
 var _Icon = _interopRequireDefault(__webpack_require__("y6ex"));
 
-var _fileSaver = _interopRequireDefault(__webpack_require__("Iab2"));
-
-var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
-
-var XLSX = _interopRequireWildcard(__webpack_require__("JcrP"));
-
-var _close = _interopRequireDefault(__webpack_require__("aodS"));
-
-var _Loader = _interopRequireDefault(__webpack_require__("Ra/y"));
-
 var _fluid = __webpack_require__("5Wkc");
 
 var _timeStep = __webpack_require__("cKQ8");
 
+var FileSaver = _interopRequireWildcard(__webpack_require__("Iab2"));
+
+var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
+
 var _consumption = _interopRequireDefault(__webpack_require__("AVq/"));
 
-var _enedisMonthlyAnalysisData = _interopRequireDefault(__webpack_require__("GrKv"));
+var XLSX = _interopRequireWildcard(__webpack_require__("JcrP"));
 
 __webpack_require__("YEWe");
 
@@ -1175,7 +1173,7 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 
 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; }
 
-function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function (_e) { function e(_x4) { return _e.apply(this, arguments); } e.toString = function () { return _e.toString(); }; return e; }(function (e) { throw e; }), f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function (_e2) { function e(_x5) { return _e2.apply(this, arguments); } e.toString = function () { return _e2.toString(); }; return e; }(function (e) { didErr = true; err = e; }), f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
+function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function (_e) { function e(_x2) { return _e.apply(this, arguments); } e.toString = function () { return _e.toString(); }; return e; }(function (e) { throw e; }), f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function (_e2) { function e(_x3) { return _e2.apply(this, arguments); } e.toString = function () { return _e2.toString(); }; return e; }(function (e) { didErr = true; err = e; }), f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
 
 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); }
 
@@ -1219,233 +1217,152 @@ var ExportLoadingModal = function ExportLoadingModal(_ref) {
     var data = new Blob([excelBuffer], {
       type: fileType
     });
-
-    _fileSaver.default.saveAs(data, fileName + fileExtension);
+    FileSaver.saveAs(data, fileName + fileExtension);
   };
 
-  var buildDataRow = (0, _react.useCallback)( /*#__PURE__*/function () {
-    var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(dataload, fluidType) {
-      var dataRow, emas, maxPowerEntities, maxLoad;
+  var getExportDataFluid = (0, _react.useCallback)( /*#__PURE__*/function () {
+    var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(fluidType) {
+      var consumptionService, firstDataDate, lastDataDate, timePeriod, dataLoad, exportDataFluid, _iterator2, _step2, data, dataRow;
+
       return _regenerator.default.wrap(function _callee$(_context) {
         while (1) {
           switch (_context.prev = _context.next) {
-            case 0:
-              dataRow = {};
-              dataRow[t('export.month')] = dataload.date.month.toString().padStart(2, '0');
-              dataRow[t('export.year')] = dataload.date.year;
-              dataRow["".concat(t('export.consumption'), " (").concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT'), ")")] = dataload.value;
-
-              if (!(fluidType === _fluid.FluidType.ELECTRICITY)) {
-                _context.next = 10;
-                break;
-              }
-
-              emas = new _enedisMonthlyAnalysisData.default(client);
-              _context.next = 8;
-              return emas.getMaxPowerByDate(dataload.date.year, dataload.date.month);
-
-            case 8:
-              maxPowerEntities = _context.sent;
-
-              if (maxPowerEntities) {
-                maxLoad = maxPowerEntities.reduce(function (max, entity) {
-                  if (entity.load > max) {
-                    return entity.load;
-                  }
-
-                  return max;
-                }, 0);
-                dataRow[t('export.maxpower')] = maxLoad;
-              }
-
-            case 10:
-              return _context.abrupt("return", dataRow);
-
-            case 11:
-            case "end":
-              return _context.stop();
-          }
-        }
-      }, _callee);
-    }));
-
-    return function (_x, _x2) {
-      return _ref2.apply(this, arguments);
-    };
-  }(), [client, t]);
-  var getExportDataSheet = (0, _react.useCallback)( /*#__PURE__*/function () {
-    var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(fluidType) {
-      var consumptionService, firstDataDate, lastDataDate, timePeriod, dataLoad, exportDataSheet, _iterator2, _step2, data, dataRow;
-
-      return _regenerator.default.wrap(function _callee2$(_context2) {
-        while (1) {
-          switch (_context2.prev = _context2.next) {
             case 0:
               consumptionService = new _consumption.default(client);
-              _context2.next = 3;
+              _context.next = 3;
               return consumptionService.fetchAllFirstDateData([fluidType], _timeStep.TimeStep.MONTH);
 
             case 3:
-              firstDataDate = _context2.sent;
-              _context2.next = 6;
+              firstDataDate = _context.sent;
+              _context.next = 6;
               return consumptionService.fetchAllLastDateData([fluidType], _timeStep.TimeStep.MONTH);
 
             case 6:
-              lastDataDate = _context2.sent;
+              lastDataDate = _context.sent;
 
               if (!(!firstDataDate[0] || !lastDataDate[0])) {
-                _context2.next = 9;
+                _context.next = 9;
                 break;
               }
 
-              return _context2.abrupt("return", null);
+              return _context.abrupt("return", null);
 
             case 9:
               timePeriod = {
                 startDate: firstDataDate[0],
                 endDate: lastDataDate[0]
               };
-              _context2.next = 12;
+              _context.next = 12;
               return consumptionService.getGraphData(timePeriod, _timeStep.TimeStep.MONTH, [fluidType], undefined, undefined, false, true);
 
             case 12:
-              dataLoad = _context2.sent;
+              dataLoad = _context.sent;
 
-              if (dataLoad !== null && dataLoad !== void 0 && dataLoad.actualData) {
-                _context2.next = 15;
+              if (!(dataLoad !== null && dataLoad !== void 0 && dataLoad.actualData)) {
+                _context.next = 20;
                 break;
               }
 
-              return _context2.abrupt("return", null);
-
-            case 15:
-              exportDataSheet = {
-                fluidName: t('FLUID.' + _fluid.FluidType[fluidType] + '.LABEL'),
-                data: []
-              };
+              exportDataFluid = {};
+              exportDataFluid.fluidName = t('FLUID.' + _fluid.FluidType[fluidType] + '.LABEL');
+              exportDataFluid.data = [];
               _iterator2 = _createForOfIteratorHelper(dataLoad.actualData);
-              _context2.prev = 17;
-
-              _iterator2.s();
 
-            case 19:
-              if ((_step2 = _iterator2.n()).done) {
-                _context2.next = 29;
-                break;
-              }
-
-              data = _step2.value;
+              try {
+                for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
+                  data = _step2.value;
 
-              if (!(data.value === -1)) {
-                _context2.next = 23;
-                break;
+                  if (data.value != -1) {
+                    dataRow = {};
+                    dataRow[t('export.month')] = data.date.month.toString().padStart(2, '0');
+                    dataRow[t('export.year')] = data.date.year;
+                    dataRow["".concat(t('export.consumption'), " (").concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT'), ")")] = data.value;
+                    exportDataFluid.data.push(dataRow);
+                  }
+                }
+              } catch (err) {
+                _iterator2.e(err);
+              } finally {
+                _iterator2.f();
               }
 
-              return _context2.abrupt("continue", 27);
-
-            case 23:
-              _context2.next = 25;
-              return buildDataRow(data, fluidType);
-
-            case 25:
-              dataRow = _context2.sent;
-              exportDataSheet.data.push(dataRow);
-
-            case 27:
-              _context2.next = 19;
-              break;
-
-            case 29:
-              _context2.next = 34;
-              break;
-
-            case 31:
-              _context2.prev = 31;
-              _context2.t0 = _context2["catch"](17);
-
-              _iterator2.e(_context2.t0);
+              return _context.abrupt("return", exportDataFluid);
 
-            case 34:
-              _context2.prev = 34;
+            case 20:
+              return _context.abrupt("return", null);
 
-              _iterator2.f();
-
-              return _context2.finish(34);
-
-            case 37:
-              return _context2.abrupt("return", exportDataSheet);
-
-            case 38:
+            case 21:
             case "end":
-              return _context2.stop();
+              return _context.stop();
           }
         }
-      }, _callee2, null, [[17, 31, 34, 37]]);
+      }, _callee);
     }));
 
-    return function (_x3) {
-      return _ref3.apply(this, arguments);
+    return function (_x) {
+      return _ref2.apply(this, arguments);
     };
-  }(), [buildDataRow, client, t]);
+  }(), [client, t]);
   (0, _react.useEffect)(function () {
     var subscribed = true;
     var date = new Date();
 
-    var exportData = /*#__PURE__*/function () {
-      var _ref4 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3() {
+    function exportData() {
+      return _exportData.apply(this, arguments);
+    }
+
+    function _exportData() {
+      _exportData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
         var exportDataSheets, _iterator3, _step3, fluidType, exportDataFluid;
 
-        return _regenerator.default.wrap(function _callee3$(_context3) {
+        return _regenerator.default.wrap(function _callee2$(_context2) {
           while (1) {
-            switch (_context3.prev = _context3.next) {
+            switch (_context2.prev = _context2.next) {
               case 0:
-                _context3.prev = 0;
+                _context2.prev = 0;
                 exportDataSheets = [];
                 _iterator3 = _createForOfIteratorHelper(selectedFluids);
-                _context3.prev = 3;
+                _context2.prev = 3;
 
                 _iterator3.s();
 
               case 5:
                 if ((_step3 = _iterator3.n()).done) {
-                  _context3.next = 13;
+                  _context2.next = 13;
                   break;
                 }
 
                 fluidType = _step3.value;
-                _context3.next = 9;
-                return getExportDataSheet(fluidType);
+                _context2.next = 9;
+                return getExportDataFluid(fluidType);
 
               case 9:
-                exportDataFluid = _context3.sent;
-
-                if (exportDataFluid) {
-                  exportDataSheets.push(exportDataFluid);
-                }
+                exportDataFluid = _context2.sent;
+                if (exportDataFluid) exportDataSheets.push(exportDataFluid);
 
               case 11:
-                _context3.next = 5;
+                _context2.next = 5;
                 break;
 
               case 13:
-                _context3.next = 18;
+                _context2.next = 18;
                 break;
 
               case 15:
-                _context3.prev = 15;
-                _context3.t0 = _context3["catch"](3);
+                _context2.prev = 15;
+                _context2.t0 = _context2["catch"](3);
 
-                _iterator3.e(_context3.t0);
+                _iterator3.e(_context2.t0);
 
               case 18:
-                _context3.prev = 18;
+                _context2.prev = 18;
 
                 _iterator3.f();
 
-                return _context3.finish(18);
+                return _context2.finish(18);
 
               case 21:
-                _context3.next = 23;
+                _context2.next = 23;
                 return new Promise(function (r) {
                   return setTimeout(r, 2000);
                 });
@@ -1456,26 +1373,23 @@ var ExportLoadingModal = function ExportLoadingModal(_ref) {
                   handleDone();
                 }
 
-                _context3.next = 29;
+                _context2.next = 29;
                 break;
 
               case 26:
-                _context3.prev = 26;
-                _context3.t1 = _context3["catch"](0);
-                handleDone(_context3.t1);
+                _context2.prev = 26;
+                _context2.t1 = _context2["catch"](0);
+                handleDone(_context2.t1);
 
               case 29:
               case "end":
-                return _context3.stop();
+                return _context2.stop();
             }
           }
-        }, _callee3, null, [[0, 26], [3, 15, 18, 21]]);
+        }, _callee2, null, [[0, 26], [3, 15, 18, 21]]);
       }));
-
-      return function exportData() {
-        return _ref4.apply(this, arguments);
-      };
-    }();
+      return _exportData.apply(this, arguments);
+    }
 
     if (subscribed) {
       exportData();
@@ -1484,7 +1398,7 @@ var ExportLoadingModal = function ExportLoadingModal(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [getExportDataSheet, handleDone, selectedFluids]);
+  }, [client, getExportDataFluid, handleDone, selectedFluids, t]);
   return /*#__PURE__*/_react.default.createElement(_Dialog.default, {
     open: open,
     onClose: function onClose(_event, reason) {
@@ -1492,13 +1406,13 @@ var ExportLoadingModal = function ExportLoadingModal(_ref) {
         handleCloseClick();
       }
     },
-    "aria-labelledby": "accessibility-title",
+    "aria-labelledby": 'accessibility-title',
     classes: {
       root: 'modal-root',
       paper: 'modal-paper'
     }
   }, /*#__PURE__*/_react.default.createElement("div", {
-    id: "accessibility-title"
+    id: 'accessibility-title'
   }, t('export.modal_loading.accessibility_title')), /*#__PURE__*/_react.default.createElement("div", {
     className: "modal-loading-root"
   }, /*#__PURE__*/_react.default.createElement("div", {
@@ -1522,7 +1436,9 @@ var ExportLoadingModal = function ExportLoadingModal(_ref) {
     className: "text-16-normal text"
   }, t('export.modal_loading.text2')), /*#__PURE__*/_react.default.createElement(_core.Button, {
     "aria-label": t('export.modal_loading.button_cancel'),
-    onClick: handleCloseClick,
+    onClick: function onClick() {
+      handleCloseClick();
+    },
     classes: {
       root: 'btn-secondary-negative',
       label: 'text-16-bold'
@@ -2179,8 +2095,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.default = void 0;
 
-var _extends2 = _interopRequireDefault(__webpack_require__("pVnL"));
-
 var _objectWithoutProperties2 = _interopRequireDefault(__webpack_require__("QILm"));
 
 var _CardActionArea = _interopRequireDefault(__webpack_require__("9pVe"));
@@ -2189,38 +2103,70 @@ var _CardContent = _interopRequireDefault(__webpack_require__("7/eH"));
 
 var _styles = __webpack_require__("DfQ9");
 
-var _react = _interopRequireDefault(__webpack_require__("q1tI"));
+var _fluid = __webpack_require__("5Wkc");
 
-var _utils = __webpack_require__("c+yx");
+var _react = _interopRequireDefault(__webpack_require__("q1tI"));
 
-var _excluded = ["fluidType", "children", "className"];
+var _excluded = ["fluidType"];
 var CardBase = (0, _styles.withStyles)({
   root: {
     background: 'var(--greyLinearGradientBackground)',
     boxSizing: 'border-box',
     boxShadow: '0px 4px 8px rgba(0, 0, 0, 0.75)',
-    borderRadius: '4px'
+    borderRadius: '4px',
+    margin: '10px 0px 10px 0px'
   }
 })(_CardActionArea.default);
+var CardElec = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--elecColor40)'
+  }
+})(CardBase);
+var CardWater = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--waterColor40)'
+  }
+})(CardBase);
+var CardGas = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--gasColor40)'
+  }
+})(CardBase);
+var CardMulti = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var( --greyDark)'
+  }
+})(CardBase);
 var CardContentBase = (0, _styles.withStyles)({
   root: {
-    color: 'white',
-    display: 'flex',
-    alignItems: 'center',
-    gap: '1rem',
-    boxSizing: 'border-box'
+    color: 'white'
   }
 })(_CardContent.default);
 
+var GenerateContentCard = function GenerateContentCard(fluidType, children) {
+  return /*#__PURE__*/_react.default.createElement(CardContentBase, null, children);
+};
+
 var StyledCard = function StyledCard(_ref) {
   var fluidType = _ref.fluidType,
-      children = _ref.children,
-      className = _ref.className,
       props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
-  var cardClass = className + (fluidType !== undefined ? " ".concat((0, _utils.getFluidName)(fluidType)) : '');
-  return /*#__PURE__*/_react.default.createElement(CardBase, (0, _extends2.default)({}, props, {
-    className: cardClass
-  }), /*#__PURE__*/_react.default.createElement(CardContentBase, null, children));
+
+  switch (fluidType) {
+    case _fluid.FluidType.ELECTRICITY:
+      return /*#__PURE__*/_react.default.createElement(CardElec, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.WATER:
+      return /*#__PURE__*/_react.default.createElement(CardWater, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.GAS:
+      return /*#__PURE__*/_react.default.createElement(CardGas, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.MULTIFLUID:
+      return /*#__PURE__*/_react.default.createElement(CardMulti, props, GenerateContentCard(fluidType, props.children));
+
+    default:
+      return /*#__PURE__*/_react.default.createElement(CardBase, props, /*#__PURE__*/_react.default.createElement(CardContentBase, null, props.children));
+  }
 };
 
 var _default = StyledCard;
@@ -2298,7 +2244,7 @@ exports.default = _default;
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.profile-type-root {\n  margin-top: 1.5rem;\n  padding: 0 1.5rem;\n}\n.profile-type-root .profile-type-content {\n  margin: 0 auto;\n  width: 100%;\n}\n@media (min-width: 768px) {\n  .profile-type-root .profile-type-content {\n    width: 45.75rem;\n  }\n}\n.profile-type-root .profile-type-content .MuiButtonBase-root {\n  height: 40px;\n  margin: 0;\n}\n.profile-type-root .profile-type-content .btn-secondary-negative {\n  border-color: #e0e0e0;\n  height: 40px;\n}\n.profile-type-root .value {\n  color: #ffffff;\n  padding: 0 0 0.5rem 0;\n}\n.profile-type-root ul {\n  display: flex;\n  flex-wrap: wrap;\n  padding: 0;\n  margin-top: 0;\n}\n.profile-type-root ul li {\n  list-style-type: none;\n  margin-right: 0.5rem;\n}\n.profile-type-root .head {\n  color: #e0e0e0;\n  margin-bottom: 1rem;\n}\n.profile-type-root .label {\n  color: #a0a0a0;\n  padding-bottom: 0.5rem;\n}\n.profile-type-root .profile-container {\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  width: 100%;\n  margin: 0 1.3rem 1rem;\n}\n@media only screen and (max-width : 768px) {\n  .profile-type-root .profile-container {\n    margin: 0 0 0.25rem;\n  }\n}\n.profile-type-root .fields {\n  align-items: flex-start;\n  padding: 8px 0px;\n  width: 100%;\n}\n.profile-type-root .profile-title {\n  padding-left: 1rem;\n}\n.profile-type-root button.profile-link {\n  height: 64px !important;\n}\n.profile-type-root button.profile-link .profile-icon {\n  vertical-align: middle;\n}\n.profile-type-root button.profile-link > button {\n  margin-bottom: 0;\n}\n.profile-type-root button.profile-link > button > div {\n  padding: 0.3rem 1rem;\n}\n.profile-type-root div.expansion-panel-summary {\n  padding: 0 0.25rem 0 1rem;\n}\n.profile-type-root .MuiCardContent-root {\n  padding: 0 1rem !important;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.profile-type-root {\n  margin-top: 1.5rem;\n  padding: 0 1.5rem;\n}\n.profile-type-root .profile-type-content {\n  margin: 0 auto;\n  width: 100%;\n}\n@media (min-width: 768px) {\n  .profile-type-root .profile-type-content {\n    width: 45.75rem;\n  }\n}\n.profile-type-root .profile-type-content .MuiButtonBase-root {\n  height: 40px;\n  margin: 0;\n}\n.profile-type-root .profile-type-content .btn-secondary-negative {\n  border-color: #e0e0e0;\n  height: 40px;\n}\n.profile-type-root .value {\n  color: #ffffff;\n  padding: 0 0 0.5rem 0;\n}\n.profile-type-root ul {\n  display: flex;\n  flex-wrap: wrap;\n  padding: 0;\n  margin-top: 0;\n}\n.profile-type-root ul li {\n  list-style-type: none;\n  margin-right: 0.5rem;\n}\n.profile-type-root .head {\n  color: #e0e0e0;\n  margin-bottom: 1rem;\n}\n.profile-type-root .label {\n  color: #a0a0a0;\n  padding-bottom: 0.5rem;\n}\n.profile-type-root .profile-container {\n  display: flex;\n  flex-direction: column;\n  flex-wrap: wrap;\n  width: 100%;\n  margin: 0 1.3rem 1rem;\n}\n@media only screen and (max-width : 768px) {\n  .profile-type-root .profile-container {\n    margin: 0 0 0.25rem;\n  }\n}\n.profile-type-root .fields {\n  align-items: flex-start;\n  padding: 8px 0px;\n  width: 100%;\n}\n.profile-type-root .profile-title {\n  padding-left: 1rem;\n}\n.profile-type-root button.profile-link {\n  color: #e0e0e0;\n  text-decoration: none;\n  min-height: 4rem;\n}\n.profile-type-root button.profile-link .profile-icon {\n  vertical-align: middle;\n}\n.profile-type-root button.profile-link .link-label {\n  margin-left: 1rem;\n}\n.profile-type-root button.profile-link > button {\n  margin-bottom: 0;\n}\n.profile-type-root button.profile-link > button > div {\n  padding: 0.3rem 1rem;\n}\n.profile-type-root div.expansion-panel-summary {\n  padding: 0 0.25rem 0 1rem;\n}\n.profile-type-root .MuiCardContent-root {\n  padding: 0 1rem !important;\n}", ""]);
 
 
 
diff --git a/5/ecolyo.72a7eabe03dee9217ec1.js b/5/ecolyo.cf7d1f9bca710f0b366e.js
similarity index 94%
rename from 5/ecolyo.72a7eabe03dee9217ec1.js
rename to 5/ecolyo.cf7d1f9bca710f0b366e.js
index b04e510c3a616557ea41c091b4d04774c0d589ae..0f943387643cd71cd4e84664f01698ba85861861 100644
--- a/5/ecolyo.72a7eabe03dee9217ec1.js
+++ b/5/ecolyo.cf7d1f9bca710f0b366e.js
@@ -998,6 +998,132 @@ if(false) {}
 
 /***/ }),
 
+/***/ "CPpy":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = void 0;
+
+var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("RIqP"));
+
+var _AxisBottom = _interopRequireDefault(__webpack_require__("ZUUJ"));
+
+var _AxisRight = _interopRequireDefault(__webpack_require__("0bt6"));
+
+var _Bar = _interopRequireDefault(__webpack_require__("qOdy"));
+
+var _d3Scale = __webpack_require__("ziQ1");
+
+var _dataload = __webpack_require__("D5WE");
+
+var _luxon = __webpack_require__("ExVU");
+
+var _react = _interopRequireDefault(__webpack_require__("q1tI"));
+
+var _reactRedux = __webpack_require__("/MKj");
+
+var BarChart = function BarChart(_ref) {
+  var chartData = _ref.chartData,
+      fluidType = _ref.fluidType,
+      timeStep = _ref.timeStep,
+      _ref$width = _ref.width,
+      width = _ref$width === void 0 ? 600 : _ref$width,
+      _ref$height = _ref.height,
+      height = _ref$height === void 0 ? 400 : _ref$height,
+      _ref$marginLeft = _ref.marginLeft,
+      marginLeft = _ref$marginLeft === void 0 ? 10 : _ref$marginLeft,
+      _ref$marginRight = _ref.marginRight,
+      marginRight = _ref$marginRight === void 0 ? 55 : _ref$marginRight,
+      _ref$marginTop = _ref.marginTop,
+      marginTop = _ref$marginTop === void 0 ? 20 : _ref$marginTop,
+      _ref$marginBottom = _ref.marginBottom,
+      marginBottom = _ref$marginBottom === void 0 ? 50 : _ref$marginBottom,
+      isSwitching = _ref.isSwitching;
+
+  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
+    return state.ecolyo.chart;
+  }),
+      showCompare = _useSelector.showCompare;
+
+  var getContentWidth = function getContentWidth() {
+    return width - marginLeft - marginRight;
+  };
+
+  var getContentHeight = function getContentHeight() {
+    return height - marginTop - marginBottom;
+  };
+
+  var getMaxLoad = function getMaxLoad() {
+    var maxCompare = chartData.comparisonData ? Math.max.apply(Math, (0, _toConsumableArray2.default)(chartData.comparisonData.map(function (d) {
+      return d.value;
+    }))) : 0;
+    var max = chartData.actualData ? Math.max.apply(Math, (0, _toConsumableArray2.default)(chartData.actualData.map(function (d) {
+      return d.value;
+    }))) : 0;
+
+    if (showCompare) {
+      if (max <= 0 && maxCompare <= 0) return 15;else return Math.max(max, maxCompare);
+    } else {
+      if (max <= 0) {
+        return 15;
+      } else return max;
+    }
+  };
+
+  var xScale = (0, _d3Scale.scaleBand)().domain(chartData.actualData.map(function (d) {
+    return d.date.toLocaleString(_luxon.DateTime.DATETIME_SHORT);
+  })).range([0, getContentWidth()]).padding(0.2);
+  var yScale = (0, _d3Scale.scaleLinear)().domain([0, getMaxLoad()]).range([getContentHeight(), 0]);
+  return /*#__PURE__*/_react.default.createElement("svg", {
+    width: width,
+    height: height
+  }, /*#__PURE__*/_react.default.createElement(_AxisRight.default, {
+    fluidType: fluidType,
+    yScale: yScale,
+    width: width,
+    marginRight: marginRight,
+    marginTop: marginTop
+  }), /*#__PURE__*/_react.default.createElement("g", {
+    transform: "translate(".concat(marginLeft, ",").concat(marginTop, ")")
+  }, chartData.actualData.map(function (d, index) {
+    var _chartData$comparison;
+
+    return /*#__PURE__*/_react.default.createElement(_Bar.default, {
+      key: index,
+      index: index,
+      dataload: d,
+      compareDataload: (_chartData$comparison = chartData.comparisonData) !== null && _chartData$comparison !== void 0 && _chartData$comparison[index] ? chartData.comparisonData[index] : null,
+      fluidType: fluidType,
+      timeStep: timeStep,
+      compare: showCompare,
+      xScale: xScale,
+      yScale: yScale,
+      height: getContentHeight(),
+      isSwitching: isSwitching,
+      isMultiMissingFluid: d.state === _dataload.DataloadState.AGGREGATED_WITH_EMPTY || d.state === _dataload.DataloadState.AGGREGATED_WITH_COMING || d.state === _dataload.DataloadState.AGGREGATED_WITH_HOLE_OR_MISSING ? true : false
+    });
+  })), /*#__PURE__*/_react.default.createElement(_AxisBottom.default, {
+    data: chartData.actualData,
+    timeStep: timeStep,
+    xScale: xScale,
+    height: height,
+    marginLeft: marginLeft,
+    marginBottom: marginBottom
+  }));
+};
+
+var _default = BarChart;
+exports.default = _default;
+
+/***/ }),
+
 /***/ "CXh2":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -1007,6 +1133,32 @@ exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE
 
 
 
+/***/ }),
+
+/***/ "Fb5D":
+/***/ (function(module, exports, __webpack_require__) {
+
+
+var content = __webpack_require__("flqf");
+
+if(typeof content === 'string') content = [[module.i, content, '']];
+
+var transform;
+var insertInto;
+
+
+
+var options = {"hmr":true}
+
+options.transform = transform
+options.insertInto = undefined;
+
+var update = __webpack_require__("aET+")(content, options);
+
+if(content.locals) module.exports = content.locals;
+
+if(false) {}
+
 /***/ }),
 
 /***/ "Fz84":
@@ -1856,7 +2008,7 @@ var _partnersInfo2 = _interopRequireDefault(__webpack_require__("4zrG"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _chart = __webpack_require__("idK9");
 
@@ -2029,10 +2181,7 @@ var KonnectorViewerCard = function KonnectorViewerCard(_ref) {
             _yield$challengeServi = _context2.sent;
             updatedUserChallenge = _yield$challengeServi.updatedUserChallenge;
             dataloads = _yield$challengeServi.dataloads;
-            dispatch((0, _challenge2.setChallengeConsumption)({
-              userChallenge: updatedUserChallenge,
-              currentDataload: dataloads
-            })); // Check is duel is done and display notification
+            dispatch((0, _challenge2.setChallengeConsumption)(updatedUserChallenge, dataloads)); // Check is duel is done and display notification
 
             _context2.next = 10;
             return challengeService.isChallengeDone(updatedUserChallenge, dataloads);
@@ -2791,7 +2940,7 @@ if(false) {}
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.consumptionview-loading {\n  background-color: #121212;\n  height: 80vh;\n  width: 100%;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.consumptionview-content {\n  background-color: #121212;\n}\n.consumptionview-content.--hidden {\n  display: none;\n}\n\n.konnector-section {\n  background-color: #121212;\n  margin: 0 auto;\n  width: 45.75rem;\n  box-sizing: border-box;\n  padding-bottom: 1rem;\n}\n@media only screen and (max-width : 768px) {\n  .konnector-section {\n    width: 100%;\n    padding-left: 1rem;\n    padding-right: 1rem;\n  }\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.consumptionview-loading {\n  background-color: #121212;\n  height: 80vh;\n  width: 100%;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n}\n\n.consumptionview-content {\n  background-color: #121212;\n}\n.consumptionview-content.--hidden {\n  display: none;\n}\n\n.konnector-section {\n  background-color: #121212;\n  margin: 0 auto;\n  width: 45.75rem;\n  box-sizing: border-box;\n}\n@media only screen and (max-width : 768px) {\n  .konnector-section {\n    width: 100%;\n    padding: 0rem 1rem 3rem 1rem;\n  }\n}", ""]);
 
 
 
@@ -3439,6 +3588,146 @@ exports.push([module.i, ".fluidchartswipe-root {\n  flex: 1;\n  height: 22rem;\n
 
 
 
+/***/ }),
+
+/***/ "Np/d":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = void 0;
+
+var _regenerator = _interopRequireDefault(__webpack_require__("o0o1"));
+
+var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
+
+var _asyncToGenerator2 = _interopRequireDefault(__webpack_require__("yXPU"));
+
+var _classnames = _interopRequireDefault(__webpack_require__("TSYQ"));
+
+var _cozyClient = __webpack_require__("SH7X");
+
+var _I18n = __webpack_require__("buk/");
+
+var _Icon = _interopRequireDefault(__webpack_require__("y6ex"));
+
+var _dataload = __webpack_require__("D5WE");
+
+var _fluid = __webpack_require__("5Wkc");
+
+var _usageEvent = __webpack_require__("/fHX");
+
+var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
+
+var _reactRouterDom = __webpack_require__("SOjZ");
+
+var _converter = _interopRequireDefault(__webpack_require__("LXmx"));
+
+var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
+
+var _picto = __webpack_require__("6DBe");
+
+var _utils = __webpack_require__("c+yx");
+
+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); }
+
+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; }
+
+var DataloadSectionDetail = function DataloadSectionDetail(_ref) {
+  var dataload = _ref.dataload,
+      fluidType = _ref.fluidType,
+      dataloadSectionType = _ref.dataloadSectionType;
+  var client = (0, _cozyClient.useClient)();
+
+  var _useI18n = (0, _I18n.useI18n)(),
+      t = _useI18n.t;
+
+  var converterService = new _converter.default();
+  var emitNavEvent = (0, _react.useCallback)( /*#__PURE__*/function () {
+    var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(targetPage) {
+      return _regenerator.default.wrap(function _callee$(_context) {
+        while (1) {
+          switch (_context.prev = _context.next) {
+            case 0:
+              _context.next = 2;
+              return _usageEvent2.default.addEvent(client, {
+                type: _usageEvent.UsageEventType.NAVIGATION_EVENT,
+                target: targetPage
+              });
+
+            case 2:
+            case "end":
+              return _context.stop();
+          }
+        }
+      }, _callee);
+    }));
+
+    return function (_x) {
+      return _ref2.apply(this, arguments);
+    };
+  }(), [client]);
+
+  if (fluidType !== _fluid.FluidType.MULTIFLUID) {
+    var _classNames;
+
+    return /*#__PURE__*/_react.default.createElement("div", {
+      className: (0, _classnames.default)('dataloadvisualizer-euro text-16-normal', (_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(_fluid.FluidType[fluidType].toLowerCase()), dataloadSectionType !== _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames, "".concat(_fluid.FluidType[fluidType].toLowerCase(), "-compare"), dataloadSectionType === _dataload.DataloadSectionType.LEFT), _classNames))
+    }, "".concat((0, _utils.formatNumberValues)(converterService.LoadToEuro(dataload.value, fluidType, dataload.price ? dataload.price : null)), " \u20AC"));
+  }
+
+  if (fluidType === _fluid.FluidType.MULTIFLUID && dataloadSectionType !== _dataload.DataloadSectionType.NO_COMPARE) {
+    return /*#__PURE__*/_react.default.createElement("div", {
+      className: "dataloadvisualizer-euro text-16-normal"
+    });
+  }
+
+  if (fluidType === _fluid.FluidType.MULTIFLUID && dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE && dataload.valueDetail) {
+    return /*#__PURE__*/_react.default.createElement("div", {
+      className: "dataloadvisualizer-euro text-16-normal"
+    }, dataload.valueDetail.map(function (valueDetail, index) {
+      var _classNames2;
+
+      return /*#__PURE__*/_react.default.createElement(_reactRouterDom.NavLink, {
+        key: index,
+        to: "/consumption/".concat(_fluid.FluidType[index].toLowerCase()),
+        className: "dataloadvisualizer-euro-link"
+      }, /*#__PURE__*/_react.default.createElement("div", {
+        className: (0, _classnames.default)('dataloadvisualizer-euro-fluid', (_classNames2 = {}, (0, _defineProperty2.default)(_classNames2, " ".concat(_fluid.FluidType[index].toLowerCase()), valueDetail.state === _dataload.DataloadState.VALID || valueDetail.state === _dataload.DataloadState.UPCOMING || valueDetail.state === _dataload.DataloadState.COMING || valueDetail.state === _dataload.DataloadState.EMPTY || valueDetail.state === _dataload.DataloadState.HOLE), (0, _defineProperty2.default)(_classNames2, " error", valueDetail.state === _dataload.DataloadState.MISSING), _classNames2)),
+        onClick: function onClick() {
+          return emitNavEvent(_fluid.FluidType[index].toLowerCase());
+        }
+      }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
+        className: "dataloadvisualizer-euro-fluid-icon",
+        icon: (0, _picto.getNavPicto)(index, true, true),
+        size: 22
+      }), /*#__PURE__*/_react.default.createElement("div", null, valueDetail.state === _dataload.DataloadState.VALID && "".concat((0, _utils.formatNumberValues)(valueDetail.value), " \u20AC"), (valueDetail.state === _dataload.DataloadState.UPCOMING || valueDetail.state === _dataload.DataloadState.COMING) && t('consumption_visualizer.data_to_come'), (valueDetail.state === _dataload.DataloadState.EMPTY || valueDetail.state === _dataload.DataloadState.HOLE) && t('consumption_visualizer.data_empty'), valueDetail.state === _dataload.DataloadState.MISSING && t('consumption_visualizer.aie'))));
+    }));
+  }
+
+  return /*#__PURE__*/_react.default.createElement("div", {
+    className: "dataloadvisualizer-euro text-16-normal"
+  }, /*#__PURE__*/_react.default.createElement(_reactRouterDom.NavLink, {
+    to: "/consumption/".concat(_fluid.FluidType[fluidType].toLowerCase()),
+    className: "dataloadvisualizer-euro-link"
+  }, /*#__PURE__*/_react.default.createElement("div", {
+    className: "dataloadvisualizer-euro-fluid ".concat(_fluid.FluidType[fluidType].toLowerCase())
+  }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
+    className: "dataloadvisualizer-euro-fluid-icon",
+    icon: (0, _picto.getNavPicto)(fluidType, true, true),
+    size: 22
+  }), /*#__PURE__*/_react.default.createElement("div", null, "".concat((0, _utils.formatNumberValues)(converterService.LoadToEuro(dataload.value, fluidType, dataload.price ? dataload.price : null)), " \u20AC")))));
+};
+
+var _default = DataloadSectionDetail;
+exports.default = _default;
+
 /***/ }),
 
 /***/ "Nxpj":
@@ -3520,6 +3809,7 @@ var DataloadConsumptionVisualizer = function DataloadConsumptionVisualizer(_ref)
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
     return state.ecolyo.chart;
   }),
+      loading = _useSelector.loading,
       showCompare = _useSelector.showCompare;
 
   var _useState = (0, _react.useState)(false),
@@ -3533,7 +3823,7 @@ var DataloadConsumptionVisualizer = function DataloadConsumptionVisualizer(_ref)
     });
   }, []);
 
-  if (!dataload) {
+  if (loading || !dataload) {
     return /*#__PURE__*/_react.default.createElement("div", {
       className: "dataloadvisualizer-root"
     });
@@ -4114,8 +4404,6 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _picto = __webpack_require__("6DBe");
 
-var _utils = __webpack_require__("c+yx");
-
 __webpack_require__("kpuL");
 
 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); }
@@ -4133,23 +4421,22 @@ var KonnectorViewerList = function KonnectorViewerList() {
 
   var navigate = (0, _reactRouterDom.useNavigate)();
   var goToFluid = (0, _react.useCallback)(function (fluidType) {
-    navigate("/consumption/".concat((0, _utils.getFluidName)(fluidType)));
+    navigate("/consumption/".concat(_fluid.FluidType[fluidType].toLowerCase()));
   }, [navigate]);
-  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, fluidStatus.map(function (fluidStatusItem, key) {
+  return fluidStatus.map(function (fluidStatusItem, key) {
     return /*#__PURE__*/_react.default.createElement(_StyledCard.default, {
       key: key,
       className: "connection-card",
       onClick: function onClick() {
         return goToFluid(fluidStatusItem.fluidType);
-      },
-      fluidType: fluidStatusItem.fluidType
+      }
     }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
       icon: (0, _picto.getAddPicto)(fluidStatusItem.fluidType),
       size: 36
     }), /*#__PURE__*/_react.default.createElement("div", {
       className: "konnector-title text-18-bold ".concat(_fluid.FluidType[fluidStatusItem.fluidType].toLowerCase())
     }, t("konnector_options.label_connect_to_".concat(_fluid.FluidType[fluidStatusItem.fluidType].toLowerCase()))));
-  }));
+  });
 };
 
 var _default = KonnectorViewerList;
@@ -4644,7 +4931,7 @@ if(false) {}
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nbutton.connection-card {\n  height: 80px;\n  margin-bottom: 1rem;\n}\nbutton.connection-card.electricity {\n  border: 1px solid var(--elecColor40);\n}\nbutton.connection-card.gas {\n  border: 1px solid var(--gasColor40);\n}\nbutton.connection-card.water {\n  border: 1px solid var(--waterColor40);\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nbutton.connection-card div {\n  display: flex;\n  align-items: center;\n  justify-content: start;\n  height: 80px;\n  font-weight: normal;\n  box-sizing: border-box;\n}\nbutton.connection-card div svg {\n  margin-right: 1.5rem;\n}", ""]);
 
 
 
@@ -4970,13 +5257,13 @@ var FluidChartSwipe = function FluidChartSwipe(_ref) {
       increment = dateChartService.defineIncrementForNextIndex(currentTimeStep, selectedDate, currentIndex);
     }
 
-    var updatedDate = dateChartService.incrementDate(currentTimeStep, selectedDate, increment);
+    var updatedDate = dateChartService.incrementeDate(currentTimeStep, selectedDate, increment);
     var updatedIndex = dateChartService.defineDateIndex(currentTimeStep, updatedDate);
     dispatch((0, _chart.setSelectedDate)(updatedDate));
     dispatch((0, _chart.setCurrentIndex)(updatedIndex));
   };
 
-  var _useChartResize = (0, _useChartResize2.useChartResize)(swipe, loading),
+  var _useChartResize = (0, _useChartResize2.useChartResize)(swipe, 300, 940, loading),
       height = _useChartResize.height,
       width = _useChartResize.width;
 
@@ -5130,6 +5417,17 @@ exports.KonnectorError = KonnectorError;
   KonnectorError["CRITICAL"] = "exit status 1";
 })(KonnectorError || (exports.KonnectorError = KonnectorError = {}));
 
+/***/ }),
+
+/***/ "flqf":
+/***/ (function(module, exports, __webpack_require__) {
+
+exports = module.exports = __webpack_require__("JPst")(false);
+// Module
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.consumptionvisualizer-root {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  padding-bottom: 0.5rem;\n}\n@media only screen and (max-width : 768px) {\n  .consumptionvisualizer-root {\n    width: 100%;\n  }\n}\n.consumptionvisualizer-root .consumptionvisualizer-info {\n  min-height: 1.5rem;\n  display: flex;\n  align-items: center;\n}", ""]);
+
+
+
 /***/ }),
 
 /***/ "goTn":
@@ -5404,16 +5702,22 @@ var FluidChart = function FluidChart(_ref) {
 
   var _useExploration = (0, _useExploration3.default)(),
       _useExploration2 = (0, _slicedToArray2.default)(_useExploration, 2),
-      setValidExploration = _useExploration2[1];
+      setValidExploration = _useExploration2[1]; // TODO use chart.loading ?
+
 
   var _useState = (0, _react.useState)(false),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
-      containsHalfHourData = _useState2[0],
-      setContainsHalfHourData = _useState2[1];
+      isLoaded = _useState2[0],
+      setIsLoaded = _useState2[1];
+
+  var _useState3 = (0, _react.useState)(false),
+      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
+      containsHalfHourData = _useState4[0],
+      setContainsHalfHourData = _useState4[1];
 
   var lowercaseTimeStep = _timeStep.TimeStep[currentTimeStep].toLowerCase();
 
-  var lowercaseFluidType = (0, _utils.getFluidName)(fluidType);
+  var lowercaseFluidType = _fluid.FluidType[fluidType].toLowerCase();
 
   var handleChangeSwitch = /*#__PURE__*/function () {
     var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
@@ -5430,7 +5734,7 @@ var FluidChart = function FluidChart(_ref) {
               return _usageEvent2.default.addEvent(client, {
                 type: _usageEvent.UsageEventType.CONSUMPTION_COMPARE_EVENT,
                 target: _timeStep.TimeStep[currentTimeStep].toLowerCase(),
-                context: lowercaseFluidType
+                context: _fluid.FluidType[fluidType].toLowerCase()
               });
 
             case 3:
@@ -5463,12 +5767,13 @@ var FluidChart = function FluidChart(_ref) {
           while (1) {
             switch (_context2.prev = _context2.next) {
               case 0:
+                consumptionService = new _consumption.default(client);
+
                 if (!(fluidType === _fluid.FluidType.ELECTRICITY)) {
                   _context2.next = 6;
                   break;
                 }
 
-                consumptionService = new _consumption.default(client);
                 _context2.next = 4;
                 return consumptionService.checkDoctypeEntries(_fluid.FluidType.ELECTRICITY, _timeStep.TimeStep.HALF_AN_HOUR);
 
@@ -5480,6 +5785,11 @@ var FluidChart = function FluidChart(_ref) {
                 }
 
               case 6:
+                if (subscribed) {
+                  setIsLoaded(true);
+                }
+
+              case 7:
               case "end":
                 return _context2.stop();
             }
@@ -5489,7 +5799,7 @@ var FluidChart = function FluidChart(_ref) {
       return _loadData.apply(this, arguments);
     }
 
-    subscribed && loadData();
+    loadData();
     return function () {
       subscribed = false;
     };
@@ -5557,7 +5867,7 @@ var FluidChart = function FluidChart(_ref) {
     }, t("auth.".concat((0, _utils.getKonnectorSlug)(fluidType), ".connect"))));
   };
 
-  return /*#__PURE__*/_react.default.createElement("div", {
+  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isLoaded && /*#__PURE__*/_react.default.createElement("div", {
     className: "fluidchart-root"
   }, !isFluidConnected && /*#__PURE__*/_react.default.createElement(LastDataValid, null), currentTimeStep === _timeStep.TimeStep.HALF_AN_HOUR && !containsHalfHourData ? /*#__PURE__*/_react.default.createElement(_HalfHourNoData.default, null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: "fluidchart-content"
@@ -5579,7 +5889,7 @@ var FluidChart = function FluidChart(_ref) {
     }
   }), /*#__PURE__*/_react.default.createElement("span", {
     className: "fluidchart-footer-label graph-switch-text"
-  }, t("timestep.".concat(lowercaseTimeStep, ".comparelabel"))))));
+  }, t("timestep.".concat(lowercaseTimeStep, ".comparelabel")))))));
 };
 
 var _default = FluidChart;
@@ -5736,11 +6046,11 @@ var FluidButton = function FluidButton(_ref) {
             _context.next = 2;
             return _usageEvent2.default.addEvent(client, {
               type: _usageEvent.UsageEventType.NAVIGATION_EVENT,
-              target: (0, _utils.getFluidName)(fluidType)
+              target: _fluid.FluidType[fluidType].toLowerCase()
             });
 
           case 2:
-            navigate(fluidType === _fluid.FluidType.MULTIFLUID ? '/consumption' : "/consumption/".concat((0, _utils.getFluidName)(fluidType)));
+            navigate(fluidType === _fluid.FluidType.MULTIFLUID ? '/consumption' : "/consumption/".concat(_fluid.FluidType[fluidType].toLowerCase()));
 
           case 3:
           case "end":
@@ -5757,7 +6067,7 @@ var FluidButton = function FluidButton(_ref) {
   };
 
   (0, _react.useEffect)(function () {
-    // Show errors only on connected konnectors that are in error, outdated, with no data (specific case), and not in multifluid
+    // Show errors only on konnected konnectors that are in error, outdated, with no data (specific case), and not in multifluid
     if (fluidType !== _fluid.FluidType.MULTIFLUID && isConnected() && isErrored() || fluidType !== _fluid.FluidType.MULTIFLUID && isConnected() && isOutdated()) {
       setShowError(true);
     }
@@ -5778,7 +6088,7 @@ var FluidButton = function FluidButton(_ref) {
     size: 22,
     className: "notif-error"
   }), /*#__PURE__*/_react.default.createElement("div", {
-    className: "fluid-title ".concat((0, _utils.getFluidName)(fluidType), " ").concat(isActive && 'active', " text-14-normal")
+    className: "fluid-title ".concat(_fluid.FluidType[fluidType].toLowerCase(), " ").concat(isActive && 'active', " text-14-normal")
   }, t('FLUID.' + _fluid.FluidType[fluidType] + '.LABEL')));
 };
 
@@ -5857,12 +6167,12 @@ var TotalConsumption = function TotalConsumption(_ref) {
 
   var client = (0, _cozyClient.useClient)();
 
-  var _useState = (0, _react.useState)('-----'),
+  var _useState = (0, _react.useState)(),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       totalValue = _useState2[0],
       setTotalValue = _useState2[1];
 
-  var _useState3 = (0, _react.useState)('-----'),
+  var _useState3 = (0, _react.useState)(),
       _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
       previousTotalValue = _useState4[0],
       setPreviousTotalValue = _useState4[1];
@@ -5929,43 +6239,11 @@ var TotalConsumption = function TotalConsumption(_ref) {
     };
   }(), [client, currentTimeStep, fluidType]);
   (0, _react.useEffect)(function () {
-    var isMounted = true;
-
-    var fetchTotal = /*#__PURE__*/function () {
-      var _ref3 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
-        return _regenerator.default.wrap(function _callee2$(_context2) {
-          while (1) {
-            switch (_context2.prev = _context2.next) {
-              case 0:
-                _context2.next = 2;
-                return computeTotal(currentDatachart.actualData, setTotalValue);
+    computeTotal(currentDatachart.actualData, setTotalValue);
 
-              case 2:
-                if (!currentDatachart.comparisonData) {
-                  _context2.next = 5;
-                  break;
-                }
-
-                _context2.next = 5;
-                return computeTotal(currentDatachart.comparisonData, setPreviousTotalValue);
-
-              case 5:
-              case "end":
-                return _context2.stop();
-            }
-          }
-        }, _callee2);
-      }));
-
-      return function fetchTotal() {
-        return _ref3.apply(this, arguments);
-      };
-    }();
-
-    isMounted && fetchTotal();
-    return function () {
-      isMounted = false;
-    };
+    if (currentDatachart.comparisonData) {
+      computeTotal(currentDatachart.comparisonData, setPreviousTotalValue);
+    }
   }, [currentDatachart, fluidType, currentTimeStep, client, computeTotal]);
 
   var compareIcon = function compareIcon() {
@@ -5986,7 +6264,9 @@ var TotalConsumption = function TotalConsumption(_ref) {
     className: "compare"
   }, /*#__PURE__*/_react.default.createElement("span", {
     className: "euro-value"
-  }, previousTotalValue)));
+  }, previousTotalValue), /*#__PURE__*/_react.default.createElement("span", {
+    className: "euro-symbol"
+  }, " \u20AC")));
 };
 
 var _default = TotalConsumption;
@@ -6119,10 +6399,10 @@ var _lodash = __webpack_require__("LvDl");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _KonnectorModalFooter = _interopRequireDefault(__webpack_require__("TAXC"));
-
 __webpack_require__("c+fo");
 
+var _KonnectorModalFooter = _interopRequireDefault(__webpack_require__("TAXC"));
+
 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); }
 
 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; }
@@ -6321,6 +6601,60 @@ exports.default = _default;
 
 /***/ }),
 
+/***/ "jx3z":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = void 0;
+
+var _I18n = __webpack_require__("buk/");
+
+var _dataload = __webpack_require__("D5WE");
+
+var _fluid = __webpack_require__("5Wkc");
+
+var _react = _interopRequireDefault(__webpack_require__("q1tI"));
+
+var _utils = __webpack_require__("c+yx");
+
+var DataloadSectionValue = function DataloadSectionValue(_ref) {
+  var dataload = _ref.dataload,
+      fluidType = _ref.fluidType,
+      dataloadSectionType = _ref.dataloadSectionType,
+      toggleEstimationModal = _ref.toggleEstimationModal;
+
+  var _useI18n = (0, _I18n.useI18n)(),
+      t = _useI18n.t;
+
+  if (fluidType === _fluid.FluidType.MULTIFLUID) {
+    return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value), /*#__PURE__*/_react.default.createElement("span", {
+      className: 'text-18-normal euroUnit'
+    }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT'))), dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE && /*#__PURE__*/_react.default.createElement("span", {
+      className: "text-14-normal estimated",
+      onClick: toggleEstimationModal
+    }, t('consumption_visualizer.estimated')));
+  }
+
+  var formattedValue = (0, _utils.formatNumberValues)(dataload.value, _fluid.FluidType[fluidType], true);
+  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, Number(formattedValue) >= 1000 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value, _fluid.FluidType[fluidType]), /*#__PURE__*/_react.default.createElement("span", {
+    className: "text-18-normal"
+  }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.MEGAUNIT')))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value), /*#__PURE__*/_react.default.createElement("span", {
+    className: 'text-18-normal'
+  }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT')))));
+};
+
+var _default = DataloadSectionValue;
+exports.default = _default;
+
+/***/ }),
+
 /***/ "k66a":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -6498,8 +6832,6 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _global = __webpack_require__("c4IZ");
 
-var _utils = __webpack_require__("c+yx");
-
 __webpack_require__("B3W9");
 
 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); }
@@ -6572,7 +6904,7 @@ var ExpiredConsentModal = function ExpiredConsentModal(_ref) {
     icon: fluidType === _fluid.FluidType.ELECTRICITY ? _consentOutdatedEnedis.default : _consentOutdatedGrdf.default,
     size: 135
   })), /*#__PURE__*/_react.default.createElement("div", {
-    className: "text-20-bold title ".concat((0, _utils.getFluidName)(fluidType))
+    className: "text-20-bold title ".concat(_fluid.FluidType[fluidType].toLowerCase())
   }, t("consent_outdated.title.".concat(fluidType))), /*#__PURE__*/_react.default.createElement("div", {
     className: "text-16-normal text1"
   }, t("consent_outdated.text1.".concat(fluidType))), /*#__PURE__*/_react.default.createElement("div", {
@@ -6746,8 +7078,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.default = void 0;
 
-var _extends2 = _interopRequireDefault(__webpack_require__("pVnL"));
-
 var _objectWithoutProperties2 = _interopRequireDefault(__webpack_require__("QILm"));
 
 var _CardActionArea = _interopRequireDefault(__webpack_require__("9pVe"));
@@ -6756,38 +7086,70 @@ var _CardContent = _interopRequireDefault(__webpack_require__("7/eH"));
 
 var _styles = __webpack_require__("DfQ9");
 
-var _react = _interopRequireDefault(__webpack_require__("q1tI"));
+var _fluid = __webpack_require__("5Wkc");
 
-var _utils = __webpack_require__("c+yx");
+var _react = _interopRequireDefault(__webpack_require__("q1tI"));
 
-var _excluded = ["fluidType", "children", "className"];
+var _excluded = ["fluidType"];
 var CardBase = (0, _styles.withStyles)({
   root: {
     background: 'var(--greyLinearGradientBackground)',
     boxSizing: 'border-box',
     boxShadow: '0px 4px 8px rgba(0, 0, 0, 0.75)',
-    borderRadius: '4px'
+    borderRadius: '4px',
+    margin: '10px 0px 10px 0px'
   }
 })(_CardActionArea.default);
+var CardElec = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--elecColor40)'
+  }
+})(CardBase);
+var CardWater = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--waterColor40)'
+  }
+})(CardBase);
+var CardGas = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--gasColor40)'
+  }
+})(CardBase);
+var CardMulti = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var( --greyDark)'
+  }
+})(CardBase);
 var CardContentBase = (0, _styles.withStyles)({
   root: {
-    color: 'white',
-    display: 'flex',
-    alignItems: 'center',
-    gap: '1rem',
-    boxSizing: 'border-box'
+    color: 'white'
   }
 })(_CardContent.default);
 
+var GenerateContentCard = function GenerateContentCard(fluidType, children) {
+  return /*#__PURE__*/_react.default.createElement(CardContentBase, null, children);
+};
+
 var StyledCard = function StyledCard(_ref) {
   var fluidType = _ref.fluidType,
-      children = _ref.children,
-      className = _ref.className,
       props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
-  var cardClass = className + (fluidType !== undefined ? " ".concat((0, _utils.getFluidName)(fluidType)) : '');
-  return /*#__PURE__*/_react.default.createElement(CardBase, (0, _extends2.default)({}, props, {
-    className: cardClass
-  }), /*#__PURE__*/_react.default.createElement(CardContentBase, null, children));
+
+  switch (fluidType) {
+    case _fluid.FluidType.ELECTRICITY:
+      return /*#__PURE__*/_react.default.createElement(CardElec, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.WATER:
+      return /*#__PURE__*/_react.default.createElement(CardWater, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.GAS:
+      return /*#__PURE__*/_react.default.createElement(CardGas, props, GenerateContentCard(fluidType, props.children));
+
+    case _fluid.FluidType.MULTIFLUID:
+      return /*#__PURE__*/_react.default.createElement(CardMulti, props, GenerateContentCard(fluidType, props.children));
+
+    default:
+      return /*#__PURE__*/_react.default.createElement(CardBase, props, /*#__PURE__*/_react.default.createElement(CardContentBase, null, props.children));
+  }
 };
 
 var _default = StyledCard;
@@ -6828,6 +7190,77 @@ var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WE
 
 /***/ }),
 
+/***/ "nGEn":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.default = void 0;
+
+var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
+
+var _classnames = _interopRequireDefault(__webpack_require__("TSYQ"));
+
+var _I18n = __webpack_require__("buk/");
+
+var _dataload = __webpack_require__("D5WE");
+
+var _fluid = __webpack_require__("5Wkc");
+
+var _react = _interopRequireDefault(__webpack_require__("q1tI"));
+
+__webpack_require__("Fb5D");
+
+var _DataloadSectionDetail = _interopRequireDefault(__webpack_require__("Np/d"));
+
+var _DataloadSectionValue = _interopRequireDefault(__webpack_require__("jx3z"));
+
+var DataloadSection = function DataloadSection(_ref) {
+  var _classNames, _classNames2;
+
+  var dataload = _ref.dataload,
+      fluidType = _ref.fluidType,
+      dataloadSectionType = _ref.dataloadSectionType,
+      toggleEstimationModal = _ref.toggleEstimationModal;
+
+  var _useI18n = (0, _I18n.useI18n)(),
+      t = _useI18n.t;
+
+  if (dataload.value === -1 && dataloadSectionType === _dataload.DataloadSectionType.LEFT) {
+    return /*#__PURE__*/_react.default.createElement("div", {
+      className: "dataloadvisualizer-section dataloadvisualizer-section-left-novalue"
+    }, /*#__PURE__*/_react.default.createElement("div", {
+      className: "dataloadvisualizer-novalue ".concat(_fluid.FluidType[fluidType].toLowerCase(), "-compare text-20-normal")
+    }, t('consumption_visualizer.no_data')));
+  }
+
+  return /*#__PURE__*/_react.default.createElement("div", {
+    className: (0, _classnames.default)('dataloadvisualizer-section', (_classNames = {}, (0, _defineProperty2.default)(_classNames, 'dataloadvisualizer-section-left', dataloadSectionType === _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames, 'dataloadvisualizer-section-right', dataloadSectionType === _dataload.DataloadSectionType.RIGHT), _classNames))
+  }, /*#__PURE__*/_react.default.createElement("div", {
+    className: (0, _classnames.default)('dataloadvisualizer-value', 'text-36-bold', (_classNames2 = {}, (0, _defineProperty2.default)(_classNames2, "".concat(_fluid.FluidType[fluidType].toLowerCase(), "-compare"), dataloadSectionType === _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames2, "".concat(_fluid.FluidType[fluidType].toLowerCase()), dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE || dataloadSectionType === _dataload.DataloadSectionType.RIGHT), (0, _defineProperty2.default)(_classNames2, 'multifluid-compare-color', dataloadSectionType === _dataload.DataloadSectionType.RIGHT && fluidType === _fluid.FluidType.MULTIFLUID), _classNames2))
+  }, /*#__PURE__*/_react.default.createElement(_DataloadSectionValue.default, {
+    dataload: dataload,
+    fluidType: fluidType,
+    dataloadSectionType: dataloadSectionType,
+    toggleEstimationModal: toggleEstimationModal
+  })), /*#__PURE__*/_react.default.createElement(_DataloadSectionDetail.default, {
+    dataload: dataload,
+    fluidType: fluidType,
+    dataloadSectionType: dataloadSectionType
+  }));
+};
+
+var _default = DataloadSection;
+exports.default = _default;
+
+/***/ }),
+
 /***/ "o1ew":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -7657,8 +8090,6 @@ var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
 var _chart = __webpack_require__("idK9");
 
-var _utils = __webpack_require__("c+yx");
-
 __webpack_require__("Nxpj");
 
 var TimeStepSelector = function TimeStepSelector(_ref) {
@@ -7688,7 +8119,7 @@ var TimeStepSelector = function TimeStepSelector(_ref) {
     _usageEvent2.default.addEvent(client, {
       type: _usageEvent.UsageEventType.CONSUMPTION_CHANGE_TIMESTEP_EVENT,
       target: _timeStep.TimeStep[_timeStep.TimeStep.WEEK].toLowerCase(),
-      context: (0, _utils.getFluidName)(fluidType)
+      context: _fluid.FluidType[fluidType].toLowerCase()
     });
 
     dispatch((0, _chart.setCurrentIndex)(0));
@@ -7702,7 +8133,7 @@ var TimeStepSelector = function TimeStepSelector(_ref) {
     _usageEvent2.default.addEvent(client, {
       type: _usageEvent.UsageEventType.CONSUMPTION_CHANGE_TIMESTEP_EVENT,
       target: _timeStep.TimeStep[currentTimeStep].toLowerCase(),
-      context: (0, _utils.getFluidName)(fluidType)
+      context: _fluid.FluidType[fluidType].toLowerCase()
     });
 
     dispatch((0, _chart.setCurrentTimeStep)(targetTimestep));
diff --git a/6/ecolyo.1540774c38e7b6124ec7.js b/6/ecolyo.c03889ab8782bad3bebe.js
similarity index 94%
rename from 6/ecolyo.1540774c38e7b6124ec7.js
rename to 6/ecolyo.c03889ab8782bad3bebe.js
index baef61fdfcd52bd54e48a205b6b252e5877c21de..3db59504b1f3a62463869888d36ce60cddbad5c9 100644
--- a/6/ecolyo.1540774c38e7b6124ec7.js
+++ b/6/ecolyo.c03889ab8782bad3bebe.js
@@ -219,6 +219,7 @@ var EcogestureView = function EcogestureView() {
   }, []);
   var handleChange = (0, _react.useCallback)(function (event, newValue) {
     event.preventDefault();
+    console.log(event);
     var params = new URLSearchParams();
     params.append('tab', newValue.toString());
     navigate({
@@ -407,7 +408,7 @@ exports.default = _default;
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.ec-empty-container {\n  margin-top: 6rem;\n}\n.ec-empty-container .ec-empty-content {\n  color: #e0e0e0;\n  text-align: center;\n  padding: 0 1.5rem;\n  display: flex;\n  gap: 1rem;\n  flex-direction: column;\n  align-items: center;\n  margin: 0 auto;\n}\n@media (min-width: 576px) {\n  .ec-empty-container .ec-empty-content {\n    max-width: 45%;\n  }\n}\n@media (min-width: 1200px) {\n  .ec-empty-container .ec-empty-content {\n    max-width: 35%;\n  }\n}\n.ec-empty-container .ec-empty-content .btn-container {\n  margin-top: 1rem;\n  display: flex;\n  gap: 1rem;\n}\n.ec-empty-container .ec-empty-content .btn-container button {\n  margin: 0;\n}\n.ec-empty-container .ec-empty-content .reinit-button {\n  margin-left: 15px;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.ec-empty-container {\n  margin-top: 6rem;\n}\n.ec-empty-container .ec-empty-content {\n  color: #e0e0e0;\n  text-align: center;\n  padding: 0 1.5rem;\n  display: flex;\n  gap: 1rem;\n  flex-direction: column;\n  align-items: center;\n  margin: 0 auto;\n}\n@media (min-width: 576px) {\n  .ec-empty-container .ec-empty-content {\n    max-width: 45%;\n  }\n}\n@media (min-width: 1200px) {\n  .ec-empty-container .ec-empty-content {\n    max-width: 35%;\n  }\n}\n.ec-empty-container .ec-empty-content .btn-container {\n  margin-top: 1rem;\n  display: flex;\n  gap: 1rem;\n}\n.ec-empty-container .ec-empty-content .btn-container button {\n  margin: 0;\n}\n.ec-empty-container .ec-empty-content .btn-container button.btn2 {\n  margin-left: 1rem;\n}\n.ec-empty-container .ec-empty-content .reinit-button {\n  margin-left: 15px;\n}", ""]);
 
 
 
@@ -551,7 +552,7 @@ if(false) {}
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.ec-content {\n  height: 100%;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: space-around;\n}\n.ec-content.ec-content-unlocked {\n  padding: 0.4rem 0;\n}\n.ec-content.ec-content-challenge {\n  padding: 0.5rem 0;\n}\n.ec-content .ec-content-short-name {\n  display: flex;\n  flex: 1;\n  align-items: center;\n  text-align: center;\n}\n\n.cp-eg-1 {\n  height: 8rem;\n  width: 100%;\n  margin-right: 0.25rem;\n  text-align: center;\n}\n\n.cp-eg-2 {\n  height: 8rem;\n  width: 100%;\n  margin-left: 0.25rem;\n  text-align: center;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.ec {\n  display: flex;\n  justify-content: center;\n  width: 100%;\n  height: 100%;\n}\n.ec .ecogesture-card-notif {\n  position: absolute;\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  right: 8px;\n  top: 8px;\n  width: 1.25rem;\n  height: 1.25rem;\n  color: #25262b;\n  border-radius: 50%;\n  border: 1px solid #25262b;\n  z-index: 1;\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  font-size: 12px;\n}\n.ec .ec-content {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: space-around;\n}\n.ec .ec-content.ec-content-unlocked {\n  padding: 0.4rem 0;\n}\n.ec .ec-content.ec-content-challenge {\n  padding: 0.5rem 0;\n}\n.ec .ec-content .ec-content-icon {\n  min-height: 50px;\n}\n.ec .ec-content .ec-content-short-name {\n  display: flex;\n  flex: 1;\n  align-items: center;\n  text-align: center;\n  min-height: 38px;\n}\n.ec .ec-content .ec-content-efficiency {\n  margin-top: 0.5rem;\n  color: #a0a0a0;\n}\n\n.cp-eg-1 {\n  height: 8rem;\n  width: 100%;\n  margin-right: 0.25rem;\n  text-align: center;\n}\n\n.cp-eg-2 {\n  height: 8rem;\n  width: 100%;\n  margin-left: 0.25rem;\n  text-align: center;\n}", ""]);
 
 
 
@@ -580,10 +581,11 @@ var _styles = __webpack_require__("DfQ9");
 
 var _react = _interopRequireDefault(__webpack_require__("q1tI"));
 
-var _excluded = ["children"];
+var _excluded = ["border", "newEcogesture"];
 var CardBase = (0, _styles.withStyles)({
   root: {
     background: 'var(--greyLinearGradientBackground)',
+    // border: '1px solid',
     boxSizing: 'border-box',
     boxShadow: '0px 4px 16px black',
     borderRadius: '4px',
@@ -591,6 +593,42 @@ var CardBase = (0, _styles.withStyles)({
     minHeight: '72px'
   }
 })(_CardActionArea.default);
+var CardNew = (0, _styles.withStyles)({
+  '@keyframes glowAnimation': {
+    '0%': {
+      boxShadow: '0px 0px 4px var(--blue)'
+    },
+    '50%': {
+      boxShadow: '0px 0px 16px var(--blue)'
+    },
+    '100%': {
+      boxShadow: '0px 0px 4px var(--blue)'
+    }
+  },
+  root: {
+    border: '1px solid var(--blue)',
+    animation: '2s glowAnimation linear infinite',
+    color: 'white',
+    height: '100%',
+    padding: 0
+  }
+})(CardBase);
+var CardBlueBorderContentBase = (0, _styles.withStyles)({
+  root: {
+    border: '1px solid var(--blue)',
+    height: '100%',
+    padding: 0
+  }
+})(CardBase);
+var CardChallengeBase = (0, _styles.withStyles)({
+  root: {
+    height: '100%',
+    padding: 0,
+    display: 'flex',
+    alignItems: 'center',
+    justifyContent: 'center'
+  }
+})(_CardContent.default);
 var CardContentBase = (0, _styles.withStyles)({
   root: {
     color: 'white',
@@ -599,10 +637,22 @@ var CardContentBase = (0, _styles.withStyles)({
   }
 })(_CardContent.default);
 
+var GenerateContentCard = function GenerateContentCard(children) {
+  return /*#__PURE__*/_react.default.createElement(CardChallengeBase, null, children);
+};
+
 var StyledEcogestureCard = function StyledEcogestureCard(_ref) {
-  var children = _ref.children,
+  var border = _ref.border,
+      newEcogesture = _ref.newEcogesture,
       props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
-  return /*#__PURE__*/_react.default.createElement(CardBase, props, /*#__PURE__*/_react.default.createElement(CardContentBase, null, children));
+
+  if (newEcogesture) {
+    return /*#__PURE__*/_react.default.createElement(CardNew, props, GenerateContentCard(props.children));
+  } else if (border) {
+    return /*#__PURE__*/_react.default.createElement(CardBlueBorderContentBase, props, GenerateContentCard(props.children));
+  } else {
+    return /*#__PURE__*/_react.default.createElement(CardBase, props, /*#__PURE__*/_react.default.createElement(CardContentBase, null, props.children));
+  }
 };
 
 var _default = StyledEcogestureCard;
@@ -669,10 +719,10 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _utils = __webpack_require__("c+yx");
 
-var _EfficiencyRating = _interopRequireDefault(__webpack_require__("Zjkz"));
-
 __webpack_require__("JY8P");
 
+var _EfficiencyRating = _interopRequireDefault(__webpack_require__("Zjkz"));
+
 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); }
 
 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; }
@@ -735,16 +785,22 @@ var EcogestureCard = function EcogestureCard(_ref) {
     component: _reactRouterDom.Link,
     className: "ecogesture-list-item"
   }, /*#__PURE__*/_react.default.createElement(_StyledEcogestureCard.default, null, /*#__PURE__*/_react.default.createElement("div", {
-    className: "ec-content"
+    className: "ec"
+  }, /*#__PURE__*/_react.default.createElement("div", {
+    className: "ec-content "
+  }, /*#__PURE__*/_react.default.createElement("div", {
+    className: "ec-content-icon"
   }, /*#__PURE__*/_react.default.createElement(_StyledIcon.default, {
     className: "Icon",
     icon: ecogestureIcon,
     size: 50
-  }), /*#__PURE__*/_react.default.createElement("div", {
+  })), /*#__PURE__*/_react.default.createElement("div", {
     className: "ec-content-short-name text-15-bold"
-  }, ecogesture.shortName), /*#__PURE__*/_react.default.createElement(_EfficiencyRating.default, {
+  }, ecogesture.shortName), /*#__PURE__*/_react.default.createElement("div", {
+    className: "ec-content-efficiency"
+  }, /*#__PURE__*/_react.default.createElement(_EfficiencyRating.default, {
     result: Math.round(ecogesture.efficiency)
-  }))));
+  }))))));
 };
 
 var _default = EcogestureCard;
@@ -1337,7 +1393,7 @@ var EcogestureEmptyList = function EcogestureEmptyList(_ref) {
       navigate('/ecogesture-form');
     },
     classes: {
-      root: 'btn-highlight',
+      root: 'btn-highlight btn2',
       label: 'text-16-bold'
     }
   }, t('ecogesture.emptyList.btn2')))));
diff --git a/7/ecolyo.8129fd19ad98c11c5897.js b/7/ecolyo.1850b6ce28566211a509.js
similarity index 52%
rename from 7/ecolyo.8129fd19ad98c11c5897.js
rename to 7/ecolyo.1850b6ce28566211a509.js
index ebdbafc5578817b4d0a0dedc4a896bcd760affdf..88347af9c62a14b8ce8a223e88eab8b5e63b026b 100644
--- a/7/ecolyo.8129fd19ad98c11c5897.js
+++ b/7/ecolyo.1850b6ce28566211a509.js
@@ -37,135 +37,6 @@ if(false) {}
 
 /***/ }),
 
-/***/ "CPpy":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.default = void 0;
-
-var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("RIqP"));
-
-var _AxisBottom = _interopRequireDefault(__webpack_require__("ZUUJ"));
-
-var _AxisRight = _interopRequireDefault(__webpack_require__("0bt6"));
-
-var _Bar = _interopRequireDefault(__webpack_require__("qOdy"));
-
-var _d3Scale = __webpack_require__("ziQ1");
-
-var _dataload = __webpack_require__("D5WE");
-
-var _luxon = __webpack_require__("ExVU");
-
-var _react = _interopRequireDefault(__webpack_require__("q1tI"));
-
-var _reactRedux = __webpack_require__("/MKj");
-
-var BarChart = function BarChart(_ref) {
-  var chartData = _ref.chartData,
-      fluidType = _ref.fluidType,
-      timeStep = _ref.timeStep,
-      _ref$width = _ref.width,
-      width = _ref$width === void 0 ? 600 : _ref$width,
-      _ref$height = _ref.height,
-      height = _ref$height === void 0 ? 400 : _ref$height,
-      _ref$marginLeft = _ref.marginLeft,
-      marginLeft = _ref$marginLeft === void 0 ? 10 : _ref$marginLeft,
-      _ref$marginRight = _ref.marginRight,
-      marginRight = _ref$marginRight === void 0 ? 55 : _ref$marginRight,
-      _ref$marginTop = _ref.marginTop,
-      marginTop = _ref$marginTop === void 0 ? 20 : _ref$marginTop,
-      _ref$marginBottom = _ref.marginBottom,
-      marginBottom = _ref$marginBottom === void 0 ? 50 : _ref$marginBottom,
-      isSwitching = _ref.isSwitching,
-      _ref$clickable = _ref.clickable,
-      clickable = _ref$clickable === void 0 ? true : _ref$clickable;
-
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.chart;
-  }),
-      showCompare = _useSelector.showCompare;
-
-  var getContentWidth = function getContentWidth() {
-    return width - marginLeft - marginRight;
-  };
-
-  var getContentHeight = function getContentHeight() {
-    return height - marginTop - marginBottom;
-  };
-
-  var getMaxLoad = function getMaxLoad() {
-    var maxCompare = chartData.comparisonData ? Math.max.apply(Math, (0, _toConsumableArray2.default)(chartData.comparisonData.map(function (d) {
-      return d.value;
-    }))) : 0;
-    var max = chartData.actualData ? Math.max.apply(Math, (0, _toConsumableArray2.default)(chartData.actualData.map(function (d) {
-      return d.value;
-    }))) : 0;
-
-    if (showCompare) {
-      if (max <= 0 && maxCompare <= 0) return 15;else return Math.max(max, maxCompare);
-    } else {
-      if (max <= 0) {
-        return 15;
-      } else return max;
-    }
-  };
-
-  var xScale = (0, _d3Scale.scaleBand)().domain(chartData.actualData.map(function (d) {
-    return d.date.toLocaleString(_luxon.DateTime.DATETIME_SHORT);
-  })).range([0, getContentWidth()]).padding(0.2);
-  var yScale = (0, _d3Scale.scaleLinear)().domain([0, getMaxLoad()]).range([getContentHeight(), 0]);
-  return /*#__PURE__*/_react.default.createElement("svg", {
-    width: width,
-    height: height
-  }, /*#__PURE__*/_react.default.createElement(_AxisRight.default, {
-    fluidType: fluidType,
-    yScale: yScale,
-    width: width,
-    marginRight: marginRight,
-    marginTop: marginTop
-  }), /*#__PURE__*/_react.default.createElement("g", {
-    transform: "translate(".concat(marginLeft, ",").concat(marginTop, ")")
-  }, chartData.actualData.map(function (d, index) {
-    var _chartData$comparison;
-
-    return /*#__PURE__*/_react.default.createElement(_Bar.default, {
-      key: index,
-      index: index,
-      dataload: d,
-      compareDataload: (_chartData$comparison = chartData.comparisonData) !== null && _chartData$comparison !== void 0 && _chartData$comparison[index] ? chartData.comparisonData[index] : null,
-      fluidType: fluidType,
-      timeStep: timeStep,
-      compare: showCompare,
-      xScale: xScale,
-      yScale: yScale,
-      height: getContentHeight(),
-      isSwitching: isSwitching,
-      isMultiMissingFluid: d.state === _dataload.DataloadState.AGGREGATED_WITH_EMPTY || d.state === _dataload.DataloadState.AGGREGATED_WITH_COMING || d.state === _dataload.DataloadState.AGGREGATED_WITH_HOLE_OR_MISSING ? true : false,
-      clickable: clickable
-    });
-  })), /*#__PURE__*/_react.default.createElement(_AxisBottom.default, {
-    data: chartData.actualData,
-    timeStep: timeStep,
-    xScale: xScale,
-    height: height,
-    marginLeft: marginLeft,
-    marginBottom: marginBottom
-  }));
-};
-
-var _default = BarChart;
-exports.default = _default;
-
-/***/ }),
-
 /***/ "CYAo":
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
@@ -188,32 +59,6 @@ var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WE
 
 /***/ }),
 
-/***/ "Fb5D":
-/***/ (function(module, exports, __webpack_require__) {
-
-
-var content = __webpack_require__("flqf");
-
-if(typeof content === 'string') content = [[module.i, content, '']];
-
-var transform;
-var insertInto;
-
-
-
-var options = {"hmr":true}
-
-options.transform = transform
-options.insertInto = undefined;
-
-var update = __webpack_require__("aET+")(content, options);
-
-if(content.locals) module.exports = content.locals;
-
-if(false) {}
-
-/***/ }),
-
 /***/ "Hno1":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -255,8 +100,6 @@ var _reactRedux = __webpack_require__("/MKj");
 
 var _dateChart = _interopRequireDefault(__webpack_require__("Ty7+"));
 
-var _analysis = __webpack_require__("JQjK");
-
 var _chart = __webpack_require__("idK9");
 
 var _date = __webpack_require__("XrP9");
@@ -267,6 +110,7 @@ __webpack_require__("pBt2");
 
 var DateNavigator = function DateNavigator(_ref) {
   var currentAnalysisDate = _ref.currentAnalysisDate,
+      setCurrentAnalysisDate = _ref.setCurrentAnalysisDate,
       _ref$inlineDateDispla = _ref.inlineDateDisplay,
       inlineDateDisplay = _ref$inlineDateDispla === void 0 ? false : _ref$inlineDateDispla;
 
@@ -290,18 +134,17 @@ var DateNavigator = function DateNavigator(_ref) {
 
   var disableNext = currentAnalysisDate ? (0, _date.isLastDateReached)(currentAnalysisDate, _timeStep.TimeStep.MONTH) : (0, _date.isLastDateReached)(selectedDate, currentTimeStep);
   var dateChartService = new _dateChart.default();
-  /** Handle date navigation from ConsumptionView and Analysis view, not ideal though */
 
   var handleClickMove = function handleClickMove(increment) {
     if (!currentAnalysisDate) {
-      var updatedDate = dateChartService.incrementDate(currentTimeStep, selectedDate, increment);
+      var updatedDate = dateChartService.incrementeDate(currentTimeStep, selectedDate, increment);
       var updatedIndex = dateChartService.defineDateIndex(currentTimeStep, updatedDate);
       dispatch((0, _chart.setSelectedDate)(updatedDate));
       dispatch((0, _chart.setCurrentIndex)(updatedIndex));
     } else {
-      var _updatedDate = dateChartService.incrementDate(_timeStep.TimeStep.MONTH, currentAnalysisDate, increment);
+      var _updatedDate = dateChartService.incrementeDate(_timeStep.TimeStep.MONTH, currentAnalysisDate, increment);
 
-      dispatch((0, _analysis.setAnalysisMonth)(_updatedDate));
+      setCurrentAnalysisDate === null || setCurrentAnalysisDate === void 0 ? void 0 : setCurrentAnalysisDate(_updatedDate);
     }
   };
 
@@ -385,146 +228,6 @@ if(false) {}
 
 /***/ }),
 
-/***/ "Np/d":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.default = void 0;
-
-var _regenerator = _interopRequireDefault(__webpack_require__("o0o1"));
-
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
-var _asyncToGenerator2 = _interopRequireDefault(__webpack_require__("yXPU"));
-
-var _classnames = _interopRequireDefault(__webpack_require__("TSYQ"));
-
-var _cozyClient = __webpack_require__("SH7X");
-
-var _I18n = __webpack_require__("buk/");
-
-var _Icon = _interopRequireDefault(__webpack_require__("y6ex"));
-
-var _dataload = __webpack_require__("D5WE");
-
-var _fluid = __webpack_require__("5Wkc");
-
-var _usageEvent = __webpack_require__("/fHX");
-
-var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
-
-var _reactRouterDom = __webpack_require__("SOjZ");
-
-var _converter = _interopRequireDefault(__webpack_require__("LXmx"));
-
-var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
-
-var _picto = __webpack_require__("6DBe");
-
-var _utils = __webpack_require__("c+yx");
-
-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); }
-
-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; }
-
-var DataloadSectionDetail = function DataloadSectionDetail(_ref) {
-  var dataload = _ref.dataload,
-      fluidType = _ref.fluidType,
-      dataloadSectionType = _ref.dataloadSectionType;
-  var client = (0, _cozyClient.useClient)();
-
-  var _useI18n = (0, _I18n.useI18n)(),
-      t = _useI18n.t;
-
-  var converterService = new _converter.default();
-  var emitNavEvent = (0, _react.useCallback)( /*#__PURE__*/function () {
-    var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(targetPage) {
-      return _regenerator.default.wrap(function _callee$(_context) {
-        while (1) {
-          switch (_context.prev = _context.next) {
-            case 0:
-              _context.next = 2;
-              return _usageEvent2.default.addEvent(client, {
-                type: _usageEvent.UsageEventType.NAVIGATION_EVENT,
-                target: targetPage
-              });
-
-            case 2:
-            case "end":
-              return _context.stop();
-          }
-        }
-      }, _callee);
-    }));
-
-    return function (_x) {
-      return _ref2.apply(this, arguments);
-    };
-  }(), [client]);
-
-  if (fluidType !== _fluid.FluidType.MULTIFLUID) {
-    var _classNames;
-
-    return /*#__PURE__*/_react.default.createElement("div", {
-      className: (0, _classnames.default)('dataloadvisualizer-euro text-16-normal', (_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat((0, _utils.getFluidName)(fluidType)), dataloadSectionType !== _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames, "".concat((0, _utils.getFluidName)(fluidType), "-compare"), dataloadSectionType === _dataload.DataloadSectionType.LEFT), _classNames))
-    }, "".concat((0, _utils.formatNumberValues)(converterService.LoadToEuro(dataload.value, fluidType, dataload.price ? dataload.price : null)), " \u20AC"));
-  }
-
-  if (fluidType === _fluid.FluidType.MULTIFLUID && dataloadSectionType !== _dataload.DataloadSectionType.NO_COMPARE) {
-    return /*#__PURE__*/_react.default.createElement("div", {
-      className: "dataloadvisualizer-euro text-16-normal"
-    });
-  }
-
-  if (fluidType === _fluid.FluidType.MULTIFLUID && dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE && dataload.valueDetail) {
-    return /*#__PURE__*/_react.default.createElement("div", {
-      className: "dataloadvisualizer-euro text-16-normal"
-    }, dataload.valueDetail.map(function (valueDetail, index) {
-      var _classNames2;
-
-      return /*#__PURE__*/_react.default.createElement(_reactRouterDom.NavLink, {
-        key: index,
-        to: "/consumption/".concat(_fluid.FluidType[index].toLowerCase()),
-        className: "dataloadvisualizer-euro-link"
-      }, /*#__PURE__*/_react.default.createElement("div", {
-        className: (0, _classnames.default)('dataloadvisualizer-euro-fluid', (_classNames2 = {}, (0, _defineProperty2.default)(_classNames2, " ".concat(_fluid.FluidType[index].toLowerCase()), valueDetail.state === _dataload.DataloadState.VALID || valueDetail.state === _dataload.DataloadState.UPCOMING || valueDetail.state === _dataload.DataloadState.COMING || valueDetail.state === _dataload.DataloadState.EMPTY || valueDetail.state === _dataload.DataloadState.HOLE), (0, _defineProperty2.default)(_classNames2, " error", valueDetail.state === _dataload.DataloadState.MISSING), _classNames2)),
-        onClick: function onClick() {
-          return emitNavEvent(_fluid.FluidType[index].toLowerCase());
-        }
-      }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
-        className: "dataloadvisualizer-euro-fluid-icon",
-        icon: (0, _picto.getNavPicto)(index, true, true),
-        size: 22
-      }), /*#__PURE__*/_react.default.createElement("div", null, valueDetail.state === _dataload.DataloadState.VALID && "".concat((0, _utils.formatNumberValues)(valueDetail.value), " \u20AC"), (valueDetail.state === _dataload.DataloadState.UPCOMING || valueDetail.state === _dataload.DataloadState.COMING) && t('consumption_visualizer.data_to_come'), (valueDetail.state === _dataload.DataloadState.EMPTY || valueDetail.state === _dataload.DataloadState.HOLE) && t('consumption_visualizer.data_empty'), valueDetail.state === _dataload.DataloadState.MISSING && t('consumption_visualizer.aie'))));
-    }));
-  }
-
-  return /*#__PURE__*/_react.default.createElement("div", {
-    className: "dataloadvisualizer-euro text-16-normal"
-  }, /*#__PURE__*/_react.default.createElement(_reactRouterDom.NavLink, {
-    to: "/consumption/".concat((0, _utils.getFluidName)(fluidType)),
-    className: "dataloadvisualizer-euro-link"
-  }, /*#__PURE__*/_react.default.createElement("div", {
-    className: "dataloadvisualizer-euro-fluid ".concat((0, _utils.getFluidName)(fluidType))
-  }, /*#__PURE__*/_react.default.createElement(_Icon.default, {
-    className: "dataloadvisualizer-euro-fluid-icon",
-    icon: (0, _picto.getNavPicto)(fluidType, true, true),
-    size: 22
-  }), /*#__PURE__*/_react.default.createElement("div", null, "".concat((0, _utils.formatNumberValues)(converterService.LoadToEuro(dataload.value, fluidType, dataload.price ? dataload.price : null)), " \u20AC")))));
-};
-
-var _default = DataloadSectionDetail;
-exports.default = _default;
-
-/***/ }),
-
 /***/ "PU46":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -638,144 +341,6 @@ exports.default = _default;
 
 /***/ }),
 
-/***/ "flqf":
-/***/ (function(module, exports, __webpack_require__) {
-
-exports = module.exports = __webpack_require__("JPst")(false);
-// Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.consumptionvisualizer-root {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  padding-bottom: 0.5rem;\n}\n@media only screen and (max-width : 768px) {\n  .consumptionvisualizer-root {\n    width: 100%;\n  }\n}\n.consumptionvisualizer-root .consumptionvisualizer-info {\n  min-height: 1.5rem;\n  display: flex;\n  align-items: center;\n}", ""]);
-
-
-
-/***/ }),
-
-/***/ "jx3z":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.default = void 0;
-
-var _I18n = __webpack_require__("buk/");
-
-var _dataload = __webpack_require__("D5WE");
-
-var _fluid = __webpack_require__("5Wkc");
-
-var _react = _interopRequireDefault(__webpack_require__("q1tI"));
-
-var _utils = __webpack_require__("c+yx");
-
-var DataloadSectionValue = function DataloadSectionValue(_ref) {
-  var dataload = _ref.dataload,
-      fluidType = _ref.fluidType,
-      dataloadSectionType = _ref.dataloadSectionType,
-      toggleEstimationModal = _ref.toggleEstimationModal;
-
-  var _useI18n = (0, _I18n.useI18n)(),
-      t = _useI18n.t;
-
-  if (fluidType === _fluid.FluidType.MULTIFLUID) {
-    return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value), /*#__PURE__*/_react.default.createElement("span", {
-      className: 'text-18-normal euroUnit'
-    }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT'))), dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE && /*#__PURE__*/_react.default.createElement("span", {
-      className: "text-14-normal estimated",
-      onClick: toggleEstimationModal
-    }, t('consumption_visualizer.estimated')));
-  }
-
-  var formattedValue = (0, _utils.formatNumberValues)(dataload.value, _fluid.FluidType[fluidType], true);
-  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, Number(formattedValue) >= 1000 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value, _fluid.FluidType[fluidType]), /*#__PURE__*/_react.default.createElement("span", {
-    className: "text-18-normal"
-  }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.MEGAUNIT')))) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, (0, _utils.formatNumberValues)(dataload.value), /*#__PURE__*/_react.default.createElement("span", {
-    className: 'text-18-normal'
-  }, "".concat(t('FLUID.' + _fluid.FluidType[fluidType] + '.UNIT')))));
-};
-
-var _default = DataloadSectionValue;
-exports.default = _default;
-
-/***/ }),
-
-/***/ "nGEn":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.default = void 0;
-
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
-var _classnames = _interopRequireDefault(__webpack_require__("TSYQ"));
-
-var _I18n = __webpack_require__("buk/");
-
-var _dataload = __webpack_require__("D5WE");
-
-var _fluid = __webpack_require__("5Wkc");
-
-var _react = _interopRequireDefault(__webpack_require__("q1tI"));
-
-var _utils = __webpack_require__("c+yx");
-
-var _DataloadSectionDetail = _interopRequireDefault(__webpack_require__("Np/d"));
-
-var _DataloadSectionValue = _interopRequireDefault(__webpack_require__("jx3z"));
-
-__webpack_require__("Fb5D");
-
-var DataloadSection = function DataloadSection(_ref) {
-  var _classNames, _classNames2;
-
-  var dataload = _ref.dataload,
-      fluidType = _ref.fluidType,
-      dataloadSectionType = _ref.dataloadSectionType,
-      toggleEstimationModal = _ref.toggleEstimationModal;
-
-  var _useI18n = (0, _I18n.useI18n)(),
-      t = _useI18n.t;
-
-  if (dataload.value === -1 && dataloadSectionType === _dataload.DataloadSectionType.LEFT) {
-    return /*#__PURE__*/_react.default.createElement("div", {
-      className: "dataloadvisualizer-section dataloadvisualizer-section-left-novalue"
-    }, /*#__PURE__*/_react.default.createElement("div", {
-      className: "dataloadvisualizer-novalue ".concat(_fluid.FluidType[fluidType].toLowerCase(), "-compare text-20-normal")
-    }, t('consumption_visualizer.no_data')));
-  }
-
-  return /*#__PURE__*/_react.default.createElement("div", {
-    className: (0, _classnames.default)('dataloadvisualizer-section', (_classNames = {}, (0, _defineProperty2.default)(_classNames, 'dataloadvisualizer-section-left', dataloadSectionType === _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames, 'dataloadvisualizer-section-right', dataloadSectionType === _dataload.DataloadSectionType.RIGHT), _classNames))
-  }, /*#__PURE__*/_react.default.createElement("div", {
-    className: (0, _classnames.default)('dataloadvisualizer-value', 'text-36-bold', (_classNames2 = {}, (0, _defineProperty2.default)(_classNames2, "".concat((0, _utils.getFluidName)(fluidType), "-compare"), dataloadSectionType === _dataload.DataloadSectionType.LEFT), (0, _defineProperty2.default)(_classNames2, "".concat((0, _utils.getFluidName)(fluidType)), dataloadSectionType === _dataload.DataloadSectionType.NO_COMPARE || dataloadSectionType === _dataload.DataloadSectionType.RIGHT), (0, _defineProperty2.default)(_classNames2, 'multifluid-compare-color', dataloadSectionType === _dataload.DataloadSectionType.RIGHT && fluidType === _fluid.FluidType.MULTIFLUID), _classNames2))
-  }, /*#__PURE__*/_react.default.createElement(_DataloadSectionValue.default, {
-    dataload: dataload,
-    fluidType: fluidType,
-    dataloadSectionType: dataloadSectionType,
-    toggleEstimationModal: toggleEstimationModal
-  })), /*#__PURE__*/_react.default.createElement(_DataloadSectionDetail.default, {
-    dataload: dataload,
-    fluidType: fluidType,
-    dataloadSectionType: dataloadSectionType
-  }));
-};
-
-var _default = DataloadSection;
-exports.default = _default;
-
-/***/ }),
-
 /***/ "pBt2":
 /***/ (function(module, exports, __webpack_require__) {
 
diff --git a/9/ecolyo.4facae32c2f3722bac49.js b/8/ecolyo.5a104e5906433ba909f2.js
similarity index 99%
rename from 9/ecolyo.4facae32c2f3722bac49.js
rename to 8/ecolyo.5a104e5906433ba909f2.js
index 2ec6d0819d89a57df8aad963fd38e02717bf5c01..778dfed93f6c790ce8bbc3e6df8292385a03676c 100644
--- a/9/ecolyo.4facae32c2f3722bac49.js
+++ b/8/ecolyo.5a104e5906433ba909f2.js
@@ -1,4 +1,4 @@
-(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[9],{
+(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[8],{
 
 /***/ "GwQd":
 /***/ (function(module, exports, __webpack_require__) {
diff --git a/8/ecolyo.a9363dc7eb1de5bcc528.js b/8/ecolyo.a9363dc7eb1de5bcc528.js
deleted file mode 100644
index a7276e9c0cd7adc6e8b22f862e7f9a0e3d6069fe..0000000000000000000000000000000000000000
--- a/8/ecolyo.a9363dc7eb1de5bcc528.js
+++ /dev/null
@@ -1,326 +0,0 @@
-(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[8],{
-
-/***/ "GrKv":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.default = void 0;
-
-var _regenerator = _interopRequireDefault(__webpack_require__("o0o1"));
-
-var _asyncToGenerator2 = _interopRequireDefault(__webpack_require__("yXPU"));
-
-var _classCallCheck2 = _interopRequireDefault(__webpack_require__("lwsE"));
-
-var _createClass2 = _interopRequireDefault(__webpack_require__("W8MJ"));
-
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
-var Sentry = _interopRequireWildcard(__webpack_require__("agHs"));
-
-var _cozyClient = __webpack_require__("SH7X");
-
-var _cozyLogger = _interopRequireDefault(__webpack_require__("Vggm"));
-
-var _doctypes = __webpack_require__("D2hQ");
-
-var _dataload = __webpack_require__("D5WE");
-
-var _luxon = __webpack_require__("ExVU");
-
-var _logger = _interopRequireDefault(__webpack_require__("gjtA"));
-
-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); }
-
-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; }
-
-var logStack = _cozyLogger.default.namespace('enedisMonthlyAnalysisDataService');
-
-var EnedisMonthlyAnalysisDataService = /*#__PURE__*/function () {
-  function EnedisMonthlyAnalysisDataService(_client) {
-    (0, _classCallCheck2.default)(this, EnedisMonthlyAnalysisDataService);
-    (0, _defineProperty2.default)(this, "_client", void 0);
-    (0, _defineProperty2.default)(this, "aggregateValuesToDataLoad", function (data) {
-      var dataLoadWeekDays = [];
-      var dataLoadWeekEndDays = [];
-      data.weekDaysHalfHourAverageValues.forEach(function (value, index) {
-        dataLoadWeekDays.push({
-          value: value,
-          state: _dataload.DataloadState.VALID,
-          valueDetail: null,
-          date: _luxon.DateTime.fromObject({
-            year: data.year,
-            month: data.month,
-            minute: 0
-          }).setZone('utc', {
-            keepLocalTime: true
-          }).plus({
-            minute: 30 * index
-          })
-        });
-      });
-      data.weekEndDaysHalfHourAverageValues.forEach(function (value, index) {
-        dataLoadWeekEndDays.push({
-          value: value,
-          state: _dataload.DataloadState.VALID,
-          valueDetail: null,
-          date: _luxon.DateTime.fromObject({
-            year: data.year,
-            month: data.month,
-            minute: 0
-          }).setZone('utc', {
-            keepLocalTime: true
-          }).plus({
-            minute: 30 * index
-          })
-        });
-      });
-      return {
-        week: dataLoadWeekDays,
-        weekend: dataLoadWeekEndDays
-      };
-    });
-    this._client = _client;
-  }
-  /**
-   * Retrieve all exploration entities from db
-   * @returns {EnedisMonthlyAnalysisData[]}
-   */
-
-
-  (0, _createClass2.default)(EnedisMonthlyAnalysisDataService, [{
-    key: "getAllEnedisMonthlyAnalysisData",
-    value: function () {
-      var _getAllEnedisMonthlyAnalysisData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee() {
-        var query, _yield$this$_client$q, enedisMonthlyAnalysisData;
-
-        return _regenerator.default.wrap(function _callee$(_context) {
-          while (1) {
-            switch (_context.prev = _context.next) {
-              case 0:
-                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE);
-                _context.next = 3;
-                return this._client.query(query);
-
-              case 3:
-                _yield$this$_client$q = _context.sent;
-                enedisMonthlyAnalysisData = _yield$this$_client$q.data;
-                return _context.abrupt("return", enedisMonthlyAnalysisData);
-
-              case 6:
-              case "end":
-                return _context.stop();
-            }
-          }
-        }, _callee, this);
-      }));
-
-      function getAllEnedisMonthlyAnalysisData() {
-        return _getAllEnedisMonthlyAnalysisData.apply(this, arguments);
-      }
-
-      return getAllEnedisMonthlyAnalysisData;
-    }()
-    /**
-     * getLastEnedisMonthlyAnalysis
-     * @param {Client} client
-     * @returns {Promise<EnedisMonthlyAnalysisData[]>}
-     */
-
-  }, {
-    key: "getLastEnedisMonthlyAnalysis",
-    value: function () {
-      var _getLastEnedisMonthlyAnalysis = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2() {
-        var query, data;
-        return _regenerator.default.wrap(function _callee2$(_context2) {
-          while (1) {
-            switch (_context2.prev = _context2.next) {
-              case 0:
-                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({}).indexFields(['year', 'month']).sortBy([{
-                  year: 'desc'
-                }, {
-                  month: 'desc'
-                }]).limitBy(1);
-                _context2.next = 3;
-                return this._client.query(query);
-
-              case 3:
-                data = _context2.sent;
-                return _context2.abrupt("return", data.data);
-
-              case 5:
-              case "end":
-                return _context2.stop();
-            }
-          }
-        }, _callee2, this);
-      }));
-
-      function getLastEnedisMonthlyAnalysis() {
-        return _getLastEnedisMonthlyAnalysis.apply(this, arguments);
-      }
-
-      return getLastEnedisMonthlyAnalysis;
-    }()
-    /**
-     * Aggregates Enedis Analysis data in order to create Dataload injectable in graph component
-     * @param {EnedisMonthlyAnalysisData} data
-     * @returns {AggregatedEnedisMonthlyDataloads}
-     */
-
-  }, {
-    key: "getEnedisMonthlyAnalysisByDate",
-    value:
-    /**
-     * Get an enedis monthly analysis for given month and year
-     * @param {number} year
-     * @param {number} month
-     * @returns {Promise<EnedisMonthlyAnalysisData[]>}
-     */
-    function () {
-      var _getEnedisMonthlyAnalysisByDate = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(year, month) {
-        var query, data;
-        return _regenerator.default.wrap(function _callee3$(_context3) {
-          while (1) {
-            switch (_context3.prev = _context3.next) {
-              case 0:
-                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({
-                  year: year,
-                  month: month
-                }).indexFields(['year', 'month']).sortBy([{
-                  year: 'desc'
-                }, {
-                  month: 'desc'
-                }]).limitBy(1);
-                _context3.next = 3;
-                return this._client.query(query);
-
-              case 3:
-                data = _context3.sent;
-                return _context3.abrupt("return", data.data);
-
-              case 5:
-              case "end":
-                return _context3.stop();
-            }
-          }
-        }, _callee3, this);
-      }));
-
-      function getEnedisMonthlyAnalysisByDate(_x, _x2) {
-        return _getEnedisMonthlyAnalysisByDate.apply(this, arguments);
-      }
-
-      return getEnedisMonthlyAnalysisByDate;
-    }()
-    /**
-     * Creates a new EnedisMonthlyAnalysis
-     * @param {EnedisMonthlyAnalysisData} newEnedisMonthlyAnalysisData
-     * @returns {Promise<EnedisMonthlyAnalysisData | null>}
-     */
-
-  }, {
-    key: "createEnedisMonthlyAnalysisData",
-    value: function () {
-      var _createEnedisMonthlyAnalysisData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(newEnedisMonthlyAnalysisData) {
-        var _yield$this$_client$c, EnedisMonthlyAnalysis, errorMessage;
-
-        return _regenerator.default.wrap(function _callee4$(_context4) {
-          while (1) {
-            switch (_context4.prev = _context4.next) {
-              case 0:
-                _context4.prev = 0;
-                _context4.next = 3;
-                return this._client.create(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE, newEnedisMonthlyAnalysisData);
-
-              case 3:
-                _yield$this$_client$c = _context4.sent;
-                EnedisMonthlyAnalysis = _yield$this$_client$c.data;
-                return _context4.abrupt("return", EnedisMonthlyAnalysis);
-
-              case 8:
-                _context4.prev = 8;
-                _context4.t0 = _context4["catch"](0);
-                errorMessage = "Error creating new EnedisMonthlyAnalysis: ".concat(JSON.stringify(_context4.t0));
-                logStack('error', errorMessage);
-
-                _logger.default.error(errorMessage);
-
-                Sentry.captureException(errorMessage);
-                throw _context4.t0;
-
-              case 15:
-              case "end":
-                return _context4.stop();
-            }
-          }
-        }, _callee4, this, [[0, 8]]);
-      }));
-
-      function createEnedisMonthlyAnalysisData(_x3) {
-        return _createEnedisMonthlyAnalysisData.apply(this, arguments);
-      }
-
-      return createEnedisMonthlyAnalysisData;
-    }()
-    /**
-     * Get Max power for a given month and year
-     * @param {number} year
-     * @param {number} month
-     * @returns {Promise<MaxPowerEntity[]>}
-     */
-
-  }, {
-    key: "getMaxPowerByDate",
-    value: function () {
-      var _getMaxPowerByDate = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(year, month) {
-        var query, data;
-        return _regenerator.default.wrap(function _callee5$(_context5) {
-          while (1) {
-            switch (_context5.prev = _context5.next) {
-              case 0:
-                query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MAXPOWER_DOCTYPE).where({
-                  year: year,
-                  month: month
-                }).indexFields(['year', 'month']).sortBy([{
-                  year: 'desc'
-                }, {
-                  month: 'desc'
-                }]);
-                _context5.next = 3;
-                return this._client.query(query);
-
-              case 3:
-                data = _context5.sent;
-                return _context5.abrupt("return", data.data);
-
-              case 5:
-              case "end":
-                return _context5.stop();
-            }
-          }
-        }, _callee5, this);
-      }));
-
-      function getMaxPowerByDate(_x4, _x5) {
-        return _getMaxPowerByDate.apply(this, arguments);
-      }
-
-      return getMaxPowerByDate;
-    }()
-  }]);
-  return EnedisMonthlyAnalysisDataService;
-}();
-
-exports.default = EnedisMonthlyAnalysisDataService;
-
-/***/ })
-
-}]);
\ No newline at end of file
diff --git a/10/ecolyo.e8a00fc8bc16cb5a9dfd.js b/9/ecolyo.d4e0f8345c64c54574af.js
similarity index 97%
rename from 10/ecolyo.e8a00fc8bc16cb5a9dfd.js
rename to 9/ecolyo.d4e0f8345c64c54574af.js
index ecaf24682c92605bf21c5f7bc81ef4997c2629dd..43e64e6da44b45adf3a4402ae6e34a84e12bd569 100644
--- a/10/ecolyo.e8a00fc8bc16cb5a9dfd.js
+++ b/9/ecolyo.d4e0f8345c64c54574af.js
@@ -1,4 +1,4 @@
-(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[10],{
+(window["webpackJsonp"] = window["webpackJsonp"] || []).push([[9],{
 
 /***/ "ckxh":
 /***/ (function(module, exports, __webpack_require__) {
diff --git a/app/ecolyo.9c6f20e5996a8ab34cd7.js b/app/ecolyo.a3308bcbd50a4d741c60.js
similarity index 97%
rename from app/ecolyo.9c6f20e5996a8ab34cd7.js
rename to app/ecolyo.a3308bcbd50a4d741c60.js
index ae4c8ec9b76055948243bbe735c46fa5c18b0d53..97dcac004dd670659c60937c96e3e7cc2e706863 100644
--- a/app/ecolyo.9c6f20e5996a8ab34cd7.js
+++ b/app/ecolyo.a3308bcbd50a4d741c60.js
@@ -64,7 +64,7 @@
 /******/
 /******/ 	// script path function
 /******/ 	function jsonpScriptSrc(chunkId) {
-/******/ 		return __webpack_require__.p + "" + ({}[chunkId]||chunkId) + "/ecolyo." + {"1":"c44aefc530d1de68ee3f","3":"dc7b4fa6e755df72417e","4":"f22d2e8508212a56cb53","5":"72a7eabe03dee9217ec1","6":"1540774c38e7b6124ec7","7":"8129fd19ad98c11c5897","8":"a9363dc7eb1de5bcc528","9":"4facae32c2f3722bac49","10":"e8a00fc8bc16cb5a9dfd"}[chunkId] + ".js"
+/******/ 		return __webpack_require__.p + "" + ({}[chunkId]||chunkId) + "/ecolyo." + {"1":"c44aefc530d1de68ee3f","3":"eff4cc1e75bcc37e8fed","4":"4bdc1836bb506dfd5fea","5":"cf7d1f9bca710f0b366e","6":"c03889ab8782bad3bebe","7":"1850b6ce28566211a509","8":"5a104e5906433ba909f2","9":"d4e0f8345c64c54574af"}[chunkId] + ".js"
 /******/ 	}
 /******/
 /******/ 	// The require function
@@ -415,7 +415,7 @@ var _quiz = _interopRequireDefault(__webpack_require__("CUhI"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("mFBf");
 
@@ -608,8 +608,6 @@ var _tracing = __webpack_require__("aI3+");
 
 var _cozyClient = _interopRequireWildcard(__webpack_require__("SH7X"));
 
-var _cozyDeviceHelper = __webpack_require__("snfs");
-
 var _oauth = __webpack_require__("sDS3");
 
 var _cozyIntent = __webpack_require__("qvEe");
@@ -686,7 +684,7 @@ var setupApp = (0, _lodash.memoize)(function () {
     replaceTitleOnMobile: false,
     appSlug: data.app.slug,
     appNamePrefix: data.app.prefix,
-    isInvertedTheme: (0, _cozyDeviceHelper.isFlagshipApp)()
+    isInvertedTheme: true
   });
 
   var tracker;
@@ -1369,8 +1367,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.default = void 0;
 
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
 var _slicedToArray2 = _interopRequireDefault(__webpack_require__("J4zp"));
 
 var _core = __webpack_require__("TTf+");
@@ -1389,47 +1385,39 @@ var _luxon = __webpack_require__("ExVU");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _utils = __webpack_require__("c+yx");
-
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
   var step = _ref.step,
+      viewedStep = _ref.viewedStep,
       profileType = _ref.profileType,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
-      setPreviousStep = _ref.setPreviousStep;
+      setPreviousStep = _ref.setPreviousStep,
+      isProfileTypeComplete = _ref.isProfileTypeComplete;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
-  var _useState = (0, _react.useState)(_luxon.DateTime.now().year),
-      _useState2 = (0, _slicedToArray2.default)(_useState, 2),
-      selectedYear = _useState2[0],
-      setSelectedYear = _useState2[1];
-
-  var _useState3 = (0, _react.useState)({
+  var _useState = (0, _react.useState)({
     label: _luxon.DateTime.now().toLocaleString({
       month: 'long'
     }),
     value: _luxon.DateTime.now().month.toString().padStart(2, '0') // Date.getMonth starts at 0
 
   }),
-      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      selectedMonth = _useState4[0],
-      setSelectedMonth = _useState4[1];
+      _useState2 = (0, _slicedToArray2.default)(_useState, 2),
+      selectedMonth = _useState2[0],
+      setSelectedMonth = _useState2[1];
 
-  var buildISODate = function buildISODate(year, month) {
-    return _luxon.DateTime.fromISO("".concat(year, "-").concat(month, "-01"));
-  };
+  var _useState3 = (0, _react.useState)(_luxon.DateTime.now().year),
+      _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
+      selectedYear = _useState4[0],
+      setSelectedYear = _useState4[1];
 
-  var _useState5 = (0, _react.useState)(buildISODate(selectedYear.toString(), selectedMonth.value)),
+  var _useState5 = (0, _react.useState)(''),
       _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
       answer = _useState6[0],
       setAnswer = _useState6[1];
@@ -1456,7 +1444,7 @@ var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
     label: 'Juillet',
     value: '07'
   }, {
-    label: 'Août',
+    label: 'Aout',
     value: '08'
   }, {
     label: 'Septembre',
@@ -1481,30 +1469,79 @@ var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
     selectYears.push(i);
   }
 
-  var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+  function getMonthFullName(month) {
+    switch (month) {
+      case 1:
+        return 'Janvier';
 
-  var handleNext = function handleNext() {
-    setNextStep(_objectSpread(_objectSpread({}, profileType), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  };
+      case 2:
+        return 'Février';
+
+      case 3:
+        return 'Mars';
+
+      case 4:
+        return 'Avril';
+
+      case 5:
+        return 'Mai';
+
+      case 6:
+        return 'Juin';
+
+      case 7:
+        return 'Juillet';
+
+      case 8:
+        return 'Aout';
+
+      case 9:
+        return 'Septembre';
+
+      case 10:
+        return 'Octobre';
+
+      case 11:
+        return 'Novembre';
+
+      case 12:
+        return 'Décembre';
+
+      default:
+        return null;
+    }
+  }
+
+  var handlePrevious = (0, _react.useCallback)(function () {
+    setPreviousStep(profileType);
+  }, [profileType, setPreviousStep]);
+  var handleNext = (0, _react.useCallback)(function () {
+    profileType[answerType.attribute] = answer;
+    setNextStep(profileType);
+  }, [profileType, setNextStep, answer, answerType.attribute]);
 
   function handleSelectMonth(event) {
     setSelectedMonth({
       value: event.target.value,
-      label: (0, _utils.getMonthFullName)(parseInt(event.target.value))
+      label: getMonthFullName(parseInt(event.target.value))
     });
-    setAnswer(buildISODate(selectedYear.toString(), event.target.value));
+    var isoString = selectedYear + '-' + selectedMonth.value + '-01';
+    setAnswer(_luxon.DateTime.fromISO(isoString));
   }
 
   function handleSelectYear(event) {
     setSelectedYear(parseInt(event.target.value));
-    setAnswer(buildISODate(event.target.value, selectedMonth.value));
+    var isoString = selectedYear + '-' + selectedMonth.value + '-01';
+    setAnswer(_luxon.DateTime.fromISO(isoString));
   }
-  /** If current year, only show past and present months else show full months */
 
-
-  var renderMonths = selectedYear === _luxon.DateTime.now().year ? selectMonths.slice(0, _luxon.DateTime.now().month) : selectMonths;
+  (0, _react.useEffect)(function () {
+    if (step < viewedStep || isProfileTypeComplete) {
+      var isoString = selectedYear + '-' + selectedMonth.value + '-01';
+      setAnswer(_luxon.DateTime.fromISO(isoString));
+      profileType[answerType.attribute] = _luxon.DateTime.fromISO(isoString);
+    }
+  }, [step, viewedStep, profileType, answerType, isProfileTypeComplete, selectedYear, selectedMonth.value]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container'
   }, /*#__PURE__*/_react.default.createElement(_FormProgress.default, {
@@ -1512,7 +1549,7 @@ var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
     formType: 'profile'
   }), /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-question-label'
-  }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), answer !== null && /*#__PURE__*/_react.default.createElement("div", {
+  }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), answer !== null ? /*#__PURE__*/_react.default.createElement("div", {
     className: "select-container"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: "date-select"
@@ -1520,7 +1557,6 @@ var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
     labelId: "selectYearDate",
     className: "year",
     defaultValue: selectedYear,
-    value: selectedYear,
     onChange: function onChange(e) {
       return handleSelectYear(e);
     }
@@ -1533,20 +1569,26 @@ var ProfileTypeFormDateSelection = function ProfileTypeFormDateSelection(_ref) {
   }))), /*#__PURE__*/_react.default.createElement("div", {
     className: "date-select"
   }, /*#__PURE__*/_react.default.createElement(_core.Select, {
+    native: false,
     labelId: "selectMonthDate",
     className: "month",
     defaultValue: selectedMonth.value,
-    value: selectedMonth.value,
     onChange: function onChange(e) {
       return handleSelectMonth(e);
     }
-  }, renderMonths.map(function (month) {
+  }, selectedYear === _luxon.DateTime.now().year ? selectMonths.slice(0, _luxon.DateTime.now().month).map(function (month) {
+    return /*#__PURE__*/_react.default.createElement(_core.MenuItem, {
+      value: month.value,
+      key: month.value,
+      className: "date-option"
+    }, month.label);
+  }) : selectMonths.map(function (month) {
     return /*#__PURE__*/_react.default.createElement(_core.MenuItem, {
       value: month.value,
       key: month.value,
       className: "date-option"
     }, month.label);
-  }))))), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
+  })))) : null), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
     step: step,
     handlePrevious: handlePrevious,
     handleNext: handleNext,
@@ -1644,13 +1686,9 @@ var _initialization = _interopRequireDefault(__webpack_require__("zIFU"));
 
 var _partnersInfo = _interopRequireDefault(__webpack_require__("4zrG"));
 
-var _profileTypeEntity = _interopRequireDefault(__webpack_require__("aypK"));
-
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _analysis = __webpack_require__("JQjK");
-
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _chart = __webpack_require__("idK9");
 
@@ -1662,7 +1700,7 @@ var _profile = __webpack_require__("jPH6");
 
 var _profileEcogesture = __webpack_require__("Zmlh");
 
-var _profileType = __webpack_require__("ZI2v");
+var _profileType = __webpack_require__("TeAr");
 
 var _duration = __webpack_require__("P86i");
 
@@ -1835,36 +1873,6 @@ var SplashRoot = function SplashRoot(_ref) {
       return _ref4.apply(this, arguments);
     };
   }(), [dispatch, getPartnerStatus]);
-  var loadProfileType = (0, _react2.useCallback)( /*#__PURE__*/function () {
-    var _ref5 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(profileType) {
-      var profileTypeEntityService, updatedProfileType;
-      return _regenerator.default.wrap(function _callee4$(_context4) {
-        while (1) {
-          switch (_context4.prev = _context4.next) {
-            case 0:
-              profileTypeEntityService = new _profileTypeEntity.default(client);
-              _context4.next = 3;
-              return profileTypeEntityService.saveProfileType(profileType);
-
-            case 3:
-              updatedProfileType = _context4.sent;
-
-              if (updatedProfileType) {
-                dispatch((0, _profileType.setProfileType)(updatedProfileType));
-              }
-
-            case 5:
-            case "end":
-              return _context4.stop();
-          }
-        }
-      }, _callee4);
-    }));
-
-    return function (_x7) {
-      return _ref5.apply(this, arguments);
-    };
-  }(), [client, dispatch]);
   (0, _react2.useEffect)(function () {
     var timeoutSplash;
 
@@ -1895,12 +1903,12 @@ var SplashRoot = function SplashRoot(_ref) {
     }
 
     function _loadData() {
-      _loadData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee7() {
+      _loadData = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6() {
         var initializationService, customPopupService, partnersInfoService, ms, startTime, transaction, termsStatus, profile, profileType, profileEcogesture, migrationsResult, _yield$Promise$all, _yield$Promise$all2, duelHash, quizHash, challengeHash, explorationHash, analysisResult, updatedProfile, fluidStatus, refDate, lastDataDate, _iterator, _step, fluid, userChallengeList, _filteredCurrentOngoi, _filteredCurrentOngoi2, _filteredCurrentOngoi3, _filteredCurrentDuelC, filteredCurrentOngoingChallenge, actionService, updatedUserChallenge, filteredCurrentDuelChallenge, _yield$initialization, _updatedUserChallenge, dataloads, challengeService, _yield$challengeServi, isDone;
 
-        return _regenerator.default.wrap(function _callee7$(_context7) {
+        return _regenerator.default.wrap(function _callee6$(_context6) {
           while (1) {
-            switch (_context7.prev = _context7.next) {
+            switch (_context6.prev = _context6.next) {
               case 0:
                 initializationService = new _initialization.default(client, setInitStep, setInitStepErrors);
                 customPopupService = new _customPopup.default(client);
@@ -1910,52 +1918,52 @@ var SplashRoot = function SplashRoot(_ref) {
                 transaction = Sentry.startTransaction({
                   name: 'Initialize app'
                 });
-                _context7.prev = 6;
-                _context7.next = 9;
+                _context6.prev = 6;
+                _context6.next = 9;
                 return initializationService.initConsent();
 
               case 9:
-                termsStatus = _context7.sent;
+                termsStatus = _context6.sent;
                 if (subscribed) dispatch((0, _global.updateTermValidation)(termsStatus)); // Init fluidPrices
 
-                _context7.next = 13;
+                _context6.next = 13;
                 return initializationService.initFluidPrices();
 
               case 13:
-                _context7.next = 15;
+                _context6.next = 15;
                 return initializationService.initProfile();
 
               case 15:
-                profile = _context7.sent;
-                _context7.next = 18;
+                profile = _context6.sent;
+                _context6.next = 18;
                 return initializationService.initProfileType();
 
               case 18:
-                profileType = _context7.sent;
-                _context7.next = 21;
+                profileType = _context6.sent;
+                _context6.next = 21;
                 return initializationService.initProfileEcogesture();
 
               case 21:
-                profileEcogesture = _context7.sent;
-                _context7.next = 24;
+                profileEcogesture = _context6.sent;
+                _context6.next = 24;
                 return ms.runMigrations(_migration.migrations);
 
               case 24:
-                migrationsResult = _context7.sent;
+                migrationsResult = _context6.sent;
                 // Init last release notes when they exist
                 dispatch((0, _global.showReleaseNotes)(migrationsResult.show, migrationsResult.notes, migrationsResult.redirectLink));
 
                 if (!(subscribed && profile)) {
-                  _context7.next = 45;
+                  _context6.next = 42;
                   break;
                 }
 
                 setValidExploration(_userExploration.UserExplorationID.EXPLORATION007);
-                _context7.next = 30;
+                _context6.next = 30;
                 return Promise.all([initializationService.initDuelEntity(profile.duelHash), initializationService.initQuizEntity(profile.quizHash), initializationService.initExplorationEntity(profile.challengeHash), initializationService.initChallengeEntity(profile.explorationHash), initializationService.initAnalysis(profile)]);
 
               case 30:
-                _yield$Promise$all = _context7.sent;
+                _yield$Promise$all = _context6.sent;
                 _yield$Promise$all2 = (0, _slicedToArray2.default)(_yield$Promise$all, 5);
                 duelHash = _yield$Promise$all2[0];
                 quizHash = _yield$Promise$all2[1];
@@ -1971,29 +1979,23 @@ var SplashRoot = function SplashRoot(_ref) {
                   haveSeenLastAnalysis: analysisResult.haveSeenLastAnalysis
                 };
                 dispatch((0, _profile.updateProfile)(updatedProfile));
-                dispatch((0, _analysis.setAnalysisMonth)(analysisResult.monthlyAnalysisDate));
 
-                if (!profileType) {
-                  _context7.next = 43;
-                  break;
+                if (profileType) {
+                  dispatch((0, _profileType.updateProfileType)(profileType));
                 }
 
-                _context7.next = 43;
-                return loadProfileType(profileType);
-
-              case 43:
                 if (profileEcogesture) {
                   dispatch((0, _profileEcogesture.updateProfileEcogestureSuccess)(profileEcogesture));
                 }
 
                 dispatch((0, _global.toggleAnalysisNotification)(!profile.haveSeenLastAnalysis));
 
-              case 45:
-                _context7.next = 47;
+              case 42:
+                _context6.next = 44;
                 return initializationService.initFluidStatus();
 
-              case 47:
-                fluidStatus = _context7.sent;
+              case 44:
+                fluidStatus = _context6.sent;
 
                 if (subscribed) {
                   dispatch((0, _global.setFluidStatus)(fluidStatus));
@@ -2021,14 +2023,14 @@ var SplashRoot = function SplashRoot(_ref) {
                 } // Init Challenge
 
 
-                _context7.next = 51;
+                _context6.next = 48;
                 return initializationService.initUserChallenges(fluidStatus);
 
-              case 51:
-                userChallengeList = _context7.sent;
+              case 48:
+                userChallengeList = _context6.sent;
 
                 if (!subscribed) {
-                  _context7.next = 78;
+                  _context6.next = 75;
                   break;
                 }
 
@@ -2043,22 +2045,22 @@ var SplashRoot = function SplashRoot(_ref) {
 
 
                 if (!(((_filteredCurrentOngoi2 = filteredCurrentOngoingChallenge[0]) === null || _filteredCurrentOngoi2 === void 0 ? void 0 : _filteredCurrentOngoi2.action.state) === _userAction.UserActionState.ONGOING)) {
-                  _context7.next = 62;
+                  _context6.next = 59;
                   break;
                 }
 
                 actionService = new _action.default(client);
-                _context7.next = 60;
+                _context6.next = 57;
                 return actionService.isActionDone(filteredCurrentOngoingChallenge[0]);
 
-              case 60:
-                updatedUserChallenge = _context7.sent;
+              case 57:
+                updatedUserChallenge = _context6.sent;
 
                 if (updatedUserChallenge) {
                   dispatch((0, _challenge2.updateUserChallengeList)(updatedUserChallenge));
                 }
 
-              case 62:
+              case 59:
                 // Set Notification if action state is notification
                 if (((_filteredCurrentOngoi3 = filteredCurrentOngoingChallenge[0]) === null || _filteredCurrentOngoi3 === void 0 ? void 0 : _filteredCurrentOngoi3.action.state) === _userAction.UserActionState.NOTIFICATION) {
                   dispatch((0, _global.toggleChallengeActionNotification)(true));
@@ -2069,108 +2071,105 @@ var SplashRoot = function SplashRoot(_ref) {
                 });
 
                 if (!(((_filteredCurrentDuelC = filteredCurrentDuelChallenge[0]) === null || _filteredCurrentDuelC === void 0 ? void 0 : _filteredCurrentDuelC.duel.state) === _userDuel.UserDuelState.ONGOING)) {
-                  _context7.next = 78;
+                  _context6.next = 75;
                   break;
                 }
 
-                _context7.next = 67;
+                _context6.next = 64;
                 return initializationService.initDuelProgress(filteredCurrentDuelChallenge[0]);
 
-              case 67:
-                _yield$initialization = _context7.sent;
+              case 64:
+                _yield$initialization = _context6.sent;
                 _updatedUserChallenge = _yield$initialization.updatedUserChallenge;
                 dataloads = _yield$initialization.dataloads;
 
                 if (!subscribed) {
-                  _context7.next = 78;
+                  _context6.next = 75;
                   break;
                 }
 
-                dispatch((0, _challenge2.setChallengeConsumption)({
-                  userChallenge: _updatedUserChallenge,
-                  currentDataload: dataloads
-                })); // Check is duel is done and display notification
+                dispatch((0, _challenge2.setChallengeConsumption)(_updatedUserChallenge, dataloads)); // Check is duel is done and display notification
 
                 challengeService = new _challenge.default(client);
-                _context7.next = 75;
+                _context6.next = 72;
                 return challengeService.isChallengeDone(_updatedUserChallenge, dataloads);
 
-              case 75:
-                _yield$challengeServi = _context7.sent;
+              case 72:
+                _yield$challengeServi = _context6.sent;
                 isDone = _yield$challengeServi.isDone;
                 dispatch((0, _global.toggleChallengeDuelNotification)(isDone));
 
-              case 78:
+              case 75:
                 if (!profile) {
-                  _context7.next = 81;
+                  _context6.next = 78;
                   break;
                 }
 
-                _context7.next = 81;
+                _context6.next = 78;
                 return _usageEvent2.default.addEvent(client, {
                   type: _usageEvent.UsageEventType.CONNECTION_EVENT,
                   result: profile.isFirstConnection ? 'firstConnection' : undefined,
                   context: /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent) ? 'mobile' : 'desktop'
                 });
 
-              case 81:
+              case 78:
                 /**
                  * Load custom popup and partners info synchronously so these treatments don't block the loading
                  */
                 customPopupService.getCustomPopup().then( /*#__PURE__*/function () {
-                  var _ref6 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(customPopup) {
-                    return _regenerator.default.wrap(function _callee5$(_context5) {
+                  var _ref5 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(customPopup) {
+                    return _regenerator.default.wrap(function _callee4$(_context4) {
                       while (1) {
-                        switch (_context5.prev = _context5.next) {
+                        switch (_context4.prev = _context4.next) {
                           case 0:
                             if (!(profile && customPopup)) {
-                              _context5.next = 3;
+                              _context4.next = 3;
                               break;
                             }
 
-                            _context5.next = 3;
+                            _context4.next = 3;
                             return processCustomPopup(profile, customPopup);
 
                           case 3:
                           case "end":
-                            return _context5.stop();
+                            return _context4.stop();
                         }
                       }
-                    }, _callee5);
+                    }, _callee4);
                   }));
 
-                  return function (_x8) {
-                    return _ref6.apply(this, arguments);
+                  return function (_x7) {
+                    return _ref5.apply(this, arguments);
                   };
                 }());
                 partnersInfoService.getPartnersInfo().then( /*#__PURE__*/function () {
-                  var _ref7 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee6(partnersInfo) {
-                    return _regenerator.default.wrap(function _callee6$(_context6) {
+                  var _ref6 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(partnersInfo) {
+                    return _regenerator.default.wrap(function _callee5$(_context5) {
                       while (1) {
-                        switch (_context6.prev = _context6.next) {
+                        switch (_context5.prev = _context5.next) {
                           case 0:
                             if (!(profile && partnersInfo)) {
-                              _context6.next = 5;
+                              _context5.next = 5;
                               break;
                             }
 
-                            _context6.next = 3;
+                            _context5.next = 3;
                             return processFluidsStatus(profile, partnersInfo);
 
                           case 3:
-                            _context6.next = 5;
+                            _context5.next = 5;
                             return processPartnersStatus(profile, partnersInfo);
 
                           case 5:
                           case "end":
-                            return _context6.stop();
+                            return _context5.stop();
                         }
                       }
-                    }, _callee6);
+                    }, _callee5);
                   }));
 
-                  return function (_x9) {
-                    return _ref7.apply(this, arguments);
+                  return function (_x8) {
+                    return _ref6.apply(this, arguments);
                   };
                 }());
 
@@ -2183,34 +2182,34 @@ var SplashRoot = function SplashRoot(_ref) {
                   });
                 }
 
-                _context7.next = 91;
+                _context6.next = 88;
                 break;
 
-              case 86:
-                _context7.prev = 86;
-                _context7.t0 = _context7["catch"](6);
+              case 83:
+                _context6.prev = 83;
+                _context6.t0 = _context6["catch"](6);
 
-                if (_context7.t0.message === 'Failed to fetch' && !initStepErrors) {
+                if (_context6.t0.message === 'Failed to fetch' && !initStepErrors) {
                   setInitStepErrors(_models.InitStepsErrors.UNKNOWN_ERROR);
                 }
 
-                _logger.default.error("[Initialization] Error : ".concat(_context7.t0));
+                _logger.default.error("[Initialization] Error : ".concat(_context6.t0));
 
                 Sentry.captureException(JSON.stringify({
-                  error: _context7.t0
+                  error: _context6.t0
                 }));
 
-              case 91:
-                _context7.prev = 91;
+              case 88:
+                _context6.prev = 88;
                 transaction.finish();
-                return _context7.finish(91);
+                return _context6.finish(88);
 
-              case 94:
+              case 91:
               case "end":
-                return _context7.stop();
+                return _context6.stop();
             }
           }
-        }, _callee7, null, [[6, 86, 91, 94]]);
+        }, _callee6, null, [[6, 83, 88, 91]]);
       }));
       return _loadData.apply(this, arguments);
     }
@@ -2219,7 +2218,7 @@ var SplashRoot = function SplashRoot(_ref) {
     return function () {
       subscribed = false;
     };
-  }, [client, dispatch, initStepErrors, loadProfileType, processCustomPopup, processFluidsStatus, processPartnersStatus, setValidExploration]);
+  }, [client, dispatch, initStepErrors, processCustomPopup, processFluidsStatus, processPartnersStatus, setValidExploration]);
   return /*#__PURE__*/_react2.default.createElement(_react2.default.Fragment, null, !splashEnd && /*#__PURE__*/_react2.default.createElement("div", {
     style: {
       transitionDuration: "".concat(fadeTimer / 1000, "s")
@@ -2263,8 +2262,6 @@ exports.default = void 0;
 
 var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("RIqP"));
 
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
 var _slicedToArray2 = _interopRequireDefault(__webpack_require__("J4zp"));
 
 var _FormNavigation = _interopRequireDefault(__webpack_require__("Pnfk"));
@@ -2281,6 +2278,12 @@ var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
 var _reactRedux = __webpack_require__("/MKj");
 
+var _reactRouterDom = __webpack_require__("SOjZ");
+
+var _profile = __webpack_require__("jPH6");
+
+var _profileEcogesture2 = __webpack_require__("Zmlh");
+
 var _EquipmentIcon = _interopRequireDefault(__webpack_require__("Nixq"));
 
 __webpack_require__("cU6T");
@@ -2289,52 +2292,52 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var EcogestureFormEquipment = function EcogestureFormEquipment(_ref) {
-  var currentProfileEcogesture = _ref.currentProfileEcogesture,
-      currentProfileType = _ref.currentProfileType,
+  var profileEcogesture = _ref.profileEcogesture,
       setPreviousStep = _ref.setPreviousStep,
-      setNextStepEcogestureForm = _ref.setNextStepEcogestureForm,
-      setNextStepProfileForm = _ref.setNextStepProfileForm,
+      setNextStep = _ref.setNextStep,
       step = _ref.step;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
+  var dispatch = (0, _reactRedux.useDispatch)();
+  var navigate = (0, _reactRouterDom.useNavigate)();
+
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
     return state.ecolyo.profile;
   }),
       isProfileEcogestureCompleted = _useSelector.isProfileEcogestureCompleted;
 
-  var previousEquipments = (currentProfileType === null || currentProfileType === void 0 ? void 0 : currentProfileType.equipments) || (currentProfileEcogesture === null || currentProfileEcogesture === void 0 ? void 0 : currentProfileEcogesture.equipments) || [];
-
-  var _useState = (0, _react.useState)(isProfileEcogestureCompleted ? previousEquipments : []),
+  var _useState = (0, _react.useState)(isProfileEcogestureCompleted ? profileEcogesture.equipments : []),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
       setAnswer = _useState2[1];
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileEcogesture);
+  }, [profileEcogesture, setPreviousStep]);
   var handleNext = (0, _react.useCallback)(function () {
-    if (setNextStepProfileForm && currentProfileType) {
-      setNextStepProfileForm(_objectSpread(_objectSpread({}, currentProfileType), {}, {
-        equipments: answer
-      }));
-    } else if (setNextStepEcogestureForm && currentProfileEcogesture) {
-      setNextStepEcogestureForm(_objectSpread(_objectSpread({}, currentProfileEcogesture), {}, {
-        equipments: answer
+    profileEcogesture.equipments = answer; // Check if gestureForm is used from Big profile or small profile
+
+    if (setNextStep) {
+      setNextStep();
+      dispatch((0, _profileEcogesture2.updateProfileEcogesture)(profileEcogesture));
+    } else {
+      dispatch((0, _profileEcogesture2.newProfileEcogestureEntry)(profileEcogesture));
+      dispatch((0, _profile.updateProfile)({
+        isProfileEcogestureCompleted: true
       }));
+      navigate('/ecogesture-selection');
     }
-  }, [setNextStepProfileForm, currentProfileType, setNextStepEcogestureForm, currentProfileEcogesture, answer]);
-
-  var isChecked = function isChecked(value) {
-    return answer.includes(value);
-  };
-
+  }, [profileEcogesture, setNextStep, answer, dispatch, navigate]);
+  var isChecked = (0, _react.useCallback)(function (value) {
+    if (answer.includes(value)) {
+      return true;
+    } else {
+      return false;
+    }
+  }, [answer]);
   var handleChange = (0, _react.useCallback)(function (value) {
     var tempAnswer = (0, _toConsumableArray2.default)(answer);
 
@@ -4044,14 +4047,10 @@ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "functio
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var EcogestureFormSingleChoice = function EcogestureFormSingleChoice(_ref) {
   var step = _ref.step,
       viewedStep = _ref.viewedStep,
-      currentProfileEcogesture = _ref.currentProfileEcogesture,
+      profileEcogesture = _ref.profileEcogesture,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
       setPreviousStep = _ref.setPreviousStep;
@@ -4064,45 +4063,53 @@ var EcogestureFormSingleChoice = function EcogestureFormSingleChoice(_ref) {
   }),
       isProfileEcogestureCompleted = _useSelector.isProfileEcogestureCompleted;
 
-  var _useState = (0, _react.useState)(isProfileEcogestureCompleted || step < viewedStep ? currentProfileEcogesture[answerType.attribute] : null),
+  var _useState = (0, _react.useState)(isProfileEcogestureCompleted ? profileEcogesture[answerType.attribute] : ''),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
       setAnswer = _useState2[1];
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileEcogesture);
+  }, [profileEcogesture, setPreviousStep]);
+  var handleAnswer = (0, _react.useCallback)(function (value) {
+    setAnswer(value);
+  }, []);
   var handleNext = (0, _react.useCallback)(function () {
-    setNextStep(_objectSpread(_objectSpread({}, currentProfileEcogesture), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  }, [currentProfileEcogesture, setNextStep, answer, answerType.attribute]);
+    profileEcogesture[answerType.attribute] = answer;
+    setNextStep(profileEcogesture);
+  }, [profileEcogesture, setNextStep, answer, answerType.attribute]);
+  (0, _react.useEffect)(function () {
+    if (step < viewedStep) {
+      setAnswer(profileEcogesture[answerType.attribute]);
+    }
+  }, [step, viewedStep, profileEcogesture, answerType]);
   return /*#__PURE__*/_react.default.createElement("div", {
     className: "ecogesture-profile-container"
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container ecogesture-form-single'
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-question-label'
-  }, t("ecogesture_form.".concat(_ecogestureForm.EcogestureStepForm[step].toLowerCase(), ".question"))), answerType.choices.map(function (value) {
+  }, t("ecogesture_form.".concat(_ecogestureForm.EcogestureStepForm[step].toLowerCase(), ".question"))), answerType.choices.map(function (value, index) {
     var _classNames;
 
-    if (!value) return null;
-    return /*#__PURE__*/_react.default.createElement("label", {
-      key: value.toString(),
+    return value || value === 0 ? /*#__PURE__*/_react.default.createElement("label", {
+      key: index,
       className: (0, _classnames.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, 'radio_short', answerType.choices.length < 5), (0, _defineProperty2.default)(_classNames, 'radio_long', answerType.choices.length > 4), (0, _defineProperty2.default)(_classNames, 'answer-checked', answer === value), _classNames))
     }, /*#__PURE__*/_react.default.createElement("input", {
       type: 'radio',
       value: value,
       name: value.toString(),
       onChange: function onChange() {
-        return setAnswer(value);
+        return handleAnswer(value);
       },
-      checked: answer === value,
+      checked: answer === value ? true : false,
       className: answer === value ? 'checked-input' : ''
-    }), t("ecogesture_form.".concat(_ecogestureForm.EcogestureStepForm[step].toLowerCase(), ".").concat(value)));
+    }), t("ecogesture_form.".concat(_ecogestureForm.EcogestureStepForm[step].toLowerCase(), ".").concat(value))) : null;
   })), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
     step: step,
     handlePrevious: handlePrevious,
     handleNext: handleNext,
-    disableNextButton: answer === null,
+    disableNextButton: answer === '',
     isEcogesture: true
   }));
 };
@@ -5629,7 +5636,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _global = __webpack_require__("c4IZ");
 
@@ -5680,7 +5687,7 @@ var DuelOngoing = function DuelOngoing(_ref) {
 
   var chartContainer = (0, _react.useRef)(null);
 
-  var _useChartResize = (0, _useChartResize2.useChartResize)(chartContainer, false),
+  var _useChartResize = (0, _useChartResize2.useChartResize)(chartContainer),
       height = _useChartResize.height,
       width = _useChartResize.width;
 
@@ -7650,8 +7657,6 @@ var _heating = _interopRequireDefault(__webpack_require__("WQDB"));
 
 var _cozyLogger = _interopRequireDefault(__webpack_require__("Vggm"));
 
-var _orgEcolyo = __webpack_require__("dK8s");
-
 var _fluid = __webpack_require__("5Wkc");
 
 var _profileType = __webpack_require__("D9qV");
@@ -7684,7 +7689,7 @@ var ProfileTypeService = /*#__PURE__*/function () {
     (0, _defineProperty2.default)(this, "year", void 0);
     (0, _defineProperty2.default)(this, "fetchDJU", /*#__PURE__*/function () {
       var _ref = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(month) {
-        var startDate, endDate, result, monthDju, degreeDayObservations, _iterator, _step, observation, errorMessage;
+        var startDate, endDate, result, monthDju, _iterator, _step, observation, errorMessage;
 
         return _regenerator.default.wrap(function _callee$(_context) {
           while (1) {
@@ -7696,32 +7701,34 @@ var ProfileTypeService = /*#__PURE__*/function () {
                   year: _this.year
                 }).set({
                   month: month
-                }).startOf('month').toISO();
+                }).startOf('month').minus({
+                  minutes: 5
+                }).toISO();
                 endDate = _luxon.DateTime.local().setZone('utc', {
                   keepLocalTime: true
                 }).set({
                   year: _this.year
                 }).set({
                   month: month
-                }).endOf('month').toISO();
+                }).endOf('month').plus({
+                  minutes: 5
+                }).toISO(); // We add or remove 5 minutes so the api returns the exact period
+
                 _context.prev = 2;
                 _context.next = 5;
-                return _this._client.getStackClient().fetchJSON('GET', "".concat(_orgEcolyo.REMOTE_ORG_ECOLYO_DJU, "?startDate=").concat(startDate, "&endDate=").concat(endDate));
+                return _this._client.getStackClient().fetchJSON('GET', "/remote/org.ecolyo.dju?observedProperty=degreeDay&startDate=".concat(startDate, "&endDate=").concat(endDate));
 
               case 5:
                 result = _context.sent;
                 monthDju = 0;
 
                 if (result) {
-                  degreeDayObservations = result.values.filter(function (value) {
-                    return value.observation === 'degreeDay';
-                  });
-                  _iterator = _createForOfIteratorHelper(degreeDayObservations);
+                  _iterator = _createForOfIteratorHelper(result.observations);
 
                   try {
                     for (_iterator.s(); !(_step = _iterator.n()).done;) {
                       observation = _step.value;
-                      monthDju += observation.measurement;
+                      monthDju += observation.result.value;
                     }
                   } catch (err) {
                     _iterator.e(err);
@@ -8906,7 +8913,7 @@ exports.default = _default;
 /***/ "9pOX":
 /***/ (function(module) {
 
-module.exports = JSON.parse("{\"common\":{\"title_app\":\"Ecolyo\",\"title_consumption\":\"Conso\",\"title_challenge\":\"Défis\",\"title_quiz\":\"Quiz\",\"title_exploration\":\"Exploration\",\"title_action\":\"Action\",\"title_duel\":\"Duel final\",\"title_ecogesture\":\"Astuce\",\"title_ecogestures\":\"Astuces\",\"title_ecogestures_choice\":\"Sélection des astuces\",\"title_options\":\"Options\",\"title_analysis\":\"Analyse\",\"title_profiletype\":\"Ajuster mon profil\",\"title_legal_notice\":\"Mentions légales\",\"title_gcu\":\"Conditions générales d’utilisation\",\"title_accessibility\":\"Accessibilité : non conforme\",\"title_sge_connect\":\"Connexion à l'électricité\",\"accessibility\":{\"loading\":\"Chargement\"}},\"navigation\":{\"consumption\":\"Conso\",\"challenges\":\"Défis\",\"ecogestures\":\"Astuces\",\"options\":\"Options\",\"analysis\":\"Analyse\"},\"FLUID\":{\"ELECTRICITY\":{\"NAME\":\"Électricité\",\"LABEL\":\"Électricité\",\"UNIT\":\"kWh\",\"ADD\":\"Ajouter l'électricité\",\"MEGAUNIT\":\"MWh\",\"provider\":\"Enedis\"},\"WATER\":{\"NAME\":\"Eau\",\"LABEL\":\"Eau\",\"ADD\":\"Ajouter l'eau\",\"UNIT\":\"L\",\"MEGAUNIT\":\"m³\",\"provider\":\"Eau Publique du Grand Lyon\"},\"GAS\":{\"NAME\":\"Gaz\",\"LABEL\":\"Gaz\",\"ADD\":\"Ajouter le gaz\",\"UNIT\":\"kWh\",\"MEGAUNIT\":\"MWh\",\"provider\":\"GRDF\"},\"MULTIFLUID\":{\"NAME\":\"Multi fluide\",\"LABEL\":\"Multi\",\"UNIT\":\"€\"}},\"action\":{\"duration\":\"Durée : %{smart_count} jours\",\"result\":\"Résultat\",\"finished\":\"Défi terminé !\",\"details\":\"Détail de l'astuce\",\"apply\":\"J'applique cette action\",\"other\":\"Je choisis une autre action\",\"resultText1\":\"Cela n'a pas été trop difficile ?\",\"resultText2\":\"Jetez un coup d'œil dans la page conso dans 1 à 3 jours, le temps que vos données arrivent, pour voir l'impact de votre action.\",\"resultText3\":\"Pas de baisse de significative ? Pas de panique, en maintenant cette pratique dans le temps, les économies d'énergies et d'eau seront davantage visibles.\",\"resultText4\":\"Dans tous les cas, bravo, vous remportez...\",\"ok\":\"Ok\"},\"action_modal\":{\"accept\":\"Je relève le défi\",\"refuse\":\"Je me défile\",\"accessibility\":{\"window_title\":\"Fenêtre de confirmation\",\"button_accept\":\"Accepter\",\"button_refuse\":\"Refuser\"}},\"analysis\":{\"viewTitle\":\"Analyse\",\"comparison\":\"Comparatif\",\"analysis_date\":\"Conso totale\",\"challenge\":\"Défis terminés en\",\"user_consumption\":\"Votre conso\",\"average_home\":\"Conso moyenne d'un profil similaire\",\"average_home_description\":\"Le comparatif ici présenté est calculé sur la base d'un profil similaire au vôtre. Il s'agit d'un calcul et non d'une comparaison avec les autres utilisateurs de l'application. Sont pris en compte l'ensemble des informations entrées dans votre profil : mode de chauffage, âge du logement et éventuels travaux de rénovation, etc. Ce modèle a été créé avec l'Agence Locale de l'Energie sur la base de chiffres issues du Schéma Directeur des Energies de la Métropole de Lyon et de Chiffres-clé publiés par l'ADEME (l'Agence de l'Environnement et de la Maîtrise de l'Energie).\",\"approximative_description\":\"Pour comparer votre consommation avec un foyer similaire ou avec une conso idéale, veuillez détailler votre profil\",\"not_connected\":\"Non connecté\",\"no_data_2\":\"Données non disponibles\",\"accessibility\":{\"button_go_to_profil\":\"Détailler mon profil\"},\"max_day\":\"Jour où vous avez le plus consommé\",\"compare\":{\"title\":\"Comparateur\",\"month_tab\":\"Comparer au mois dernier\",\"year_tab\":\"Comparer à l'année dernière\"},\"no_data\":\"Pas de données\"},\"analysis_error_modal\":{\"title\":\"Aucune analyse\",\"message\":\"Pour profiter d’une analyse de vos consommations, connectez au moins un de vos compteurs.\",\"go_to_options\":\"Je connecte mes compteurs\",\"go_back\":\"Retour\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_go_back\":\"Retour\",\"button_goto_konnector\":\"Aller aux connecteurs\"}},\"analysis_pie\":{\"total\":\"Conso totale\",\"month\":\"Au mois \",\"estimation\":\"Comment sont estimés\",\"estimation2\":\"les prix ?\"},\"special_elec\":{\"title\":\"Spécial Électricité\",\"average\":\"Conso moyenne\",\"weektype\":\"un jour de \",\"week\":\"semaine\",\"weekend\":\"week-end\",\"min\":\"Conso minimum\",\"percentage\":\"Part dans la facture\",\"price\":\"Soit\",\"maxPower\":\"Puissance maximum atteinte\",\"showModal\":\"Plus d'infos\"},\"elec_info_modal\":{\"accessibility\":{\"window_title\":\"electricity-info-modal\",\"button_close\":\"close-modal\"},\"title1\":\"Qu’est-ce que la consommation minimum ?\",\"title2\":\"Qu’est-ce que la puissance maximum ?\",\"text1\":\"Elle correspond à votre plus petite consommation du mois sur un créneau d'une demi-heure.\",\"text2\":\"Nous extrapolons cette consommation sur 1 mois afin vous donner un aperçu de la consommation de vos consommations électriques en veille (box, télé, chargeurs, ...) ou encore de celle, incompressible, de vos appareils de froid (frigo, congélateur).\",\"text3\":\"C’est la puissance maximum délivrée par tous les appareils fonctionnant au même moment dans votre logement.\",\"text4\":\"Vous avez choisi une puissance maximum dans votre offre d’électricité (3, 6 ou 9 kVA...) que vous ne devez pas dépasser pour ne pas faire sauter votre compteur. \",\"text5\":\"Cette puissance varie d'un mois à l'autre, regardez cette valeur sur l'ensemble de l'année pour vérifier si votre puissance souscrite correspond bien à votre usage.\"},\"auth\":{\"enedissgegrandlyon\":{\"title\":\"Ecolyo doit se connecter à l’électricité\",\"bill\":\"Munissez-vous d’une <span>facture d’électricité</span> pour valider la connexion\",\"connect\":\"Je me connecte à l'électricité\",\"accessibility\":{\"connect\":\"Se connecter\"},\"identityTitle\":\"Nom inscrit sur la facture\",\"firstName\":\"Prénom\",\"lastName\":\"Nom\",\"pdlTitle\":\"Numéro de votre compteur électrique (PDL)\",\"pdlLabel\":\"N° (14 chiffres)\",\"pdlHint\":\"Où trouver le n° de PDL ?\",\"pdlModal\":{\"txt1\":\"Où trouver le n° de PDL ou PRM ?\",\"txt2\":\"Le numéro de PDL ou PRM se compose de 14 chiffres.\",\"txt3\":\"Votre numéro de PDL ou PRM se trouve sur votre facture d’électricité.\",\"txt4\":\"Si vous avez un compteur Linky, appuyez sur le bouton “+” et faites défiler l’affichage jusqu’à obtenir l’affichage suivant :\"},\"addressTitle\":\"Adresse du titulaire\",\"address\":\"Numéro et voie\",\"zipCode\":\"Code postal\",\"city\":\"Ville\",\"headConsent\":\"Vous allez partager vos données à la Métropole de Lyon. Elles seront directement transférées à Ecolyo à l'intérieur de votre cloud personnel, sans que la Métropole n'y accède ni ne les visualise.\",\"textConsent\":\"Afin  de vous offrir des fonctionnalités de visualisation et d'analyse, Ecolyo a besoin des données suivantes : \",\"consentLi1\":\"L'historique et le relevé de vos consommations quotidiennes en kWh\",\"consentLi2\":\"L'historique et le relevé de vos consommations au pas de temps 30 minutes\",\"consentLi3\":\"Les puissances maximales atteintes quotidiennement\",\"consentLi4\":\"Les données contractuelles (début de contrat et puissance souscrite)\",\"consentCheck1\":\"Je consens à partager les données personnelles ci-dessus pour une durée d'<span>un an</span>\",\"consentCheck2\":\"J’atteste être le titulaire du point de livraison (PDL) renseigné à l’étape précédente\",\"modalHint\":{\"accessibility\":\"Titre de la modale\",\"title\":\"Où trouver le n° de PDL ?\",\"button\":\"J'ai compris\",\"button-accessibility\":\"Bouton valider\"}},\"grdfgrandlyon\":{\"bill\":\"Munissez-vous d’une <span>facture de gaz</span> pour valider la connexion\",\"connect\":\"Je me connecte au gaz\",\"accessibility\":{\"connect\":\"Se connecter\"},\"connect_form\":{\"label\":\"Je donne mon accord via mon compte GRDF\"},\"no_account\":{\"title\":\"Ecolyo doit se connecter au gaz\"},\"with_account\":{\"title\":\"Votre compte GRDF a bien été créé ?\",\"subtitle1\":\"Plus qu’à donner votre accord pour connecter votre compteur de gaz et Ecolyo !\"},\"step1\":{\"info1\":\"Un <span>compte chez GRDF</span> est nécessaire pour vous connecter au gaz\",\"info2\":\" <span>quelque soit votre fournisseur de gaz</span>.\",\"info3\":\"<p>GRDF est le gestionnaire de réseau. C'est lui qui est responsable de votre compteur Gazpar et de la collecte des données de consommation.</p>\",\"info4\":\"Possédez-vous un <span>compte GRDF</span> ?\"},\"step2\":{\"info1\":\"Une fois votre compte créé, <span>n'oubliez pas de revenir sur Ecolyo</span> pour finaliser la connexion.\"},\"step3\":{\"info1\":\"La visualisation de vos données sur Ecolyo demande l'activation du <span>partage de toutes les données.</span>\",\"info2\":\"Pour une expérience optimale, <span>une période de consentement de 1 an</span> est recommandée à partir d’aujourd’hui.\",\"info3\":\"<p>Veillez également à indiquer une date antérieure pour l'historique (1er calendrier) afin de pouvoir récupérer jusqu'à 3 ans d'historique.</p>\"},\"button_go_to_partner_site\":\"Aller sur GRDF\"},\"eglgrandlyon\":{\"bill\":\"Munissez-vous d’une <span>facture d'eau</span> pour valider la connexion\",\"connect\":\"Je me connecte à l'eau\",\"accessibility\":{\"connect\":\"Se connecter\"},\"connect_form\":{\"login\":\"Identifiant (7 chiffres)\",\"password\":\"Mot de passe\",\"label\":\"Je connecte Ecolyo à mon compte Eau Publique du Grand Lyon\"},\"no_account\":{\"title\":\"Ecolyo doit se connecter à l'eau\"},\"with_account\":{\"title\":\"Votre compte Eau Publique du Grand Lyon a bien été créé ?\",\"subtitle1\":\"Plus qu’à donner votre accord pour connecter votre compteur d'eau et Ecolyo !\"},\"step1\":{\"info1\":\"La connexion se fait via <span>votre compte Eau Publique du Grand Lyon</span>.\",\"info2\":\"Possédez-vous un <span>compte Eau Publique du Grand Lyon</span> ?\"},\"step2\":{\"info1\":\"Une fois votre compte créé, <span>n'oubliez pas de revenir sur Ecolyo</span> pour finaliser la connexion.\"},\"button_go_to_partner_site\":\"Aller sur EPGL\"},\"connect_oauth\":{\"loading\":\"Chargement...\"},\"accessibility\":{\"button_reveal_password\":\"Afficher le mot de passe\",\"button_connect\":\"Se connecter\",\"button_create_account\":\"Se créer un compte\",\"window_title\":\"Fenêtre d'information sur la création de compte.\",\"button_close\":\"Fermer la fenêtre.\"},\"button_previous\":\"Précédent\",\"button_connect\":\"Se connecter\",\"button_create_account\":\"Se créer un compte\",\"button_has_account\":\"J'ai déjà un compte\",\"button_validate\":\"J'ai compris\",\"button_showOfflineData\":\"Voir mes anciennes données\",\"warningOfflineData\":\"Attention, vous visualisez d’anciennes données. Pour actualiser vos données, connectez votre compteur\"},\"challenge\":{\"card\":{\"ongoing\":{\"quiz\":\"Quiz\",\"exploration\":\"Explorations\",\"action\":\"Actions\",\"duel\":\"Duel Final\",\"result\":\"Résultat\",\"duelDone\":\"du duel final\"},\"locked\":{\"desc\":\"À débloquer en terminant le défi précédent\"}},\"card_done\":{\"saving\":\"Économie de\",\"depense\":\"Dépense de\",\"win\":\"Gagné\",\"lost\":\"Perdu\",\"final_defi\":\"sur le duel final\",\"final_defi_view\":\"Revoir le duel final\"},\"card_last\":{\"title\":\"Tous les défis sont terminés\",\"message1\":\"Nous travaillons actuellement à vous proposer de nouveaux défis.\",\"button\":\"Suggérer une idée de défi\"},\"card_unlocked\":{\"button_launch\":\"Lancer le défi\"},\"accessibility\":{\"button_launch\":\"Lancer le défi\",\"button_goto_konnector\":\"Aller aux connecteurs\",\"button_slider_previous\":\"Précédent\",\"button_slider_next\":\"Suivant\"}},\"challenge_no_fluid_modal\":{\"title\":\"Oups !\",\"content\":\"Connectez au moins 1 fluide pour pouvoir jouer\",\"button_validate\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_validate\":\"Valider\"}},\"consumption\":{\"display_last_data\":\"Voir mes dernières consos\",\"accessibility\":{\"button_previous_period\":\"Afficher la période précédente\",\"button_next_period\":\"Afficher la période suivante\",\"button_previous_value\":\"Sélectionner la valeur précédente\",\"button_next_value\":\"Sélectionner la valeur suivante\",\"checkbox_compare\":\"Afficher ou cacher la comparaison\"},\"partner_issue_modal\":{\"title\":\"Attention !\",\"error_connect_gaz\":\"La connexion à vos données de <span class='gaz'>gaz</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='gaz'>GRDF</span> ou dans notre service)\",\"error_connect_elec\":\"La connexion à vos données d'<span class='elec'>électricité</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='elec'>Enedis</span> ou dans notre service)\",\"error_connect_water\":\"La connexion à vos données d'<span class='water'>eau</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='water'>Eau Publique du Grand Lyon</span> ou dans notre service)\",\"additional_text\":\"La visualisation et/ou la connexion à vos données de consommation peut s'en trouver affectée.<br /><br /><i>Merci pour votre patience en attendant un retour à la normale :)</i>\",\"ok\":\"Ok\"},\"compared\":\"Comparé\"},\"consumption_details\":{\"detail\":\"Détail par fluide\",\"connect\":\"Connecter d'autres fluides\",\"mini_cards_label\":\"AUTRES ENERGIES\"},\"consumption_visualizer\":{\"missing_data\":\"Données manquantes\",\"no_data\":\"Pas de données\",\"why_no_data\":\"Pourquoi n'ai-je pas de données ?\",\"last_data\":\"Dernières données\",\"last_valid_data\":\"Dernières données valides\",\"last_available_data\":\"Dernières données disponibles\",\"last_valid_data_multi\":\"Dernières données complètes\",\"data_to_come\":\"à venir\",\"aie\":\"Aïe !\",\"data_empty\":\"Vide\",\"estimated\":\"estimés\",\"dataModal\":{\"list_title\":\"3 raisons possibles :\",\"item1\":\"le lien entre Ecolyo et le fournisseur de données est rompu : une mise à jour de ce lien (en bas de la page) peut résoudre ce problème.\",\"item2\":\"un problème technique chez votre gestionnaire : se connecter directement chez ce gestionnaire pour vérifier que cette donnée apparaît.\",\"item3\":\"pour le gaz : vous n'avez pas autorisé Ecolyo à accéder aux données de consommation de cette période.\",\"item4\":\"vous n'aviez tout simplement pas de compteur communicant à l'époque !\"},\"modal\":{\"window_title\":\"info estimation des prix\",\"title\":\"Comment sont estimés les prix ?\",\"close\":\"Fermer la fenêtre\",\"part1\":\"Le prix de votre électricité ou de votre gaz dépend de l'offre choisie auprès de votre fournisseur. N’ayant pas accès à cette information, Ecolyo affiche un prix moyen par fluide. \",\"part2\":\"Tarifs moyens retenus :\",\"list1\":\" : 1 kWh = %{elecPrice} €TTC (il correspond au tarif réglementé d’EDF au %{elecPriceStartDate} pour une puissance souscrite de 3 ou 6 kVA et hors offre heure pleine/heure creuse)\",\"list2\":\" : 1 kWh = %{gasPrice} €TTC (tarif réglementé de vente au %{gasPriceStartDate} pour un consommateur soutirant moins de 6 MWh par an)\",\"list3\":\" : 1 litre d’eau = %{waterPrice} € TTC (prix constaté au %{waterPriceStartDate} pour un abonnement et une consommation de 120 m3/an sur la Métropole de Lyon)\",\"part3\":\"Le coût de votre abonnement n'est pas pris en compte dans Ecolyo.\"},\"release_notes_modal\":{\"title\":\"Du nouveau sur Ecolyo !\",\"message\":\"Les mises à jour suivantes ont été effectuées sur votre application :\",\"go_back\":\"J'ai compris\",\"accessibility\":{\"window_title\":\"Fenêtre de notifications\",\"button_go_back\":\"J'ai compris\"}}},\"ecogestures\":{\"loading\":\"Chargement des astuces\"},\"duel\":{\"global_error\":\"Oups. Une erreur est survenue. Veuillez retourner à l'écran d’accueil des défis\",\"button_go_back\":\"Retour\",\"average_info\":\"%{average} euros étant votre moyenne actuelle, relevez-vous le défi ?\",\"button_start\":\"Allons-y !\",\"goal1\":\"Faites moins que votre moyenne actuelle sur %{durationInDays} jours\",\"goal2\":\"pour gagner le badge %{title}\",\"goal_done\":\"Duel remporté\",\"goal_failed\":\"Duel perdu\",\"caption_average\":\"Votre moyenne à titre indicatif\",\"caption_consumption\":\"Votre consommation\",\"caption_incoming\":\"Données à venir\",\"accessibility\":{\"button_go_back\":\"Retour\",\"button_start_duel\":\"Lancer le duel\",\"button_start_quiz\":\"Lancer le quiz\"}},\"duel_result_modal\":{\"sucess\":{\"title\":\"Félicitations !\",\"message1\":\"Vous avez économisé \",\"message2\":\"et gagné le badge \",\"button_validate\":\"Youpi !\"},\"lost\":{\"title\":\"Presque !\",\"message1\":\"Vous avez dépassé de \",\"message2\":\"et manqué le badge \",\"button_validate\":\"Zut alors !\"},\"accessibility\":{\"window_title\":\"Fenêtre de résultat\",\"button_validate\":\"Valider\"}},\"last_duel_modal\":{\"title\":\"Félicitations !\",\"subtitle\":\"Vous avez terminé tous les défis !\",\"message1\":\"Nous travaillons actuellement à vous proposer de nouveaux défis.\",\"message2\":\"Vous pouvez donner votre avis sur ce que vous aimeriez en cliquant sur la bulle d'aide.\"},\"duel_empty_value_modal\":{\"title\":\"Oups !\",\"message\":\"Impossible de lancer le duel. Il nous manque en effet certaines de vos données de consommation pour vous proposer un duel à votre hauteur.\",\"button\":\"Je retourne au menu des défis\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_validate\":\"Retourner au menu des défis\"}},\"ecogesture\":{\"title_tab_0\":\"Objectifs\",\"title_tab_1\":\"Je fais déjà\",\"title_tab_2\":\"Toutes\",\"MENU_TITLE\":\"Filtrer\",\"ALL\":\"Tous les usages\",\"HEATING\":\"Chauffage\",\"AIR_CONDITIONING\":\"Climatisation\",\"ECS\":\"Eau chaude\",\"COLD_WATER\":\"Eau froide\",\"ELECTRICITY_SPECIFIC\":\"Électricité courante\",\"COOKING\":\"Cuisson\",\"selection\":\"Sélectionner les astuces les plus adaptées à votre consommation\",\"selection_2\":\"vues sur\",\"button_selection\":\"Continuer ma sélection\",\"no_ecogesture\":\"Aucune astuce ne correspond à votre filtrage\",\"no_ecogesture_filter\":{\"text1\":\"Nous n'avons pas trouvé d'astuces adaptées à votre profil dans cette catégorie.\",\"text2\":\"En effet, de par votre profil et vos modes de chauffage, d'eau ou d'eau chaude sanitaire, nous n'avons pas identifié d’astuces vous permettant de diminuer vos factures à titre individuel. Toutefois, vous pouvez toujours agir pour préserver les ressources en appliquant et diffusant autour de vous les autres bonnes pratiques présentées dans la partie \\\"Toutes les astuces\\\".\"},\"adjust_profil\":{\"description\":\"Pour une sélection d’astuces adaptée à votre consommation, vous pouvez ajuster votre profil.\",\"button_go_to_profil\":\"Ajuster mon profil\"},\"accessibility\":{\"window_title\":\"Fenêtre d'information'\",\"button_close\":\"Fermer la fenêtre\",\"button_selection\":\"Aller à la page de sélection\"},\"doing\":\"Je fais déjà\",\"objective\":\"Objectif\",\"emptyList\":{\"obj1\":\"Les astuces présentées sont des actions qui vous permettent de réduire vos consommations et donc vos factures. On parle parfois d’écogestes.\",\"obj1_done\":\"Aucune astuce n’a été sélectionnée comme objectif actuellement.\",\"obj2\":\"Vous pouvez sélectionner ceux à mettre en objectifs et ceux que vous appliquez déjà.\",\"obj2_done\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous souhaitez garder en objectif dans cette section.\",\"doing1\":\"Aucune astuce n’a été sélectionnée dans la catégorie appliquée actuellement.\",\"doing1_done\":\"Aucune astuce n’est indiquée comme déjà appliquée actuellement.\",\"doing2\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous mettez déjà en pratique dans cette section.\",\"doing2_done\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous mettez déjà en pratique dans cette section.\",\"btn1\":\"Voir toutes les astuces\",\"btn2\":\"Sélectionner\"},\"initModal\":{\"title\":\"Sélectionner mes astuces\",\"text1\":\"Les astuces présentées sont des actions qui vous permettent de réduire vos consommations et donc vos factures. On parle parfois d’écogestes \",\"text2\":\"Vous pouvez sélectionner celles à mettre en objectifs et celles que vous appliquez déjà.\",\"text3\":\"Afin de pré-sélectionner les astuces correspondant à votre consommation, merci de répondre à quelques rapides questions.\",\"btn1\":\"Plus tard\",\"btn2\":\"C'est parti !\"},\"reinit\":\"Réinitialiser ma sélection\",\"reinitModal\":{\"title_part1\":\"Cette action\",\"title_part2\":\"supprimera votre liste d’astuces\",\"title_part3\":\"sélectionnées dans\",\"title_part4\":\"“Objectifs”\",\"title_part5\":\"et\",\"title_part6\":\"“Je fais déjà”\",\"text1\":\"Vous pourrez ensuite faire une nouvelle sélection adaptée à votre consommation.\",\"text2\":\"Souhaitez-vous réinitialiser votre sélection d’astuces ?\",\"btn1\":\"Non\",\"btn2\":\"Réinitialiser\"}},\"ecogesture_modal\":{\"title_ecogesture\":\"Astuce\",\"title_action\":\"Action\",\"efficiency\":\"Efficacité\",\"show_less\":\"Voir moins d’infos\",\"show_more\":\"Voir plus d’infos\",\"select_action\":\"Je choisis cette action\",\"accessibility\":{\"window_title_ecogesture\":\"Fenêtre astuce\",\"window_title_action\":\"Fenêtre action\",\"button_close\":\"Fermer la fenêtre\",\"button_select_action\":\"Sélectionner cette action\",\"button_see_more_detail\":\"Afficher plus de détails\"}},\"ecogesture_info_modal\":{\"header\":\"Comment sont choisis les astuces adaptées à mon profil ?\",\"text\":\"Les astuces adaptés à votre profil sont aujourd’hui choisies en fonction des compteurs individuels que vous possédez (communicants ou non). Ceux présentés ici vous permettent d'agir sur vos consommations individuelles. Des modes de tri plus personnalisables seront proposés à l'avenir.\",\"button_close\":\"J'ai compris\",\"accessibility\":{\"window_title\":\"Fenêtre d'information\",\"button_close\":\"Fermer la fenêtre\"}},\"ecogesture_form\":{\"heating_type\":{\"title\":\"Chauffage\",\"question\":\"Quel est votre type de chauffage ?\",\"individual\":\"Individuel\",\"collective\":\"Collectif\"},\"warming_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Bois\",\"4\":\"Fioul\",\"title\":\"Source chauffage\",\"question\":\"Quelle source d’énergie principale utilisez-vous pour votre chauffage ?\"},\"hot_water_type\":{\"title\":\"Eau chaude\",\"question\":\"Quel est votre type de production d’eau chaude ?\",\"individual\":\"Individuelle\",\"collective\":\"Collective\"}},\"ecogesture_profile\":{\"equipments\":{\"question\":\"Quels équipements possédez-vous ?\",\"hint\":\"Plusieurs réponses possibles\",\"air_conditioning\":\"Climatisation\",\"computer\":\"Ordinateur\",\"microwave\":\"Micro-ondes\",\"oven\":\"Four\",\"washing_machine\":\"Lave-linge\",\"dishwasher\":\"Lave-vaisselle\",\"cooking_plates\":\"Plaques électriques\",\"garden\":\"Jardin\",\"dryer\":\"Sèche-linge\",\"refregirator\":\"Réfrigérateur\",\"fan\":\"Ventilateur\",\"water_heater\":\"Chauffe-eau\",\"curtain\":\"Rideaux\",\"internet_box\":\"Box internet\",\"ventilation\":\"VMC\",\"freezer\":\"Congélateur\",\"boiler\":\"Chaudière\",\"hydraulic_heating\":\"Chauffage hydraulique\"}},\"ecogesture_selection\":{\"header\":\"Sélection des astuces\",\"title\":\"Vous avez parcouru un groupe de %{smart_count} astuces\",\"text\":\"Voulez-vous continuer sur votre lancée ou remettre cette sélection à plus tard ?\",\"title_final\":\"Félicitations !\",\"text_final_1\":\"Vous avez terminé la sélection des astuces adaptées à votre consommation.\",\"text_final_2\":\"Vous pouvez les retrouver dans les sections “Objectifs” et “Je fais déjà” selon que vous les pratiquiez déjà ou non.\",\"button_go_to_ecogesture\":\"Plus tard\",\"button_ok\":\"J'ai compris\",\"button_continue\":\"Poursuivre\",\"button_objective\":\"Objectif\",\"button_doing\":\"Je fais déjà\",\"button_skip\":\"Pas intéressé\",\"accessibility\":{\"window_title\":\"Fenêtre d'information'\",\"button_close\":\"Fermer la fenêtre\",\"button_go_to_ecogesture\":\"Retourner aux astuces\",\"button_continue\":\"Poursuivre\",\"button_ok\":\"Fermer la sélection\"},\"selectionModal\":{\"title\":\"Des astuces correspondant à votre profil ont été trouvées !\",\"text\":\"À vous de choisir celles que vous souhaitez mettre en objectif et celles que vous faites déjà.\",\"button_close\":\"C'est parti !\"}},\"exploration\":{\"global_error\":\"Oups. Une erreur est survenue. Veuillez retourner à l'écran d’accueil des défis\",\"button_go_back\":\"Retour\",\"button_already_done\":\"C’est déjà fait !\",\"button_come_back\":\"Je reviens quand cela sera fait\",\"button_start\":\"C'est parti !\",\"watch_consumption\":\"Je fonce\",\"congratulation\":\"Bravo !\",\"earn\":\"Vous remportez\",\"button_confirm\":\"Ok\",\"interval\":{\"explanation\":\"Vous pouvez vérifier cette informations sur l'écran Conso.\"},\"accessibility\":{\"button_already_done\":\"Marquer l'exploration comme déjà réalisée\",\"button_confirm\":\"Valider\",\"button_come_back\":\"Fermer l'exploration\",\"button_go_back\":\"Retour\",\"button_start\":\"Lancer l'exploration\"}},\"error_page\":{\"main\":\"Erreur\",\"back\":\"Retour\",\"no_ecogesture\":\"Oups ! Nous n'avons pas trouvé l'astuce demandée.\"},\"help\":{\"title_help\":\"une question ? un problème ? une suggestion ?\",\"read_help\":\"Nous écrire via le Service d'Assistance Utilisateur\"},\"feedback\":{\"title\":\"Vous allez contacter le Service Assistance Utilisateur du Grand Lyon.\",\"text1\":\"Vous pourrez nous remonter un problème, chercher de l'aide pour vous connecter plus facilement, ou encore nous partager une bonne idée d'évolution.\",\"text2\":\"N'hésitez pas à nous écrire ! L'équipe Ecolyo vous répondra avec plaisir :)\",\"later\":\"Plus tard\",\"lets_go\":\"J'y vais\",\"accessibility\":{\"window_title\":\"Fenêtre de partage de retours\",\"button_close\":\"Fermer la fenêtre de partage de retours\"}},\"dataShare\":{\"title1\":\"Bienvenue !\",\"title1Update\":\"Ecolyo évolue !\",\"title2Update\":\"Pour continuer à utiliser Ecolyo, merci d’accepter les modalités de traitement des données ci-dessous.\",\"part1\":\"Pour le bon fonctionnement du service, nous avons besoin de l’adresse email utilisée lors la création de votre cloud personnel Grand Lyon.\",\"part2\":\"Cette donnée de compte est conservée dans Ecolyo le temps de l’utilisation de ce service.\",\"part3\":\"La Métropole de Lyon utilisera cet email afin de vous tenir informé·e :\",\"item1\":\"En réponse à vos demandes, si vous avez pris l’initiative de nous contacter.\",\"item2\":\"En cas de problème majeur avec la gestion de votre compte.\",\"item3\":\"De l’évolution de vos consommations, des nouveautés et  de la qualité du service via une lettre mensuelle. Vous pouvez à tout moment vous désinscrire de cette lettre via la page Options du service.\",\"part4\":\"Vos données privées de consommation d’énergie et d’eau sont récupérées, sauvegardées et stockées dans votre cloud personnel à votre initiative sans visibilité de la Métropole  de Lyon sur leur contenu.\",\"part5\":\"Il en est de même pour les données privées de composition du logement et du foyer, fournies par vos soins. Elles restent également sans visibilité de la Métropole de Lyon sur leur contenu.\\nLes données d’identification entrées lors de la connexion aux données de consommations d’électricité sont quant à elles conservées dans un espace sécurisé de la Métropole de Lyon et sont utilisées uniquement à des fins de contrôle du consentement par des organismes extérieurs.\",\"part6\":\"Dans le cadre de l’évaluation et de l’amélioration du service, des données d’utilisation anonymisées et pseudonymisées seront remontées à des fins d’exploitation statistiques. La récupération de ces statistiques nous permettra de s’assurer du bon fonctionnement technique de la connexion à vos données de consommation, d’évaluer globalement l’usage de l’application via des mesures d’audience ainsi que d’évaluer à terme l’impact global en termes de baisse des consommations énergétiques de notre service.\",\"part7\":\"Au sein de votre cloud personnel, vous pouvez à tout moment exercer vos droits d’accès, de rectification, de portabilité, de limitation et d’opposition en consultant notamment la page Options.\",\"part8\":\"Vous pouvez également exercer vos droits d’accès, de rectification, de limitation, d’opposition et d’effacement de vos données personnelles en contactant directement le Délégué à la Protection des Données par courrier en écrivant à l’adresse :\",\"part9\":\"Métropole de Lyon – Délégué à la Protection des Données - Direction des Assemblées, des Affaires Juridiques et des Assurances - 20, rue du Lac - BP 33569 - 69505 Lyon Cedex 03 \",\"part10\":\"ou en ligne, au moyen du formulaire disponible à l'adresse suivante : \",\"link1\":\"<a href=\\\"https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/\\\">https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/</a>\",\"validDataConsent\":\"Je consens au traitement de mes données tel que décrit ci-dessus.\",\"validCGU\":\"Je valide les <span class=\\\"action\\\">Conditions Générales d’Utilisation</span> \",\"validLegal\":\" du service et ai pris connaissance des <span class=\\\"action\\\"> Mentions Légales </span> de celui-ci.\",\"button_accept\":\"C'est parti !\",\"accessibility\":{\"button_accept\":\"Accepter les conditions générales d'utilisation\"}},\"minorUpdate\":{\"title\":\"Ecolyo évolue !\",\"button\":\"J'ai compris\"},\"gcu\":{\"title\":\"Conditions générales d’utilisation du service\",\"version\":\"Version du 12.12.2022\",\"content\":{\"title1\":\"Ecolyo, késako ?\",\"part1_1\":\"Ecolyo est un service proposé par la Métropole de Lyon vous permettant de suivre au même endroit vos consommations d’électricité, de gaz et d’eau, en kWh, en litres, en euros et à différentes échelles de temps. Ce service vous permet également de participer à des défis individuels et vous offre une analyse de vos consommations. Des astuces vous sont aussi proposées afin de vous permettre de réduire vos consommations.\",\"part1_2\":\"C’est un service gratuit qui prend la forme d’un site web dit « responsive », c’est-à-dire qu’il peut être consulté sur ordinateur ou sur mobile. Sur mobile, c’est une application que l’on a souhaitée ergonomique, réactive et esthétique pour votre plaisir de navigation et d’utilisation au quotidien.\",\"part1_3\":\"Tous les termes « techniques » sont définis en bas de page.\",\"title2\":\"Quelles fonctionnalités le service propose-t-il ?\",\"part2_1\":\"La fonctionnalité principale d’Ecolyo est la visualisation, au même endroit, de vos consommations d’électricité, de gaz et d’eau et ce, à différents pas de temps (de la demi-heure – uniquement pour l’électricité, à plusieurs années, en passant par les pas de temps journaliers et mensuels). La visualisation des consommations se fait en kWh pour l’énergie et en L pour l’eau ainsi qu’en euros (euros résultant d’un prix moyenné).\",\"part2_2\":\"Au-delà de la visualisation de vos consommations et parce que nous souhaitons vous aider à diminuer ces consommations vous retrouverez plusieurs autres pages : \",\"part2_2_list1\":\"Défis : Des quiz, et actions à mettre en place vous seront proposés pour vous pousser à réduire vos consommations.\",\"part2_2_list2\":\"Astuces : Une liste d’astuces pour maîtriser ses consommations d’énergie et d’eau à trier par usage, et avec une possibilité de les adapter plus précisément à votre profil.\",\"part2_2_list3\":\"Analyse : Une analyse de vos consommations réelles en comparaison à celle d’un foyer étant proche d’une vôtre.\",\"part2_3\":\"Pour la page Analyse ainsi que pour la partie personnalisation des astuces, des éléments supplémentaires sur votre profil vous seront demandés. L’ensemble de ces informations récoltées à l’aide du formulaire peuvent être modifiées par la suite.\",\"part2_4\":\"Dernière page : la page Options dans laquelle vous pourrez vous abonner à un service d’alerte sur vos consommations d’eau, de quoi ajuster votre profil ou encore vous désabonner de la lettre mensuelle.\",\"title3\":\"Comment ai-je accès à mes données d’électricité, de gaz et d’eau ?\",\"part3_1\":\"Pour visualiser vos consommations réelles et profiter pleinement du potentiel de notre service, il vous faut au minimum un des trois compteurs communicants suivants : Linky (pour l’électricité), Gazpar (pour le gaz), Téléo (pour l’eau).\",\"part3_2\":\"Ces compteurs sont opérés par les gestionnaires de réseaux. Pour Linky, c’est Enedis, le gestionnaire de réseau de distribution d’électricité. Pour Gazpar, GRDF est responsable de cette gestion. Et pour Téléo, c’est Eau Publique du Grand Lyon.\",\"part3_3\":\"Ces acteurs sont responsables de la relève de vos données. Ces données servent notamment à votre fournisseur d’électricité, de gaz ou d’eau pour permettre la facturation de vos consommations d’énergie. Des fournisseurs d’électricité ou de gaz il y en a des dizaines. Les gestionnaires de réseaux (… et de votre compteur) ne sont qu’au nombre de trois. Nous avons donc décidé de travailler avec eux, au plus près de la donnée brute issue de vos compteurs.\",\"part3_4\":\"Il vous faudra donc avoir un compte chez GRDF et Eau Publique du Grand Lyon pour accéder à vos données. Si vous n’en avez pas, il suffira de vous en créer un. Ceci ne sera à faire qu’une fois, au début.\",\"title4\":\"Ecolyo se trouve dans un cloud personnel Grand Lyon, qu’est-ce que cela signifie ?\",\"part4_1\":\"Comme vous avez dû le remarquer, lors de votre première connexion à Ecolyo vous avez dû vous créer un compte Cloud Personnel Grand Lyon. Ce cloud personnel est un espace sécurisé porté par l’ambition de vous apporter visibilité, transparence et maîtrise sur l’usage de vos données personnelles, et dont les fonctionnalités vous permettant de récupérer, synchroniser, stocker et partager vos données avec les destinataires de votre choix.  Le service Ecolyo se déploie  à l’intérieur de cet espace protégé. Dans ce cloud personnel, vous pourrez accéder également à d’autres services. Toutes les données traitées par Ecolyo, mais aussi les autres services que vous seriez amenés à utiliser dans ce cloud personnel restent dans ce Cloud Personnel Grand Lyon et n’en sortent pas, sauf si vous décidez vous-même de partager vos données avec des tiers.\",\"part4_2\":\"Pour en savoir plus sur ce cloud et son utilisation, ainsi que la durée de conservation de vos données, vous pouvez lire les conditions générales d’utilisation du service <a href=\\\"https://manager.cozygrandlyon.cloud/tos/266b4226-8417-42fb-b911-41e86dae8581.pdf?locale=fr\\\">ici</a>.\",\"title5\":\"Et donc concrètement pour Ecolyo, quelles données sont collectées et qui y a accès ?\",\"part5_1\":\"Pour qu’Ecolyo ait accès à vos données de consommations, vous devrez activer vos différents connecteurs. À ce moment-là, pour la connexion aux données de gaz et d’eau à travers un parcours qui vous conduira de manière intuitive sur le site de chacun des gestionnaires de réseaux concerné, vous pourrez donner votre consentement à partager ces données avec le Service Ecolyo, et ce pour une durée limitée dans le temps. Pour l’électricité, le don du consentement et la connexion aux données se fait directement dans notre service. Quid de la durée de ce consentement ? Pour les données électriques, elle est par défaut d'un an. Pour les données gaz, cela sera à vous de la définir (nous vous recommandons 1 an pour une expérience optimale). Les données utilisées pour vérifier la bonne connexion de vos données d’électricité sont stockées du côté de la Métropole de Lyon sur des serveurs sécurisés.\",\"part5_2\":\"Vos connecteurs, une fois configurés, permettent le transfert de vos données de consommations au service Ecolyo. Le transfert de ces données de consommation se fait sans que personne n’accède à leur contenu, pas même la Métropole de Lyon. En effet, ces données sont stockées et traitées directement dans votre cloud personnel qui en assure la protection. Tous les calculs, analyses et traitements sur ces données sont faites DANS votre espace personnel sans visibilité sur le contenu des données par la Métropole de Lyon.\",\"part5_3\":\"Vous pouvez bien sûr mettre fin à la récupération/ au transfert de vos données de consommation sur votre espace cloud personnel à tout moment et  à plusieurs niveaux : \",\"part5_3_list1\":\"Vous pouvez supprimer le transfert quotidien de vos données en supprimant tout simplement le connecteur dans la page Consos (en bas).\",\"part5_3_list2\":\"Pour supprimer l’ensemble de vos données ainsi que votre espace personnel Grand Lyon, vous devez demander la suppression de votre cloud. Pour faire cela, rendez-vous dans les paramètres de votre cloud personnel via la barre blanche en haut d’Ecolyo et appuyez sur le bouton « Supprimer mon compte » dans la partie paramètres.\",\"part5_4\":\"Des données sur le profil de votre foyer peuvent être également remplies au sein de l’application. Ces données s’enrichiront au fur et à mesure de votre utilisation du service avec d’autres informations : défis réalisés, étoiles gagnées, etc. L’ensemble de ces données restent à l’intérieur de votre cloud personnel, sans que personne n’y ait accès.\",\"part5_5\":\"Enfin, afin de permettre une mise à jour quotidienne de vos données de consommations, vos identifiants Eau Publique du Grand Lyon, un jeton d’identification GRDF ainsi que vos numéros de compteurs sont stockés.\",\"title6\":\"Personne n’a donc accès à mes données, pas même la Métropole de Lyon, vraiment ?\",\"part6_1\":\"Conformément aux indications du paragraphe précédent, la Métropole de Lyon n’accède ni à vos données de consommations ni aux données utilisées via certaines fonctionnalités du service comme le formulaire (celui-là même qui permet l’analyse de vos consommations personnalisée ainsi qu’une sélection d’éco-gestes personnalisés). Toutes ces informations sont bien gardées au chaud dans votre cloud personnel Grand Lyon.\",\"part6_2\":\"Seul vous pouvez accepter de partager vos données, documents ou fichiers privés avec la Métropole de Lyon, ses partenaires ou d’autres utilisateurs ou acteurs (publics ou privés) après recueil de votre consentement éclairé et par une action expresse de votre part.\",\"part6_3\":\"La Métropole de Lyon n'a cependant accès qu’à l’adresse email utilisée lors la création de votre cloud personnel Grand Lyon. Elle utilise cet email afin de vous tenir informé·e :\",\"part6_3_list1\":\"En réponse à vos demandes, si vous avez pris l’initiative de nous contacter. \",\"part6_3_list2\":\"En cas de problème majeur avec la gestion de votre compte.\",\"part6_3_list3\":\"De l’évolution de vos consommations, des nouveautés et  de la qualité du service via une lettre mensuelle. Vous pouvez à tout moment vous désinscrire de cette lettre via la page Options du service.\",\"part6_4\":\"Elle stocke également les informations transmises lors de la connexion à l’électricité (nom, adresse postale). Ces informations doivent être stockées car la Métropole de Lyon est régulièrement contrôlée par Enedis et doit prouver détenir le consentement des personnes pour lesquelles elle va chercher la donnée.\",\"part6_5\":\"Par ailleurs, et dans le cadre de l’évaluation et de l’amélioration du service, des données d’utilisation anonymisées seront remontées à des fins d’exploitation statistiques. La récupération de ces statistiques anonymisées nous permettra de s’assurer du bon fonctionnement technique de la connexion à vos données de consommation ainsi que d’évaluer l’impact global en termes de baisse des consommations énergétiques de notre service. Parmi ces statistiques, des mesures d’audience de la fréquentation des différentes pages du service sont réalisées. Vous pouvez, via la page Options, à tout instant, décider de vous opposer à la récupération de ces données d’utilisation.\",\"title8\":\"Encore des questions ?\",\"part8_1\":\"N’hésitez pas à consulter la FAQ ou à nous contacter via le formulaire de contact présente sur l’ensemble des pages.\",\"part8_2\":\"Dernière option, contactez-nous directement à <a href=\\\"mailto:ecolyo@grandlyon.com\\\">ecolyo(at)grandlyon.com</a>.\",\"title9\":\"LEXIQUE\",\"part9_1_title\":\"Cloud personnel Grand Lyon : \",\"part9_1_content\":\"Cloud personnel : appelé aussi le « domicile numérique », le cloud personnel est souvent réduit à un simple espace de stockage de documents mais il est bien plus que ça. C'est un espace individuel et sécurisé où vous pouvez accéder à des services sans exposer aucune donnée à l’extérieur. Vous seul pouvez y accéder, personne d'autre.\",\"part9_2_title\":\"Connecteur : \",\"part9_2_content\":\"Un connecteur est un service, installé dans votre cloud personnel également, qui a pour but uniquement d’aller récupérer les données auprès de différents partenaires/sources de données. Dans le cadre d’Ecolyo, trois connecteurs sont pré-installés dans votre cloud personnel : celui d’Enedis, celui de GRDF et celui d’Eau Publique du Grand Lyon.\",\"part9_3_title\":\"Compteur communicant : \",\"part9_3_content\":\"Un compteur communicant est un compteur qui mesure de manière précise et détaillée vos consommations et peut transmettre ces données  au gestionnaire de réseau via une technologie radio (c'est le cas pour Gazpar et Téléo par exemple) ou via les réseaux électriques (via Courant Porteur en ligne, c'est le cas pour Linky par exemple).\",\"part9_4_title\":\"Fournisseur : \",\"part9_4_content\":\"Votre fournisseur d’électricité, de gaz ou d’eau est l’entreprise qui vous facture votre électricité, gaz ou eau. Côté électricité il en existe <a href=\\\"https://www.enedis.fr/liste-des-fournisseurs-delectricite\\\">aujourd’hui plus de 50</a>, chacun proposant des tarifs différents.\",\"part9_5_title\":\"Gestionnaire de réseau de distribution : \",\"part9_5_content\":\"Appelé aussi parfois distributeur, il est en charge de la livraison de votre électricité, gaz ou eau jusqu’à votre domicile. Il est aussi en charge du compteur qui relève vos consommations. Il transmet vos données de consommations à votre fournisseur afin qu’il effectue la facturation de vos consommations d’énergie. Il peut également les transmettre à tout acteur avec qui vous avez décidé de partager ces données.\"}},\"gcu_modal\":{\"button_accept\":\"J'accepte\",\"accessibility\":{\"window_title\":\"Conditions générales d’utilisation\",\"button_accept\":\"Accepter les conditions générales d'utilisation\"}},\"matomo\":{\"matomo_title\":\"Suivi statistiques d'usage Matomo\"},\"header\":{\"accessibility\":{\"button_back\":\"Retour à la page précédente\",\"button_open_feedbacks\":\"Ouvrir le partage de retours\"}},\"konnector_form\":{\"label_updated_at\":\"Dernière mise-à-jour le\",\"button_update\":\"Mettre à jour\",\"loading\":\"Chargement...\",\"wait_end_issue\":\"Attendre la fin de la maintenance avant de mettre à jour.\",\"button_delete\":\"Supprimer\",\"issue\":\"Le problème semble venir de \",\"resolve\":\"Une mise à jour peut résoudre ce problème.\",\"login_failed\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"not_installed\":\"Le connecteur n'est pas installé. Veuillez l'installer en cliquant sur le bouton ci-dessous.\",\"button_install\":\"Installer\",\"error_account_creation\":\"Une erreur est survenue, veuillez essayer de nouveau.\",\"error_no_login_password\":\"Identifiant et mot de passe requis\",\"error_login_failed\":\"Identifiants invalides\",\"error_update\":\"Un problème est survenu lors du rapatriement de vos données.\",\"error_update_oauth\":\"Votre autorisation pour afficher vos données %{fluid} a expiré.\",\"error_consent_form_gas\":\"Vos données ne peuvent être récupérées car vous n'avez pas coché l'autorisation d'accès aux données informatives lors de votre partage de consentement.\",\"button_oauth_reload\":\"Redonner mon consentement\",\"OK\":\"Ok\",\"konnector_delta\":{\"ELECTRICITY\":\"La donnée de consommation électrique arrive normalement à J+1. Un retard d'un ou deux jours est parfois constaté.\",\"GAS\":\"La donnée de consommation de gaz arrive normalement à J+3. Un retard d'un ou deux jours est parfois constaté.\",\"WATER\":\"La donnée de consommation d'eau arrive normalement à J+3. Un retard d'un ou deux jours est parfois constaté.\"},\"accessibility\":{\"button_install\":\"Installer le connecteur\",\"button_update\":\"Mettre à jour votre connexion\",\"button_delete\":\"Supprimer votre connexion\"}},\"konnector_options\":{\"label_connect_to_electricity\":\"Se connecter à l'électricité\",\"label_connect_to_water\":\"Se connecter à l'eau\",\"label_connect_to_gas\":\"Se connecter au gaz\",\"label_offline_electricity\":\"Électricité déconnectée\",\"label_offline_water\":\"Eau déconnectée\",\"label_offline_gas\":\"Gaz déconnecté\",\"partner_issue\":\"En maintenance\",\"outdated\":\"Données manquantes depuis %{isOutdatedData} jours\",\"accessibility\":{\"label_ko_status\":\"Connecteur en erreur\",\"button_toggle_detail_electricity\":\"Afficher ou masquer le détail de la connexion à l'électricité\",\"button_toggle_detail_water\":\"Afficher ou masquer le détail de la connexion à l'eau\",\"button_toggle_detail_gas\":\"Afficher ou masquer le détail de la connexion au gaz\"}},\"konnector_modal\":{\"loading_data\":\"Veuillez patienter, vos données sont en cours de chargement.\",\"loading_data_update\":\"Veuillez patienter, vos données sont en cours de mise à jour.\",\"logging_txt\":\"Nous vérifions vos informations d'identité\",\"success_txt\":\"Félicitations !\",\"success_data_electricity\":\"Vos données de consommation d'électricité sont maintenant connectées à Ecolyo.\",\"success_data_water\":\"Vos données de consommation d'eau sont maintenant connectées à Ecolyo.\",\"success_data_gas\":\"Vos données de consommation de gaz sont maintenant connectées à Ecolyo.\",\"success_data_additional_electricity\":\"Les données de consommations mettent entre un et deux jours pour arriver.\",\"success_data_additional_water\":\"Les données de consommations mettent entre trois et cinq jours pour arriver.\",\"success_data_additional_gas\":\"Les données de consommations mettent entre trois et cinq jours pour arriver.\",\"success_update_txt\":\"Connexion réussie !\",\"success_data_update_electricity\":\"Ecolyo est bien connecté à votre compteur d'électricité.\",\"success_data_update_water\":\"Ecolyo est bien connecté à votre compteur d'eau.\",\"success_data_update_gas\":\"Ecolyo est bien connecté à votre compteur de gaz.\",\"success_data_additional_update_electricity\":\"Sachez que la donnée de consommation d'électricité arrive entre J+1 et J+2.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"success_data_additional_update_water\":\"Sachez que la donnée de consommation d'eau arrive entre J+3 et J+5.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"success_data_additional_update_gas\":\"Sachez que la donnée de consommation de gaz arrive entre J+3 et J+5.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"error_txt\":\"Aïe !\",\"mismatch\":{\"title\":\"Vos données n'ont pas pu être récupérées.\",\"text1\":\"Vos nom et numéro de compteur ne correspondent plus. Merci de reconfigurer votre connecteur.\",\"text2\":\"Reconfigurer mon connecteur ?\",\"text3\":\"La reconfiguration de votre connecteur passe par sa suppression et sa nouvelle installation. Vos données seront conservées.\"},\"error_data_electricity\":\"Un problème est survenu. Vos données de consommation d’électricité ne seront pas chargées.\",\"error_data_water\":\"Un problème est survenu. Vos données de consommation d’eau ne seront pas chargées.\",\"error_credentials_water\":\"Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter. L'identifiant est un numéro à 7 chiffres (différent de votre numéro de contrat).\",\"error_credentials_electricity\":\"Il semblerait que les nom(s) et adresse ne concordent pas avec le numéro de votre compteur.\",\"error_credentials_electricity_2\":\"Nous ne pouvons vous donner accès aux données de consommation.\",\"error_credentials_update_water\":\"Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter.\",\"error_credentials_update_electricity\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"error_credentials_update_gas\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"error_data_gas\":\"Un problème est survenu. Vos données de consommation de gaz ne seront pas chargées.\",\"error_consent_form_gas_title\":\"Nous n'avons pas pu connecter vos données de consommation de gaz à Ecolyo.\",\"error_consent_form_gas_content\":\"En effet, le partage de vos données de consommation de gaz \\\"informatives\\\" doit être accepté.\",\"error_consent_form_gas_content_2\":\"Merci de cocher \\\"OUI\\\" au partage de vos données de consommation de gaz, et à \\\"Autoriser l'accès à mes données informatives\\\".\",\"error_data_update_electricity\":\"Un problème est survenu. Vos données de consommation d’électricité n’ont pas été mises à jour.\",\"error_data_update_water\":\"Un problème est survenu. Vos données de consommation d’eau n’ont pas été mises à jour.\",\"error_data_update_gas\":\"Un problème est survenu. Vos données de consommation de gaz n’ont pas été mises à jour.\",\"error_data_2\":\"Merci de réessayer plus tard.\",\"button_validate\":\"Ok\",\"button_understood\":\"J'ai compris\",\"button_try_again\":\"Réessayer\",\"show_common_error\":\"Voir les erreurs récurrentes\",\"show_common_error_list\":\"<span style=\\\"text-align:left; font-weight:700;\\\">Le problème peut provenir des cas suivants :</span> <ul style=\\\"text-align:left;\\\"><li>Vous avez un co-titulaire sur votre contrat. Veillez à bien entrer le nom du <span style=\\\"color:#E3B82A; font-weight:700;\\\">titulaire du contrat</span> et non le co-titulaire.</li><li>  Votre nom comporte un tiret ? Tentez sans le tiret.</li><li>  Entrez bien le nom de votre commune de résidence en entier (tirets et accents inclus)</li><li>  Avez-vous bien entré le <span style=\\\"color:#E3B82A; font-weight:700;\\\">numéro de votre compteur</span> (PDL) ? Tout autre numéro (de contrat, de client) ne fonctionne pas.</li></ul><p style=\\\"text-align:center; font-style: italic; font-weight:400; font-size: 0.9rem;\\\">Si vous rencontrez toujours des difficultés, contactez notre service d'aide </p><div style=\\\"text-align:center; font-weight:700;\\\">Avez-vous pensez à vérifier ces informations ?</div>\",\"accessibility\":{\"window_title\":\"Fenêtre d'attente de connexion\",\"button_close\":\"Fermer la fenêtre\"}},\"consent_outdated\":{\"title\":{\"0\":\"Votre autorisation pour afficher vos données d’électricité a expiré\",\"2\":\"Votre autorisation pour afficher vos données de gaz a expiré\"},\"text1\":{\"0\":\"Veuillez re-donner votre consentement pour la transmission et la reconnexion de vos données ENEDIS à Ecolyo.\",\"2\":\"Veuillez re-donner votre accord pour que GRDF nous transmette vos données de consommation.\"},\"text2\":{\"0\":\"Souhaitez-vous renouveler votre accord dès maintenant pour un an ?\",\"2\":\"Voulez-vous  donner votre accord sur votre compte GRDF maintenant ?\"},\"later\":\"Plus tard\",\"go\":\"J'y vais\",\"no\":\"Non\",\"yes\":\"Oui\"},\"delete_grdf_modal\":{\"text1\":\"La suppression de la connexion avec GRDF s’accompagne de la suppression de votre consentement à partager vos données gaz avec Ecolyo.\",\"text2\":\"Si vous souhaitez vous reconnecter, il vous faudra re-donner votre accord pour que GRDF nous transmette vos données de consommation.\",\"text3\":\"Voulez-vous  supprimer votre connexion et votre consentement à GRDF ?\",\"cancel\":\"Plus tard\",\"go\":\"Oui\"},\"legal\":{\"read_legal\":\"Lire les mentions légales\",\"title_legal\":\"Mentions légales & CGU\",\"version\":\"Version du 12.12.2022\",\"site\":\"Site du service Ecolyo : <a href=\\\"https://ecolyo.com/\\\"> https://ecolyo.com/</a>\",\"adress\":\"Métropole de Lyon - 20, rue du Lac – CS 33569 - 69505 Lyon cedex 03\",\"phone\":\"Tél : (33) 4 78 63 40 40\",\"mail\":\"<a href=\\\"mailto:ecolyo@grandlyon.com\\\"> ecolyo(at)grandlyon.com</a>\",\"p1b\":\"Directrice de publication : \",\"p1\":\"Blandine MELAY, Responsable du Service Transition Énergétique\",\"p2b\":\"Animation éditoriale, gestion et mise à jour : \",\"p2\":\"Marion BERTHOLON,  Chargée de services numériques pour la transition énergétique\",\"p3b\":\"Photographies : \",\"p3\":\"sauf mention contraire, les photos sont la propriété de la Métropole de Lyon\",\"p4b\":\"Conception et Charte graphique : \",\"p4\":\"Florent Dufier\",\"p5b\":\"Réalisation technique : \",\"p5\":\"Métropole de Lyon, Sopra Steria\",\"p6b\":\"Maintenance technique : \",\"p6\":\"Délégation Développement économique, emploi & savoirs - Innovation numérique & systèmes d’information - Usages et services numériques - Développement des services numériques\",\"title1\":\"Crédits\",\"part1\":\"Ce site est le résultat de développements spécifiques réalisés dans les langages Go, TypeScript, HTML et Sass. Les développements s’appuient sur plusieurs bibliothèques et frameworks libres : axios, cozy-bar, cozy-client, cozy-harvest-lib, cozy-scripts, cozy-ui, d3, detect-browser, global, lodash, luxon, moment, moment-timezone, node-sass, object-hash, react, react-dom, react-redux, react-router-dom, react-swipeable-views, redux-devtools-extension, sass-loader. Les tests de l’application s’appuient sur les bibliothèques et frameworks libres suivants: enzyme, enzyme-adapter-react-16, jest-junit, react-test-renderer, redux-mock-store. La pile technique intègre également les applications Cozy stack, Yarn, Docker, ACH. Les déploiements sont réalisés sur le registre hébergé chez Cozy. L’équipe de réalisation utilise au quotidien les applications GitLab, IceScrum, RocketChat, SonarQube.\",\"title2\":\"Traitement des données personnelles et droit d’accès, de modification et de suppression\",\"part2\":\"Conformément à la réglementation en vigueur en matière de protection des données personnelles, le service Ecolyo a fait l’objet d’une inscription au registre des traitements de la Métropole de Lyon. Ecolyo fait partie de l’écosystème de services orientés « self data » déployés par la Métropole de Lyon avec l’ambition d’offrir aux usagers métropolitains les outils et les services leur permettant d’exercer directement leur droit à la portabilité, dans un cadre apte à garantir aussi bien la transparence et le contrôle sur l’usage de leurs données personnelles que l’exploitation directe du contenu de ces données selon leurs libres choix. Le self data est en effet selon la Fondation Internet Nouvelle Génération (FING) « la production, l’exploitation et le partage de données personnelles par les individus, sous leur contrôle et à leurs propres fins ». Au sein de cet environnement self data, la gestion des données s’appuie sur l’organisation suivante des rôles et responsabilités associées : \",\"part2-1\":\"Les partenaires du service GRDF et Eau Publique du Grand Lyon sont responsables exclusivement des seuls traitements de Données Personnelles relatifs à la collecte des données de consommation de gaz et d’eau de l’utilisateur et à leur transmission sur la plateforme de cloud personnel, après consentement de l’utilisateur.\",\"part2-2\":\"Enedis est responsable de la collecte des données de consommation d’électricité et de leur mise à disposition à la Métropole de Lyon qui, elle en gère la transmission sur la plateforme du cloud personnel de l’utilisateur, après avoir récupéré le consentement de l’utilisateur.\",\"part2-3\":\"La Métropole de Lyon est responsable de traitement sur le périmètre du service Ecolyo qu’elle propose à l’usager, ainsi que des traitements nécessaires à la fourniture de la plateforme de cloud personnel qu’elle met à disposition de l’usager pour accéder au service Ecolyo. En sa qualité de responsable de ces traitements, elle collecte et traite : \",\"part2-3-1\":\"Les données de compte de l’usager renseignées par l’usager au sein de son espace de cloud personnel Grand Lyon à des fins de gestion du compte et de communication avec l’usager ;\",\"part2-3-2\":\"Les données de compte de l’utilisateur lui permettant de connecter ses données d’électricité à Ecolyo ;\",\"part2-3-3\":\"Les données privées de consommation d’énergie et d’eau dont la récupération, la sauvegarde, le stockage, la synchronisation et le partage sur la plateforme de cloud personnel sont initiés par l’usager sans visibilité de la Métropole de Lyon sur leur contenu.\",\"part2-3-4\":\"Les données privées sur la composition du logement et du foyer de l’utilisateur, fournies par l’utilisateur lui-même au sein du service, sont traitées par le service sans visibilité de la Métropole de Lyon sur leur contenu.\",\"part2-3-5\":\"Des métriques d’usage du service anonymisées et remontées périodiquement afin d’améliorer la qualité du service et d’évaluer son impact (Plus d’informations sur la manière dont votre anonymat est bien préservé dans ce processus <a href=\\\"https://ecolyo.com/cloud_statistiques.html\\\">ici</a>).\",\"part2-4\":\"La Métropole réalise également des mesures d’audience à l’aide de la solution Matomo. Afin de vous fournir un meilleur service et d’améliorer votre expérience d'utilisateur, nous utilisons des solutions de mesure d’audience qui utilisent la technologie des « cookies », des fichiers texte qui sont enregistrés sur votre ordinateur et qui permettent de générer des informations envoyées aux serveurs de mesure d’audience. Sur ces serveurs, l’adresse IP est anonymisée. Les données recueillies ont uniquement pour finalité de permettre d'analyser la fréquentation de nos pages afin d'en améliorer le contenu. Il s'agit de statistiques agrégées permettant de connaître le nombre de visites et de visiteurs différents, les pages les plus populaires, les chemins préférés, les niveaux d'activité par jour de la semaine et par heure de la journée, les principales erreurs etc. Vous avez cependant le droit de vous opposer à l’utilisation de ces cookies, et donc au traitement de vos données personnelles de navigation, en vous rendant dans la page Options de notre service.\",\"part2-5\":\"L’usager est seul décisionnaire des finalités d’utilisation qu’il souhaite définir pour le traitement de ses données personnelles de consommation, à la suite de leur transmission par les partenaires du service Ecolyo sur son cloud personnel. Ainsi, dans le cadre de l’utilisation d’Ecolyo, l’usager ne recevra les données des partenaires du service : Enedis, GRDF et Eau Publique du Grand Lyon seulement qu’à sa demande expresse après la saisie de ses identifiants.\",\"part2-6\":\"L’utilisateur est donc le seul à accéder :\",\"part2-6-1\":\"À ses données de consommation d’électricité horaires, journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-6-2\":\"À ses données de consommation de gaz journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-6-3\":\"À ses données de consommation eau journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-7\":\"Les engagements et responsabilités de la Métropole de Lyon concernant la protection des données et la confidentialité des données Ecolyo sont précisés dans les Mentions légales et les conditions d’utilisation du cloud personnel Grand Lyon qui accueille aujourd’hui le service Ecolyo et sans lequel le service ne peut pas fonctionner. Pour plus d’informations sur les engagements et responsabilités de la Métropole de Lyon concernant la protection et la confidentialité dans le cloud personnel, nous vous invitons à vous référer <a href=\\\"https://manager.cozygrandlyon.cloud/tos/266b4226-8417-42fb-b911-41e86dae8581.pdf?locale=fr\\\">aux mentions légales et CGU du cloud personnel métropolitain.</a> \",\"part2-8\":\"Conformément à la loi 78-17 du 6 janvier 1978 modifiée relative à l’information, aux fichiers et aux libertés, vous disposez d’un droit d’accès, de rectification et d’opposition au traitement de vos données à caractère personnel. Votre cloud personnel vous permet d’exercer ces droits directement dans cet espace sur vos données de compte. S’agissant des données de consommations d’électricité et de gaz, l’utilisateur peut supprimer son consentement à partager ses données en supprimant son connecteur dans la page Consos.\",\"part2-9\":\"Vous pouvez également exercer vos droits d’accès, de rectification, de limitation, d’opposition et d’effacement de vos données personnelles en contactant directement le Délégué à la Protection des Données par courrier en écrivant à l’adresse :\",\"part2-10\":\"Métropole de Lyon – Délégué à la Protection des Données - Direction des Assemblées, des Affaires Juridiques et des Assurances - 20, rue du Lac - BP 33569 - 69505 Lyon Cedex 03 ou en ligne, au moyen du formulaire disponible à l'adresse suivante : <a href=\\\"https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/\\\">https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/.</a>\",\"part2-11\":\"L’exercice de ces droits sur vos données personnelles auprès de la Métropole de Lyon concerne exclusivement les données traitées dans le cadre du service  « Ecolyo ».\",\"title3\":\"Dispositions légales\",\"part3-1\":\"Les divers éléments du site web (la forme, la mise en page, le fonds, la structure …) sont protégés par le droit des dessins et modèles, le droit d’auteur, le droit des marques ainsi que le droit à l’image et ils ne peuvent être copiés ou imités en tout ou partie sauf autorisation expresse de la Métropole de Lyon.\",\"part3-2\":\"Toute personne ne respectant pas les dispositions légales applicables se rend coupable du délit de contrefaçon et est passible des sanctions pénales prévues par la loi.\",\"title4\":\"Droits d’auteurs\",\"part4-1\":\"Les photographies, textes, logos, pictogrammes, ainsi que toutes œuvres intégrées dans le site sont la propriété de la \\\"Métropole de Lyon\\\" ou de tiers ayant autorisé la \\\"Métropole de Lyon\\\" à les utiliser.\",\"part4-2\":\"Les reproductions, les transmissions, les modifications, les réutilisations, sur un support papier ou informatique, dudit site et des œuvres qui y sont reproduites ne sont autorisées que pour un usage personnel et privé conforme aux dispositions de l’article L 122-5 du Code de la Propriété Intellectuelle. Ces reproductions devront ainsi notamment indiquer clairement la source et l’auteur du site et/ou de ces œuvres multimédias. En aucun cas ces reproductions ne sauraient porter préjudice aux droits des tiers. Les reproductions, les transmissions, les modifications, les réutilisations à des fins publicitaires, commerciales ou d’information, de tout ou partie du site, sont totalement interdites.\",\"title5\":\"Logo de la Métropole de Lyon et d’Ecolyo\",\"part5\":\"Les logos de la Métropole de Lyon et d’Ecolyo ne peuvent pas être modifiés – proportions, couleurs, éléments, constituants – et ne peuvent pas être sujet à aucune transformation, animation ou tout autre processus. Les logos de la Métropole de Lyon et d’Ecolyo ne peuvent être utilisés et associés qu’aux seules informations vérifiables. Ils ne peuvent être notamment utilisés que pour illustrer des relations avec la Métropole de Lyon ou des actions de sponsorings dûment établies. Quel que soit le cas d’espèce, la Métropole de Lyon se réserve le droit d’approuver ou de désapprouver toute utilisation des logos de la Métropole de Lyon et d’Ecolyo, pour assurer son utilisation correcte, conformément à l’éthique, la morale et aux intérêts de la Métropole de Lyon. Les conditions susmentionnées s’appliquent dans le cadre de pages web, elles ne font pas référence à l’utilisation des logos dans tout autre document. La Métropole de Lyon se réserve le droit de modifier les conditions d’utilisation des logos de la Métropole de Lyon et d’Ecolyo à tout moment et sans préavis.\",\"title6\":\"Droit des bases de données\",\"part6\":\"Les bases de données sont protégées par la loi du 1er juillet 1998 et le régime français du droit d’auteur.\",\"title7\":\"Établissements de liens vers le site Ecolyo\",\"part7-1\":\"La Métropole de Lyon autorise la mise en place d’un lien hypertexte vers son service Ecolyo pour tous les sites internet, à l’exclusion de ceux diffusant des informations à caractère polémique, pornographique, xénophobe ou pouvant, dans une plus large mesure porter atteinte à la sensibilité du plus grand nombre.\",\"part7-2\":\"Le lien doit aboutir à la page d’accueil du service (<a href=\\\"https://ecolyo.com\\\">https://ecolyo.com</a>), cette page devant apparaître dans une nouvelle fenêtre. Les pages du service Ecolyo ne doivent en aucun cas être intégrées à l’intérieur des pages d’un autre site (iframe).\",\"part7-3\":\"Dans tous les cas d’espèce, La Métropole de Lyon se réserve le droit de demander la suppression d’un lien si elle estime que le site cible ne respecte pas les règles ainsi définies.\",\"title8\":\"Liens vers des sites tiers depuis le site Ecolyo\",\"part8\":\"Les liens hypertextes mis en œuvre au sein du site en direction d’autres sites et/ou de pages personnelles et d’une manière générale vers toutes ressources existantes sur internet ne sauraient engager la responsabilité de la Métropole de Lyon quant aux liens qu’ils contiennent ou aux changements ou mises à jour qui leur sont apportés.\",\"title9\":\"Mise en garde générale\",\"part9-1\":\"Nos services mettent tout en œuvre pour offrir aux visiteurs de ce site web des informations fiables et vérifiées. Cependant, malgré tous les soins apportés, le site peut comporter des inexactitudes, des défauts de mise à jour ou des erreurs.\",\"part9-2\":\"Nous remercions les utilisateurs du site de nous faire part d’éventuelles omissions, erreurs ou corrections par mail sur la boite aux lettres du webmestre ou directement via le formulaire proposé dans le service.\",\"accessibility\":{\"button_close\":\"Fermer la fenêtre\"}},\"oauth\":{\"window\":{\"title\":\"OAuth\"}},\"onboarding\":{\"welcomeModal\":{\"title\":\"Vous êtes à mi-chemin !\",\"part1\":\"Votre cloud personnel a bien été créé.\",\"part2\":\"Il vous faut maintenant donner votre accord pour connecter vos compteurs au service.\",\"button_valid\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre de bienvenue\",\"button_valid\":\"Valider\"}}},\"old_fluid_data_modal\":{\"errorTxt\":\"Aïe !\",\"oldData\":\"Vos données semblent anciennes\",\"verify\":\"Veuillez vérifier l’état de vos connecteurs : \",\"problem\":\"Vos connecteurs semblent bien connectés, il se peut qu’il y ait un problème au niveau du ou des fournisseurs de données :\",\"problem_electricity\":\"pour l'électricité.\",\"problem_water\":\"pour l'eau.\",\"problem_gas\":\"pour le gaz.\",\"contact\":\"Veuillez prendre contact directement avec eux.\",\"accessButton\":\"Accéder aux connecteurs\",\"later\":\"Plus tard\",\"ok\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre d'information\",\"button_ok\":\"Fermer la fenêtre\",\"button_later\":\"Fermer la fenêtre\",\"button_goto_konnector\":\"Aller aux connecteurs\"}},\"performance_indicator\":{\"bilan\":{\"text1\":\"Par rapport à \",\"text2\":\"soit une différence de : \"},\"error_no_compare\":\"comparaison impossible\",\"error_no_compare_reason\":\"(manque de données)\",\"error_no_compare_no_data\":\"Vos consommations pour cette période sont incomplètes à cause d’un problème technique concernant :\",\"fpi\":{\"no_data\":\"Données non disponibles\",\"no_comparison\":\"Pas de comparaison possible\"}},\"profile\":{\"report\":{\"title_alert\":\"Alerte Consommation Excessive d'Eau\",\"title_bilan\":\"Notification par mail\",\"switch_label_bilan\":\"Je reçois la lettre mensuelle contenant un bilan et des conseils sur ma consommation.\",\"switch_label_alert\":\"Être prévenu d’un dépassement anormal de ma consommation d’eau\",\"input_label_alert\":\"Si ma consommation d’eau quotidienne dépasse :\",\"input_label_subtext_alert\":\"Votre consommation quotidienne maximum sur les 6 derniers mois : \",\"activate\":\"Activer\",\"deactivate\":\"Désactiver\"},\"accessibility\":{\"button_toggle_mail_report\":\"Recevoir mon bilan mensuel par mail\",\"button_toggle_consumption_alert\":\"Recevoir des alertes sur mes consommations journalières\",\"input_water_alert_report\":\"Indiquer une limite de consommation d'eau journalière\"}},\"profile_type\":{\"title_profile\":\"Mes données\",\"read_profile\":\"Ajuster mon profil\",\"button_update_profile\":\"J'ajuste mon profil\",\"your_profile\":\"Mon profil\",\"multi_choices\":\"Plusieurs réponses possibles\",\"housing_type\":{\"title\":\"Logement\",\"question\":\"De quel type de logement disposez-vous ?\",\"individual_house\":\"Maison individuelle\",\"apartment\":\"Appartement\"},\"construction_year\":{\"title\":\"Construction\",\"question\":\"Quelle est son année de construction ?\",\"text_before_1948\":\"Construit avant 1948\",\"text_between_1948_and_1974\":\"Construit entre 1948 et 1974\",\"text_between_1975_and_1989\":\"Construit entre 1975 et 1989\",\"text_between_1990_and_1998\":\"Construit entre 1990 et 1998\",\"text_after_1998\":\"Construit après 1998\",\"text_unknown\":\"Construit après 1998\",\"before_1948\":\"Avant 1948\",\"between_1948_and_1974\":\"Entre 1948 et 1974\",\"between_1975_and_1989\":\"Entre 1975 et 1989\",\"between_1990_and_1998\":\"Entre 1990 et 1998\",\"after_1998\":\"Après 1998\",\"unknown\":\"Je ne sais pas\"},\"occupantsNumber\":{\"single\":\" occupant\",\"multi\":\" occupants\"},\"area\":{\"title\":\"Surface\",\"question\":\"Quelle est sa surface en m² ?\",\"name\":\" m²\"},\"occupants_number\":{\"title\":\"Nombre d'occupants\",\"question\":\"Combien il y a-t-il d'occupants ?\"},\"outside_facing_walls\":{\"1\":\"1 façade\",\"2\":\"2 façades\",\"3\":\"3 façades\",\"4\":\"4 façades\",\"title\":\"Murs extérieurs\",\"question\":\"Combien de façades donnent sur l'extérieur ?\",\"text\":{\"single\":\" façade donne sur l'extérieur\",\"multi\":\" façades donnent sur l'extérieur\"}},\"floor\":{\"title\":\"Étage\",\"question\":\"À quel étage est votre appartement ?\",\"ground_floor\":\"Au rez-de-chaussée\",\"intermediate_floor\":\"Étage intermédiaire\",\"last_floor\":\"Dernier étage\",\"not_applicable\":\"Sans objet\"},\"heating\":{\"title\":\"Chauffage\",\"question\":\"Quel est votre type de chauffage ?\",\"individual\":\"Individuel\",\"collective\":\"Collectif\"},\"individual_insulation_work\":{\"title\":\"Travaux de rénovation\",\"question\":\"Quels travaux de rénovation avez-vous réalisés ces 10 dernières années ?\",\"none\":\"Aucun\",\"roof_insulation\":\"Isolation toiture\",\"window_replacement\":\"Remplacement fenêtres\",\"wall_insulation\":\"Isolation des murs\",\"window_replacement_and_wall_insulation\":\"Remplacement fenêtres et isolation des murs\",\"window_replacement_and_roof_insulation\":\"Remplacement fenêtres et isolation toiture\",\"roof_and_wall_insulation\":\"Isolation toiture et murs\",\"window_replacement_and_roof_and_wall_insulation\":\"Remplacement fenêtre et isolation des murs et isolation toiture\",\"built_after_1998\":\"construit après 1998\"},\"facilities_installation\":{\"title\":\"Équipement\"},\"ventilation\":{\"title\":\"Ventilation double flux\",\"question\":\"Êtes-vous équipé d'une ventilation double flux ?\",\"yes\":\"Oui\",\"no\":\"Non\",\"unknown\":\"Je ne sais pas\",\"text\":\"Équipé d'une ventilation double flux\"},\"heater_replacement\":{\"title\":\"Pompe à chaleur ou poêle à bois\",\"question\":\"Au cours de ces 10 dernières années, avez-vous remplacé votre chaudière ou vous êtes-vous équipé d'une pompe à chaleur ou d'un poêle à bois ?\",\"yes\":\"Oui\",\"no\":\"Non\",\"unknown\":\"Je ne sais pas\",\"text\":\"Équipé d'une pompe à chaleur ou poêle à bois\"},\"cold_water\":{\"title\":\"Eau\",\"question\":\"Votre eau est-elle comprise dans vos charges collectives ?\",\"individual\":\"Non\",\"collective\":\"Oui\",\"individual_text\":\"Individuelle\",\"collective_text\":\"Collective\"},\"hot_water\":{\"title\":\"Eau chaude\",\"question\":\"Quel est votre type de production d’eau chaude ?\",\"individual\":\"Individuelle\",\"collective\":\"Collective\"},\"hot_water_equipment\":{\"title\":\"Eau chaude\",\"question\":\"Utilisez-vous l’un de ces équipements pour produire votre eau chaude ?\",\"solar\":\"Chauffe-eau solaire\",\"thermodynamic\":\"Chauffe-eau thermodynamique\",\"other\":\"Aucun des deux\"},\"warming_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Bois\",\"4\":\"Fioul\",\"5\":\"Autre\",\"title\":\"Source chauffage\",\"question\":\"Quelle source d’énergie principale utilisez-vous pour vous chauffer ?\",\"no_fluid_text\":\"Produit ni par de l'électricité, ni par du gaz, ni par du bois ou du fuel\",\"0_text\":\"Produit grâce à de l'électricité\",\"2_text\":\"Produit grâce au gaz\",\"3_text\":\"Produit grâce au bois\",\"4_text\":\"Produit grâce au fioul\",\"5_text\":\"Produit grâce à un autre moyen\"},\"hot_water_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Autre (Fioul, Bois)\",\"title\":\"Source eau chaude\",\"question\":\"Avec quelle source d’énergie votre eau chaude est-elle produite ?\",\"no_fluid_text\":\"Produite ni par de l'électricité, ni par du gaz\",\"0_text\":\"Produite grâce à de l'électricité\",\"2_text\":\"Produite grâce au gaz\",\"3_text\":\"Produite à partir d'un autre moyen que l'électricité ou le gaz\"},\"cooking_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"title\":\"Source cuisson\",\"question\":\"Quel mode de cuisson principal utilisez-vous ?\"},\"update_date\":{\"title\":\"Date de prise d'effet\",\"question\":\"A partir de quelle date souhaitez-vous que ce nouveau profil soit pris en compte dans l'analyse de vos données ?\"},\"fluidType\":{\"0\":\"Électricité\",\"1\":\"Eau\",\"2\":\"Gaz\"},\"form\":{\"button_previous\":\"Précédent\",\"button_next\":\"Suivant\",\"button_end\":\"Terminer\",\"button_loading\":\"Chargement...\"},\"finished\":{\"title\":\"Terminé !\",\"label1\":\"Grâce à ces informations, vous pourrez comparer votre consommation avec celle d'un foyer vous ressemblant davantage !\",\"label2\":\"Nous pourrons aussi vous proposer des astuces pour maîtriser vos consommations adaptées à votre profil.\",\"button_validate\":\"OK\"},\"accessibility\":{\"button_end\":\"Terminer la mise à jour du profil\",\"button_next\":\"Aller à la section suivante\",\"button_previous\":\"Retour à la section précédente\",\"button_update_profile\":\"Ouvrir la page de mise à jour du profil\",\"button_toggle_detail_profile\":\"Afficher ou masquer le détail du profil\",\"button_toggle_export\":\"Afficher ou masquer l'export des données'\",\"button_toggle_average_home\":\"Afficher ou masquer les informations sur le comparatif'\",\"button_validate\":\"Valider\"}},\"export\":{\"title_export\":\"Télécharger mes données\",\"text1\":\"Vous allez télécharger l'historique mensuel de vos fluides sélectionnés\",\"fluid_select\":\"Pour quel(s) fluide(s) souhaitez vous exporter vos données ?\",\"no_data\":\"Vous n'avez aucune donnée de fluide...\",\"button_download\":\"Télécharger\",\"month\":\"Mois\",\"year\":\"Année\",\"consumption\":\"Consommation\",\"maxpower\":\"Puissance max (kVA)\",\"button_close\":\"Fermer la fenêtre\",\"modal_start\":{\"accessibility_title\":\"Commencer le téléchargement\",\"text1\":\"Vous allez télécharger des données personnelles, Ecolyo n’est plus responsable de celles-ci une fois téléchargées\",\"text2\":\"Les données seront téléchargées sous forme de document excel (.xls)\",\"text3\":\"Lancer le téléchargement ?\",\"button_cancel\":\"Annuler\"},\"modal_loading\":{\"accessibility_title\":\"Téléchargement en cours\",\"text1\":\"Données en cours de téléchargement\",\"text2\":\"Veuillez ne pas quitter l’application pendant la récupération et le téléchargement de vos données\",\"button_cancel\":\"Annuler le téléchargement\"},\"modal_done\":{\"accessibility_title\":\"Téléchargement terminé\",\"text1\":\"Vos données ont bien été téléchargées !\",\"text2\":\"Vous pouvez maintenant retrouver l’historique de vos données sur votre appareil\",\"error1\":\"Aïe !\",\"error2\":\"Il semblerait qu’une erreur se soit produite lors du téléchargement de vos données.\",\"button_close\":\"Fermer\",\"button_close_error\":\"Revenir plus tard\"}},\"quiz\":{\"explanation\":\"Répondez correctement aux 5 questions et remportez 5 des 15 étoiles nécessaires pour débloquer le duel final\",\"score_final\":\"SCORE FINAL\",\"correct\":\"Bravo !\",\"wrong\":\"Raté !\",\"rightAnswer\":\"Bonne réponse :\",\"earn\":\"Vous remportez\",\"button_go_back\":\"Retour\",\"button_end_quiz\":\"Youpi !\",\"button_try_again\":\"Réessayer\",\"button_validate\":\"Valider\",\"next\":\"Suivant\",\"consumption_question\":\"Question sur votre consommation\",\"accessibility\":{\"window_title\":\"Fenêtre de résultat\",\"button_end_quiz\":\"Terminer le quiz\",\"button_go_back\":\"Retour\",\"button_go_next\":\"Suivant\",\"button_try_again\":\"Relancer le quiz\",\"button_validate\":\"Valider\"}},\"splashscreen\":{\"error_loading\":\"Une erreur est survenue\",\"button_reload\":\"Réessayer\",\"accessibility\":{\"button_reload\":\"Recharger la page\"},\"migration_error\":\"Mise à jour de l'application\",\"consent_error\":\"Vérification de vos consentements pour partager vos données avec Ecolyo\",\"profile_error\":\"Chargement de votre profil utilisateur\",\"profileType_error\":\"Chargement de votre profil de consommation.\",\"challenges_error\":\"Actualisation de votre progression dans les défis\",\"analysis_error\":\"Chargement de votre analyse mensuelle\",\"index_error\":\"Chargement des index\",\"prices_error\":\"Mise à jour des prix\",\"consos_error\":\"Connexion à vos données de consommation\",\"partners_error\":\"Récupération de l'état des services partenaires\",\"unknown_error\":\"Veuillez vérifier votre connexion internet\",\"network_error\":\"Erreur de réseau\",\"step\":{\"0\":\"Mise à jour de l'application\",\"1\":\"Vérification de vos consentements pour partager vos données avec Ecolyo\",\"2\":\"Chargement de votre profil\",\"3\":\"Actualisation de votre progression dans les défis\",\"4\":\"Mise à jour des prix\",\"5\":\"Connexion à vos données de consommation\"}},\"timestep\":{\"today\":\"Aujourd'hui\",\"year\":{\"period\":\"5 ans\",\"comparelabel\":\"Comparer à l'année précédente\"},\"month\":{\"period\":\"Année\",\"comparelabel\":\"Comparer à l'année précédente\",\"current\":\"année actuelle\",\"last\":\"année précédente\"},\"day\":{\"period\":\"Mois\",\"comparelabel\":\"Comparer au mois précédent\",\"current\":\"mois actuel\",\"last\":\"mois précédent\"},\"week\":{\"period\":\"Semaine\",\"comparelabel\":\"Comparer à la semaine précédente\",\"current\":\"semaine actuelle\",\"last\":\"semaine précédente\"},\"half_an_hour\":{\"period\":\"Jour\",\"comparelabel\":\"Comparer à la journée précédente\",\"gather_data_title\":\"La récupération de vos données demi-horaires prend environ 24h.\",\"current\":\"jour actuel\",\"last\":\"jour précédent\",\"gather_data_subtitle\":\"Votre connexion a bien été prise en compte mais un délai de 24h est en général nécessaire à l’obtention de vos données.\\nÀ demain !\",\"analysis_waiting_data\":\"Pour bénéficier d'une analyse approfondie de votre consommation électrique, il nous faut récupérer vos données de consommation horaires. La récupération de ces données prend environ 24h. A bientôt !\"},\"accessibility\":{\"button_zoom_in\":\"Sélectionner le pas de temps précédent\",\"button_zoom_out\":\"Sélectionner le pas de temps suivant\"}},\"unsubscribe\":{\"title\":\"Êtes-vous sûr de ne plus vouloir recevoir notre email mensuel ?\",\"content\":\"Dans ce cas, vous ne recevrez plus la notification de votre bilan ainsi que les conseils associés au mois en cours.\",\"button_text\":\"Oui, je me désabonne\",\"button_accessibility\":\"Bouton de désinscription\"},\"welcome_modal\":{\"title\":\"Félicitations\",\"perso\":\"Votre espace personnel a bien été créé.\",\"connect\":\"Vous pouvez maintenant connecter vos compteurs d’énergie à Ecolyo en toute sécurité.\",\"button_valid\":\"Ok\",\"accessibility\":{\"title\":\"Fenêtre de félicitations\",\"button_valid\":\"Valider\"}}}");
+module.exports = JSON.parse("{\"common\":{\"title_app\":\"Ecolyo\",\"title_consumption\":\"Conso\",\"title_challenge\":\"Défis\",\"title_quiz\":\"Quiz\",\"title_exploration\":\"Exploration\",\"title_action\":\"Action\",\"title_duel\":\"Duel final\",\"title_ecogesture\":\"Astuce\",\"title_ecogestures\":\"Astuces\",\"title_ecogestures_choice\":\"Sélection des astuces\",\"title_options\":\"Options\",\"title_analysis\":\"Analyse\",\"title_profiletype\":\"Ajuster mon profil\",\"title_legal_notice\":\"Mentions légales\",\"title_gcu\":\"Conditions générales d’utilisation\",\"title_accessibility\":\"Accessibilité : non conforme\",\"title_sge_connect\":\"Connexion à l'électricité\",\"accessibility\":{\"loading\":\"Chargement\"}},\"navigation\":{\"consumption\":\"Conso\",\"challenges\":\"Défis\",\"ecogestures\":\"Astuces\",\"options\":\"Options\",\"analysis\":\"Analyse\"},\"FLUID\":{\"ELECTRICITY\":{\"NAME\":\"Électricité\",\"LABEL\":\"Électricité\",\"UNIT\":\"kWh\",\"ADD\":\"Ajouter l'électricité\",\"MEGAUNIT\":\"MWh\",\"provider\":\"Enedis\"},\"WATER\":{\"NAME\":\"Eau\",\"LABEL\":\"Eau\",\"ADD\":\"Ajouter l'eau\",\"UNIT\":\"L\",\"MEGAUNIT\":\"m³\",\"provider\":\"Eau Publique du Grand Lyon\"},\"GAS\":{\"NAME\":\"Gaz\",\"LABEL\":\"Gaz\",\"ADD\":\"Ajouter le gaz\",\"UNIT\":\"kWh\",\"MEGAUNIT\":\"MWh\",\"provider\":\"GRDF\"},\"MULTIFLUID\":{\"NAME\":\"Multi fluide\",\"LABEL\":\"Multi\",\"UNIT\":\"€\"}},\"action\":{\"duration\":\"Durée : %{smart_count} jours\",\"result\":\"Résultat\",\"finished\":\"Défi terminé !\",\"details\":\"Détail de l'astuce\",\"apply\":\"J'applique cette action\",\"other\":\"Je choisis une autre action\",\"resultText1\":\"Cela n'a pas été trop difficile ?\",\"resultText2\":\"Jetez un coup d'œil dans la page conso dans 1 à 3 jours, le temps que vos données arrivent, pour voir l'impact de votre action.\",\"resultText3\":\"Pas de baisse de significative ? Pas de panique, en maintenant cette pratique dans le temps, les économies d'énergies et d'eau seront davantage visibles.\",\"resultText4\":\"Dans tous les cas, bravo, vous remportez...\",\"ok\":\"Ok\"},\"action_modal\":{\"accept\":\"Je relève le défi\",\"refuse\":\"Je me défile\",\"accessibility\":{\"window_title\":\"Fenêtre de confirmation\",\"button_accept\":\"Accepter\",\"button_refuse\":\"Refuser\"}},\"analysis\":{\"viewTitle\":\"Analyse\",\"comparison\":\"Comparatif\",\"analysis_date\":\"Conso totale\",\"challenge\":\"Défis terminés en\",\"user_consumption\":\"Votre conso\",\"average_home\":\"Conso moyenne d'un profil similaire\",\"average_home_description\":\"Le comparatif ici présenté est calculé sur la base d'un profil similaire au vôtre. Il s'agit d'un calcul et non d'une comparaison avec les autres utilisateurs de l'application. Sont pris en compte l'ensemble des informations entrées dans votre profil : mode de chauffage, âge du logement et éventuels travaux de rénovation, etc. Ce modèle a été créé avec l'Agence Locale de l'Energie sur la base de chiffres issues du Schéma Directeur des Energies de la Métropole de Lyon et de Chiffres-clé publiés par l'ADEME (l'Agence de l'Environnement et de la Maîtrise de l'Energie).\",\"approximative_description\":\"Pour comparer votre consommation avec un foyer similaire ou avec une conso idéale, veuillez détailler votre profil\",\"not_connected\":\"Non connecté\",\"no_data_2\":\"Données non disponibles\",\"accessibility\":{\"button_go_to_profil\":\"Détailler mon profil\"},\"max_day\":\"Jour où vous avez le plus consommé\",\"compare\":{\"title\":\"Comparateur\",\"month_tab\":\"Comparer au mois dernier\",\"year_tab\":\"Comparer à l'année dernière\"},\"no_data\":\"Pas de données\"},\"analysis_error_modal\":{\"title\":\"Aucune analyse\",\"message\":\"Pour profiter d’une analyse de vos consommations, connectez au moins un de vos compteurs.\",\"go_to_options\":\"Je connecte mes compteurs\",\"go_back\":\"Retour\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_go_back\":\"Retour\",\"button_goto_konnector\":\"Aller aux connecteurs\"}},\"analysis_pie\":{\"total\":\"Conso totale\",\"month\":\"Au mois de \",\"estimation\":\"Comment sont estimés\",\"estimation2\":\"les prix ?\"},\"special_elec\":{\"title\":\"Spécial Électricité\",\"average\":\"Conso moyenne\",\"weektype\":\"un jour de \",\"week\":\"semaine\",\"weekend\":\"week-end\",\"min\":\"Conso minimum\",\"percentage\":\"Part dans la facture\",\"price\":\"Soit\",\"maxPower\":\"Puissance maximum atteinte\",\"showModal\":\"Plus d'infos\"},\"elec_info_modal\":{\"accessibility\":{\"window_title\":\"electricity-info-modal\",\"button_close\":\"close-modal\"},\"title1\":\"Qu’est-ce que la consommation minimum ?\",\"title2\":\"Qu’est-ce que la puissance maximum ?\",\"text1\":\"Elle correspond à votre plus petite consommation du mois sur un créneau d'une demi-heure.\",\"text2\":\"Nous extrapolons cette consommation sur 1 mois afin vous donner un aperçu de la consommation de vos consommations électriques en veille (box, télé, chargeurs, ...) ou encore de celle, incompressible, de vos appareils de froid (frigo, congélateur).\",\"text3\":\"C’est la puissance maximum délivrée par tous les appareils fonctionnant au même moment dans votre logement.\",\"text4\":\"Vous avez choisi une puissance maximum dans votre offre d’électricité (3, 6 ou 9 kVA...) que vous ne devez pas dépasser pour ne pas faire sauter votre compteur. \",\"text5\":\"Cette puissance varie d'un mois à l'autre, regardez cette valeur sur l'ensemble de l'année pour vérifier si votre puissance souscrite correspond bien à votre usage.\"},\"auth\":{\"enedissgegrandlyon\":{\"title\":\"Ecolyo doit se connecter à l’électricité\",\"bill\":\"Munissez-vous d’une <span>facture d’électricité</span> pour valider la connexion\",\"connect\":\"Je me connecte à l'électricité\",\"accessibility\":{\"connect\":\"Se connecter\"},\"identityTitle\":\"Nom inscrit sur la facture\",\"firstName\":\"Prénom\",\"lastName\":\"Nom\",\"pdlTitle\":\"Numéro de votre compteur électrique (PDL)\",\"pdlLabel\":\"N° (14 chiffres)\",\"pdlHint\":\"Où trouver le n° de PDL ?\",\"pdlModal\":{\"txt1\":\"Où trouver le n° de PDL ou PRM ?\",\"txt2\":\"Le numéro de PDL ou PRM se compose de 14 chiffres.\",\"txt3\":\"Votre numéro de PDL ou PRM se trouve sur votre facture d’électricité.\",\"txt4\":\"Si vous avez un compteur Linky, appuyez sur le bouton “+” et faites défiler l’affichage jusqu’à obtenir l’affichage suivant :\"},\"addressTitle\":\"Adresse du titulaire\",\"address\":\"Numéro et voie\",\"zipCode\":\"Code postal\",\"city\":\"Ville\",\"headConsent\":\"Vous allez partager vos données à la Métropole de Lyon. Elles seront directement transférées à Ecolyo à l'intérieur de votre cloud personnel, sans que la Métropole n'y accède ni ne les visualise.\",\"textConsent\":\"Afin  de vous offrir des fonctionnalités de visualisation et d'analyse, Ecolyo a besoin des données suivantes : \",\"consentLi1\":\"L'historique et le relevé de vos consommations quotidiennes en kWh\",\"consentLi2\":\"L'historique et le relevé de vos consommations au pas de temps 30 minutes\",\"consentLi3\":\"Les puissances maximales atteintes quotidiennement\",\"consentLi4\":\"Les données contractuelles (début de contrat et puissance souscrite)\",\"consentCheck1\":\"Je consens à partager les données personnelles ci-dessus pour une durée d'<span>un an</span>\",\"consentCheck2\":\"J’atteste être le titulaire du point de livraison (PDL) renseigné à l’étape précédente\",\"modalHint\":{\"accessibility\":\"Titre de la modale\",\"title\":\"Où trouver le n° de PDL ?\",\"button\":\"J'ai compris\",\"button-accessibility\":\"Bouton valider\"}},\"grdfgrandlyon\":{\"bill\":\"Munissez-vous d’une <span>facture de gaz</span> pour valider la connexion\",\"connect\":\"Je me connecte au gaz\",\"accessibility\":{\"connect\":\"Se connecter\"},\"connect_form\":{\"label\":\"Je donne mon accord via mon compte GRDF\"},\"no_account\":{\"title\":\"Ecolyo doit se connecter au gaz\"},\"with_account\":{\"title\":\"Votre compte GRDF a bien été créé ?\",\"subtitle1\":\"Plus qu’à donner votre accord pour connecter votre compteur de gaz et Ecolyo !\"},\"step1\":{\"info1\":\"Un <span>compte chez GRDF</span> est nécessaire pour vous connecter au gaz\",\"info2\":\" <span>quelque soit votre fournisseur de gaz</span>.\",\"info3\":\"<p>GRDF est le gestionnaire de réseau. C'est lui qui est responsable de votre compteur Gazpar et de la collecte des données de consommation.</p>\",\"info4\":\"Possédez-vous un <span>compte GRDF</span> ?\"},\"step2\":{\"info1\":\"Une fois votre compte créé, <span>n'oubliez pas de revenir sur Ecolyo</span> pour finaliser la connexion.\"},\"step3\":{\"info1\":\"La visualisation de vos données sur Ecolyo demande l'activation du <span>partage de toutes les données.</span>\",\"info2\":\"Pour une expérience optimale, <span>une période de consentement de 1 an</span> est recommandée à partir d’aujourd’hui.\",\"info3\":\"<p>Veillez également à indiquer une date antérieure pour l'historique (1er calendrier) afin de pouvoir récupérer jusqu'à 3 ans d'historique.</p>\"},\"button_go_to_partner_site\":\"Aller sur GRDF\"},\"eglgrandlyon\":{\"bill\":\"Munissez-vous d’une <span>facture d'eau</span> pour valider la connexion\",\"connect\":\"Je me connecte à l'eau\",\"accessibility\":{\"connect\":\"Se connecter\"},\"connect_form\":{\"login\":\"Identifiant (7 chiffres)\",\"password\":\"Mot de passe\",\"label\":\"Je connecte Ecolyo à mon compte Eau Publique du Grand Lyon\"},\"no_account\":{\"title\":\"Ecolyo doit se connecter à l'eau\"},\"with_account\":{\"title\":\"Votre compte Eau Publique du Grand Lyon a bien été créé ?\",\"subtitle1\":\"Plus qu’à donner votre accord pour connecter votre compteur d'eau et Ecolyo !\"},\"step1\":{\"info1\":\"La connexion se fait via <span>votre compte Eau Publique du Grand Lyon</span>.\",\"info2\":\"Possédez-vous un <span>compte Eau Publique du Grand Lyon</span> ?\"},\"step2\":{\"info1\":\"Une fois votre compte créé, <span>n'oubliez pas de revenir sur Ecolyo</span> pour finaliser la connexion.\"},\"button_go_to_partner_site\":\"Aller sur EPGL\"},\"connect_oauth\":{\"loading\":\"Chargement...\"},\"accessibility\":{\"button_reveal_password\":\"Afficher le mot de passe\",\"button_connect\":\"Se connecter\",\"button_create_account\":\"Se créer un compte\",\"window_title\":\"Fenêtre d'information sur la création de compte.\",\"button_close\":\"Fermer la fenêtre.\"},\"button_previous\":\"Précédent\",\"button_connect\":\"Se connecter\",\"button_create_account\":\"Se créer un compte\",\"button_has_account\":\"J'ai déjà un compte\",\"button_validate\":\"J'ai compris\",\"button_showOfflineData\":\"Voir mes anciennes données\",\"warningOfflineData\":\"Attention, vous visualisez d’anciennes données. Pour actualiser vos données, connectez votre compteur\"},\"challenge\":{\"card\":{\"ongoing\":{\"quiz\":\"Quiz\",\"exploration\":\"Explorations\",\"action\":\"Actions\",\"duel\":\"Duel Final\",\"result\":\"Résultat\",\"duelDone\":\"du duel final\"},\"locked\":{\"desc\":\"À débloquer en terminant le défi précédent\"}},\"card_done\":{\"saving\":\"Économie de\",\"depense\":\"Dépense de\",\"win\":\"Gagné\",\"lost\":\"Perdu\",\"final_defi\":\"sur le duel final\",\"final_defi_view\":\"Revoir le duel final\"},\"card_last\":{\"title\":\"Tous les défis sont terminés\",\"message1\":\"Nous travaillons actuellement à vous proposer de nouveaux défis.\",\"button\":\"Suggérer une idée de défi\"},\"card_unlocked\":{\"button_launch\":\"Lancer le défi\"},\"accessibility\":{\"button_launch\":\"Lancer le défi\",\"button_goto_konnector\":\"Aller aux connecteurs\",\"button_slider_previous\":\"Précédent\",\"button_slider_next\":\"Suivant\"}},\"challenge_no_fluid_modal\":{\"title\":\"Oups !\",\"content\":\"Connectez au moins 1 fluide pour pouvoir jouer\",\"button_validate\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_validate\":\"Valider\"}},\"consumption\":{\"display_last_data\":\"Voir mes dernières consos\",\"accessibility\":{\"button_previous_period\":\"Afficher la période précédente\",\"button_next_period\":\"Afficher la période suivante\",\"button_previous_value\":\"Sélectionner la valeur précédente\",\"button_next_value\":\"Sélectionner la valeur suivante\",\"checkbox_compare\":\"Afficher ou cacher la comparaison\"},\"partner_issue_modal\":{\"title\":\"Attention !\",\"error_connect_gaz\":\"La connexion à vos données de <span class='gaz'>gaz</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='gaz'>GRDF</span> ou dans notre service)\",\"error_connect_elec\":\"La connexion à vos données d'<span class='elec'>électricité</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='elec'>Enedis</span> ou dans notre service)\",\"error_connect_water\":\"La connexion à vos données d'<span class='water'>eau</span> est actuellement dysfonctionnelle (Maintenance chez notre partenaire <span class='water'>Eau Publique du Grand Lyon</span> ou dans notre service)\",\"additional_text\":\"La visualisation et/ou la connexion à vos données de consommation peut s'en trouver affectée.<br /><br /><i>Merci pour votre patience en attendant un retour à la normale :)</i>\",\"ok\":\"Ok\"},\"compared\":\"Comparé\"},\"consumption_details\":{\"detail\":\"Détail par fluide\",\"connect\":\"Connecter d'autres fluides\",\"mini_cards_label\":\"AUTRES ENERGIES\"},\"consumption_visualizer\":{\"missing_data\":\"Données manquantes\",\"no_data\":\"Pas de données\",\"why_no_data\":\"Pourquoi n'ai-je pas de données ?\",\"last_data\":\"Dernières données\",\"last_valid_data\":\"Dernières données valides\",\"last_available_data\":\"Dernières données disponibles\",\"last_valid_data_multi\":\"Dernières données complètes\",\"data_to_come\":\"à venir\",\"aie\":\"Aïe !\",\"data_empty\":\"Vide\",\"estimated\":\"estimés\",\"dataModal\":{\"list_title\":\"3 raisons possibles :\",\"item1\":\"le lien entre Ecolyo et le fournisseur de données est rompu : une mise à jour de ce lien (en bas de la page) peut résoudre ce problème.\",\"item2\":\"un problème technique chez votre gestionnaire : se connecter directement chez ce gestionnaire pour vérifier que cette donnée apparaît.\",\"item3\":\"pour le gaz : vous n'avez pas autorisé Ecolyo à accéder aux données de consommation de cette période.\",\"item4\":\"vous n'aviez tout simplement pas de compteur communicant à l'époque !\"},\"modal\":{\"window_title\":\"info estimation des prix\",\"title\":\"Comment sont estimés les prix ?\",\"close\":\"Fermer la fenêtre\",\"part1\":\"Le prix de votre électricité ou de votre gaz dépend de l'offre choisie auprès de votre fournisseur. N’ayant pas accès à cette information, Ecolyo affiche un prix moyen par fluide. \",\"part2\":\"Tarifs moyens retenus :\",\"list1\":\" : 1 kWh = %{elecPrice} €TTC (il correspond au tarif réglementé d’EDF au %{elecPriceStartDate} pour une puissance souscrite de 3 ou 6 kVA et hors offre heure pleine/heure creuse)\",\"list2\":\" : 1 kWh = %{gasPrice} €TTC (tarif réglementé de vente au %{gasPriceStartDate} pour un consommateur soutirant moins de 6 MWh par an)\",\"list3\":\" : 1 litre d’eau = %{waterPrice} € TTC (prix constaté au %{waterPriceStartDate} pour un abonnement et une consommation de 120 m3/an sur la Métropole de Lyon)\",\"part3\":\"Le coût de votre abonnement n'est pas pris en compte dans Ecolyo.\"},\"release_notes_modal\":{\"title\":\"Du nouveau sur Ecolyo !\",\"message\":\"Les mises à jour suivantes ont été effectuées sur votre application :\",\"go_back\":\"J'ai compris\",\"accessibility\":{\"window_title\":\"Fenêtre de notifications\",\"button_go_back\":\"J'ai compris\"}}},\"ecogestures\":{\"loading\":\"Chargement des astuces\"},\"duel\":{\"global_error\":\"Oups. Une erreur est survenue. Veuillez retourner à l'écran d’accueil des défis\",\"button_go_back\":\"Retour\",\"average_info\":\"%{average} euros étant votre moyenne actuelle, relevez-vous le défi ?\",\"button_start\":\"Allons-y !\",\"goal1\":\"Faites moins que votre moyenne actuelle sur %{durationInDays} jours\",\"goal2\":\"pour gagner le badge %{title}\",\"goal_done\":\"Duel remporté\",\"goal_failed\":\"Duel perdu\",\"caption_average\":\"Votre moyenne à titre indicatif\",\"caption_consumption\":\"Votre consommation\",\"caption_incoming\":\"Données à venir\",\"accessibility\":{\"button_go_back\":\"Retour\",\"button_start_duel\":\"Lancer le duel\",\"button_start_quiz\":\"Lancer le quiz\"}},\"duel_result_modal\":{\"sucess\":{\"title\":\"Félicitations !\",\"message1\":\"Vous avez économisé \",\"message2\":\"et gagné le badge \",\"button_validate\":\"Youpi !\"},\"lost\":{\"title\":\"Presque !\",\"message1\":\"Vous avez dépassé de \",\"message2\":\"et manqué le badge \",\"button_validate\":\"Zut alors !\"},\"accessibility\":{\"window_title\":\"Fenêtre de résultat\",\"button_validate\":\"Valider\"}},\"last_duel_modal\":{\"title\":\"Félicitations !\",\"subtitle\":\"Vous avez terminé tous les défis !\",\"message1\":\"Nous travaillons actuellement à vous proposer de nouveaux défis.\",\"message2\":\"Vous pouvez donner votre avis sur ce que vous aimeriez en cliquant sur la bulle d'aide.\"},\"duel_empty_value_modal\":{\"title\":\"Oups !\",\"message\":\"Impossible de lancer le duel. Il nous manque en effet certaines de vos données de consommation pour vous proposer un duel à votre hauteur.\",\"button\":\"Je retourne au menu des défis\",\"accessibility\":{\"window_title\":\"Fenêtre d'erreur\",\"button_validate\":\"Retourner au menu des défis\"}},\"ecogesture\":{\"title_tab_0\":\"Objectifs\",\"title_tab_1\":\"Je fais déjà\",\"title_tab_2\":\"Toutes\",\"MENU_TITLE\":\"Filtrer\",\"ALL\":\"Tous les usages\",\"HEATING\":\"Chauffage\",\"AIR_CONDITIONING\":\"Climatisation\",\"ECS\":\"Eau chaude\",\"COLD_WATER\":\"Eau froide\",\"ELECTRICITY_SPECIFIC\":\"Électricité courante\",\"COOKING\":\"Cuisson\",\"selection\":\"Sélectionner les astuces les plus adaptées à votre consommation\",\"selection_2\":\"vues sur\",\"button_selection\":\"Continuer ma sélection\",\"no_ecogesture\":\"Aucune astuce ne correspond à votre filtrage\",\"no_ecogesture_filter\":{\"text1\":\"Nous n'avons pas trouvé d'astuces adaptées à votre profil dans cette catégorie.\",\"text2\":\"En effet, de par votre profil et vos modes de chauffage, d'eau ou d'eau chaude sanitaire, nous n'avons pas identifié d’astuces vous permettant de diminuer vos factures à titre individuel. Toutefois, vous pouvez toujours agir pour préserver les ressources en appliquant et diffusant autour de vous les autres bonnes pratiques présentées dans la partie \\\"Toutes les astuces\\\".\"},\"adjust_profil\":{\"description\":\"Pour une sélection d’astuces adaptée à votre consommation, vous pouvez ajuster votre profil.\",\"button_go_to_profil\":\"Ajuster mon profil\"},\"accessibility\":{\"window_title\":\"Fenêtre d'information'\",\"button_close\":\"Fermer la fenêtre\",\"button_selection\":\"Aller à la page de sélection\"},\"doing\":\"Je fais déjà\",\"objective\":\"Objectif\",\"emptyList\":{\"obj1\":\"Les astuces présentées sont des actions qui vous permettent de réduire vos consommations et donc vos factures. On parle parfois d’écogestes.\",\"obj1_done\":\"Aucune astuce n’a été sélectionnée comme objectif actuellement.\",\"obj2\":\"Vous pouvez sélectionner ceux à mettre en objectifs et ceux que vous appliquez déjà.\",\"obj2_done\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous souhaitez garder en objectif dans cette section.\",\"doing1\":\"Aucune astuce n’a été sélectionnée dans la catégorie appliquée actuellement.\",\"doing1_done\":\"Aucune astuce n’est indiquée comme déjà appliquée actuellement.\",\"doing2\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous mettez déjà en pratique dans cette section.\",\"doing2_done\":\"Vous pouvez consulter toutes les astuces et ajouter celles que vous mettez déjà en pratique dans cette section.\",\"btn1\":\"Voir toutes les astuces\",\"btn2\":\"Sélectionner\"},\"initModal\":{\"title\":\"Sélectionner mes astuces\",\"text1\":\"Les astuces présentées sont des actions qui vous permettent de réduire vos consommations et donc vos factures. On parle parfois d’écogestes \",\"text2\":\"Vous pouvez sélectionner celles à mettre en objectifs et celles que vous appliquez déjà.\",\"text3\":\"Afin de pré-sélectionner les astuces correspondant à votre consommation, merci de répondre à quelques rapides questions.\",\"btn1\":\"Plus tard\",\"btn2\":\"C'est parti !\"},\"reinit\":\"Réinitialiser ma sélection\",\"reinitModal\":{\"title_part1\":\"Cette action\",\"title_part2\":\"supprimera votre liste d’astuces\",\"title_part3\":\"sélectionnées dans\",\"title_part4\":\"“Objectifs”\",\"title_part5\":\"et\",\"title_part6\":\"“Je fais déjà”\",\"text1\":\"Vous pourrez ensuite faire une nouvelle sélection adaptée à votre consommation.\",\"text2\":\"Souhaitez-vous réinitialiser votre sélection d’astuces ?\",\"btn1\":\"Non\",\"btn2\":\"Réinitialiser\"}},\"ecogesture_modal\":{\"title_ecogesture\":\"Astuce\",\"title_action\":\"Action\",\"efficiency\":\"Efficacité\",\"show_less\":\"Voir moins d’infos\",\"show_more\":\"Voir plus d’infos\",\"select_action\":\"Je choisis cette action\",\"accessibility\":{\"window_title_ecogesture\":\"Fenêtre astuce\",\"window_title_action\":\"Fenêtre action\",\"button_close\":\"Fermer la fenêtre\",\"button_select_action\":\"Sélectionner cette action\",\"button_see_more_detail\":\"Afficher plus de détails\"}},\"ecogesture_info_modal\":{\"header\":\"Comment sont choisis les astuces adaptées à mon profil ?\",\"text\":\"Les astuces adaptés à votre profil sont aujourd’hui choisies en fonction des compteurs individuels que vous possédez (communicants ou non). Ceux présentés ici vous permettent d'agir sur vos consommations individuelles. Des modes de tri plus personnalisables seront proposés à l'avenir.\",\"button_close\":\"J'ai compris\",\"accessibility\":{\"window_title\":\"Fenêtre d'information\",\"button_close\":\"Fermer la fenêtre\"}},\"ecogesture_form\":{\"heating_type\":{\"title\":\"Chauffage\",\"question\":\"Quel est votre type de chauffage ?\",\"individual\":\"Individuel\",\"collective\":\"Collectif\"},\"warming_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Bois\",\"4\":\"Fioul\",\"title\":\"Source chauffage\",\"question\":\"Quelle source d’énergie principale utilisez-vous pour votre chauffage ?\"},\"hot_water_type\":{\"title\":\"Eau chaude\",\"question\":\"Quel est votre type de production d’eau chaude ?\",\"individual\":\"Individuelle\",\"collective\":\"Collective\"}},\"ecogesture_profile\":{\"equipments\":{\"question\":\"Quels équipements possédez-vous ?\",\"hint\":\"Plusieurs réponses possibles\",\"air_conditioning\":\"Climatisation\",\"computer\":\"Ordinateur\",\"microwave\":\"Micro-ondes\",\"oven\":\"Four\",\"washing_machine\":\"Lave-linge\",\"dishwasher\":\"Lave-vaisselle\",\"cooking_plates\":\"Plaques électriques\",\"garden\":\"Jardin\",\"dryer\":\"Sèche-linge\",\"refregirator\":\"Réfrigérateur\",\"fan\":\"Ventilateur\",\"water_heater\":\"Chauffe-eau\",\"curtain\":\"Rideaux\",\"internet_box\":\"Box internet\",\"ventilation\":\"VMC\",\"freezer\":\"Congélateur\",\"boiler\":\"Chaudière\",\"hydraulic_heating\":\"Chauffage hydraulique\"}},\"ecogesture_selection\":{\"header\":\"Sélection des astuces\",\"title\":\"Vous avez parcouru un groupe de %{smart_count} astuces\",\"text\":\"Voulez-vous continuer sur votre lancée ou remettre cette sélection à plus tard ?\",\"title_final\":\"Félicitations !\",\"text_final_1\":\"Vous avez terminé la sélection des astuces adaptées à votre consommation.\",\"text_final_2\":\"Vous pouvez les retrouver dans les sections “Objectifs” et “Je fais déjà” selon que vous les pratiquiez déjà ou non.\",\"button_go_to_ecogesture\":\"Plus tard\",\"button_ok\":\"J'ai compris\",\"button_continue\":\"Poursuivre\",\"button_objective\":\"Objectif\",\"button_doing\":\"Je fais déjà\",\"button_skip\":\"Pas intéressé\",\"accessibility\":{\"window_title\":\"Fenêtre d'information'\",\"button_close\":\"Fermer la fenêtre\",\"button_go_to_ecogesture\":\"Retourner aux astuces\",\"button_continue\":\"Poursuivre\",\"button_ok\":\"Fermer la sélection\"},\"selectionModal\":{\"title\":\"Des astuces correspondant à votre profil ont été trouvées !\",\"text\":\"À vous de choisir celles que vous souhaitez mettre en objectif et celles que vous faites déjà.\",\"button_close\":\"C'est parti !\"}},\"exploration\":{\"global_error\":\"Oups. Une erreur est survenue. Veuillez retourner à l'écran d’accueil des défis\",\"button_go_back\":\"Retour\",\"button_already_done\":\"C’est déjà fait !\",\"button_come_back\":\"Je reviens quand cela sera fait\",\"button_start\":\"C'est parti !\",\"watch_consumption\":\"Je fonce\",\"congratulation\":\"Bravo !\",\"earn\":\"Vous remportez\",\"button_confirm\":\"Ok\",\"interval\":{\"explanation\":\"Vous pouvez vérifier cette informations sur l'écran Conso.\"},\"accessibility\":{\"button_already_done\":\"Marquer l'exploration comme déjà réalisée\",\"button_confirm\":\"Valider\",\"button_come_back\":\"Fermer l'exploration\",\"button_go_back\":\"Retour\",\"button_start\":\"Lancer l'exploration\"}},\"error_page\":{\"main\":\"Erreur\",\"back\":\"Retour\",\"no_ecogesture\":\"Oups ! Nous n'avons pas trouvé l'astuce demandée.\"},\"help\":{\"title_help\":\"une question ? un problème ? une suggestion ?\",\"read_help\":\"Nous écrire via le Service d'Assistance Utilisateur\"},\"feedback\":{\"title\":\"Vous allez contacter le Service Assistance Utilisateur du Grand Lyon.\",\"text1\":\"Vous pourrez nous remonter un problème, chercher de l'aide pour vous connecter plus facilement, ou encore nous partager une bonne idée d'évolution.\",\"text2\":\"N'hésitez pas à nous écrire ! L'équipe Ecolyo vous répondra avec plaisir :)\",\"later\":\"Plus tard\",\"lets_go\":\"J'y vais\",\"accessibility\":{\"window_title\":\"Fenêtre de partage de retours\",\"button_close\":\"Fermer la fenêtre de partage de retours\"}},\"dataShare\":{\"title1\":\"Bienvenue !\",\"title1Update\":\"Ecolyo évolue !\",\"title2Update\":\"Pour continuer à utiliser Ecolyo, merci d’accepter les modalités de traitement des données ci-dessous.\",\"part1\":\"Pour le bon fonctionnement du service, nous avons besoin de l’adresse email utilisée lors la création de votre cloud personnel Grand Lyon.\",\"part2\":\"Cette donnée de compte est conservée dans Ecolyo le temps de l’utilisation de ce service.\",\"part3\":\"La Métropole de Lyon utilisera cet email afin de vous tenir informé·e :\",\"item1\":\"En réponse à vos demandes, si vous avez pris l’initiative de nous contacter.\",\"item2\":\"En cas de problème majeur avec la gestion de votre compte.\",\"item3\":\"De l’évolution de vos consommations, des nouveautés et  de la qualité du service via une lettre mensuelle. Vous pouvez à tout moment vous désinscrire de cette lettre via la page Options du service.\",\"part4\":\"Vos données privées de consommation d’énergie et d’eau sont récupérées, sauvegardées et stockées dans votre cloud personnel à votre initiative sans visibilité de la Métropole  de Lyon sur leur contenu.\",\"part5\":\"Il en est de même pour les données privées de composition du logement et du foyer, fournies par vos soins. Elles restent également sans visibilité de la Métropole de Lyon sur leur contenu.\\nLes données d’identification entrées lors de la connexion aux données de consommations d’électricité sont quant à elles conservées dans un espace sécurisé de la Métropole de Lyon et sont utilisées uniquement à des fins de contrôle du consentement par des organismes extérieurs.\",\"part6\":\"Dans le cadre de l’évaluation et de l’amélioration du service, des données d’utilisation anonymisées et pseudonymisées seront remontées à des fins d’exploitation statistiques. La récupération de ces statistiques nous permettra de s’assurer du bon fonctionnement technique de la connexion à vos données de consommation, d’évaluer globalement l’usage de l’application via des mesures d’audience ainsi que d’évaluer à terme l’impact global en termes de baisse des consommations énergétiques de notre service.\",\"part7\":\"Au sein de votre cloud personnel, vous pouvez à tout moment exercer vos droits d’accès, de rectification, de portabilité, de limitation et d’opposition en consultant notamment la page Options.\",\"part8\":\"Vous pouvez également exercer vos droits d’accès, de rectification, de limitation, d’opposition et d’effacement de vos données personnelles en contactant directement le Délégué à la Protection des Données par courrier en écrivant à l’adresse :\",\"part9\":\"Métropole de Lyon – Délégué à la Protection des Données - Direction des Assemblées, des Affaires Juridiques et des Assurances - 20, rue du Lac - BP 33569 - 69505 Lyon Cedex 03 \",\"part10\":\"ou en ligne, au moyen du formulaire disponible à l'adresse suivante : \",\"link1\":\"<a href=\\\"https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/\\\">https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/</a>\",\"validDataConsent\":\"Je consens au traitement de mes données tel que décrit ci-dessus.\",\"validCGU\":\"Je valide les <span class=\\\"action\\\">Conditions Générales d’Utilisation</span> \",\"validLegal\":\" du service et ai pris connaissance des <span class=\\\"action\\\"> Mentions Légales </span> de celui-ci.\",\"button_accept\":\"C'est parti !\",\"accessibility\":{\"button_accept\":\"Accepter les conditions générales d'utilisation\"}},\"minorUpdate\":{\"title\":\"Ecolyo évolue !\",\"button\":\"J'ai compris\"},\"gcu\":{\"title\":\"Conditions générales d’utilisation du service\",\"version\":\"Version du 12.12.2022\",\"content\":{\"title1\":\"Ecolyo, késako ?\",\"part1_1\":\"Ecolyo est un service proposé par la Métropole de Lyon vous permettant de suivre au même endroit vos consommations d’électricité, de gaz et d’eau, en kWh, en litres, en euros et à différentes échelles de temps. Ce service vous permet également de participer à des défis individuels et vous offre une analyse de vos consommations. Des astuces vous sont aussi proposées afin de vous permettre de réduire vos consommations.\",\"part1_2\":\"C’est un service gratuit qui prend la forme d’un site web dit « responsive », c’est-à-dire qu’il peut être consulté sur ordinateur ou sur mobile. Sur mobile, c’est une application que l’on a souhaitée ergonomique, réactive et esthétique pour votre plaisir de navigation et d’utilisation au quotidien.\",\"part1_3\":\"Tous les termes « techniques » sont définis en bas de page.\",\"title2\":\"Quelles fonctionnalités le service propose-t-il ?\",\"part2_1\":\"La fonctionnalité principale d’Ecolyo est la visualisation, au même endroit, de vos consommations d’électricité, de gaz et d’eau et ce, à différents pas de temps (de la demi-heure – uniquement pour l’électricité, à plusieurs années, en passant par les pas de temps journaliers et mensuels). La visualisation des consommations se fait en kWh pour l’énergie et en L pour l’eau ainsi qu’en euros (euros résultant d’un prix moyenné).\",\"part2_2\":\"Au-delà de la visualisation de vos consommations et parce que nous souhaitons vous aider à diminuer ces consommations vous retrouverez plusieurs autres pages : \",\"part2_2_list1\":\"Défis : Des quiz, et actions à mettre en place vous seront proposés pour vous pousser à réduire vos consommations.\",\"part2_2_list2\":\"Astuces : Une liste d’astuces pour maîtriser ses consommations d’énergie et d’eau à trier par usage, et avec une possibilité de les adapter plus précisément à votre profil.\",\"part2_2_list3\":\"Analyse : Une analyse de vos consommations réelles en comparaison à celle d’un foyer étant proche d’une vôtre.\",\"part2_3\":\"Pour la page Analyse ainsi que pour la partie personnalisation des astuces, des éléments supplémentaires sur votre profil vous seront demandés. L’ensemble de ces informations récoltées à l’aide du formulaire peuvent être modifiées par la suite.\",\"part2_4\":\"Dernière page : la page Options dans laquelle vous pourrez vous abonner à un service d’alerte sur vos consommations d’eau, de quoi ajuster votre profil ou encore vous désabonner de la lettre mensuelle.\",\"title3\":\"Comment ai-je accès à mes données d’électricité, de gaz et d’eau ?\",\"part3_1\":\"Pour visualiser vos consommations réelles et profiter pleinement du potentiel de notre service, il vous faut au minimum un des trois compteurs communicants suivants : Linky (pour l’électricité), Gazpar (pour le gaz), Téléo (pour l’eau).\",\"part3_2\":\"Ces compteurs sont opérés par les gestionnaires de réseaux. Pour Linky, c’est Enedis, le gestionnaire de réseau de distribution d’électricité. Pour Gazpar, GRDF est responsable de cette gestion. Et pour Téléo, c’est Eau Publique du Grand Lyon.\",\"part3_3\":\"Ces acteurs sont responsables de la relève de vos données. Ces données servent notamment à votre fournisseur d’électricité, de gaz ou d’eau pour permettre la facturation de vos consommations d’énergie. Des fournisseurs d’électricité ou de gaz il y en a des dizaines. Les gestionnaires de réseaux (… et de votre compteur) ne sont qu’au nombre de trois. Nous avons donc décidé de travailler avec eux, au plus près de la donnée brute issue de vos compteurs.\",\"part3_4\":\"Il vous faudra donc avoir un compte chez GRDF et Eau Publique du Grand Lyon pour accéder à vos données. Si vous n’en avez pas, il suffira de vous en créer un. Ceci ne sera à faire qu’une fois, au début.\",\"title4\":\"Ecolyo se trouve dans un cloud personnel Grand Lyon, qu’est-ce que cela signifie ?\",\"part4_1\":\"Comme vous avez dû le remarquer, lors de votre première connexion à Ecolyo vous avez dû vous créer un compte Cloud Personnel Grand Lyon. Ce cloud personnel est un espace sécurisé porté par l’ambition de vous apporter visibilité, transparence et maîtrise sur l’usage de vos données personnelles, et dont les fonctionnalités vous permettant de récupérer, synchroniser, stocker et partager vos données avec les destinataires de votre choix.  Le service Ecolyo se déploie  à l’intérieur de cet espace protégé. Dans ce cloud personnel, vous pourrez accéder également à d’autres services. Toutes les données traitées par Ecolyo, mais aussi les autres services que vous seriez amenés à utiliser dans ce cloud personnel restent dans ce Cloud Personnel Grand Lyon et n’en sortent pas, sauf si vous décidez vous-même de partager vos données avec des tiers.\",\"part4_2\":\"Pour en savoir plus sur ce cloud et son utilisation, ainsi que la durée de conservation de vos données, vous pouvez lire les conditions générales d’utilisation du service <a href=\\\"https://manager.cozygrandlyon.cloud/tos/266b4226-8417-42fb-b911-41e86dae8581.pdf?locale=fr\\\">ici</a>.\",\"title5\":\"Et donc concrètement pour Ecolyo, quelles données sont collectées et qui y a accès ?\",\"part5_1\":\"Pour qu’Ecolyo ait accès à vos données de consommations, vous devrez activer vos différents connecteurs. À ce moment-là, pour la connexion aux données de gaz et d’eau à travers un parcours qui vous conduira de manière intuitive sur le site de chacun des gestionnaires de réseaux concerné, vous pourrez donner votre consentement à partager ces données avec le Service Ecolyo, et ce pour une durée limitée dans le temps. Pour l’électricité, le don du consentement et la connexion aux données se fait directement dans notre service. Quid de la durée de ce consentement ? Pour les données électriques, elle est par défaut d'un an. Pour les données gaz, cela sera à vous de la définir (nous vous recommandons 1 an pour une expérience optimale). Les données utilisées pour vérifier la bonne connexion de vos données d’électricité sont stockées du côté de la Métropole de Lyon sur des serveurs sécurisés.\",\"part5_2\":\"Vos connecteurs, une fois configurés, permettent le transfert de vos données de consommations au service Ecolyo. Le transfert de ces données de consommation se fait sans que personne n’accède à leur contenu, pas même la Métropole de Lyon. En effet, ces données sont stockées et traitées directement dans votre cloud personnel qui en assure la protection. Tous les calculs, analyses et traitements sur ces données sont faites DANS votre espace personnel sans visibilité sur le contenu des données par la Métropole de Lyon.\",\"part5_3\":\"Vous pouvez bien sûr mettre fin à la récupération/ au transfert de vos données de consommation sur votre espace cloud personnel à tout moment et  à plusieurs niveaux : \",\"part5_3_list1\":\"Vous pouvez supprimer le transfert quotidien de vos données en supprimant tout simplement le connecteur dans la page Consos (en bas).\",\"part5_3_list2\":\"Pour supprimer l’ensemble de vos données ainsi que votre espace personnel Grand Lyon, vous devez demander la suppression de votre cloud. Pour faire cela, rendez-vous dans les paramètres de votre cloud personnel via la barre blanche en haut d’Ecolyo et appuyez sur le bouton « Supprimer mon compte » dans la partie paramètres.\",\"part5_4\":\"Des données sur le profil de votre foyer peuvent être également remplies au sein de l’application. Ces données s’enrichiront au fur et à mesure de votre utilisation du service avec d’autres informations : défis réalisés, étoiles gagnées, etc. L’ensemble de ces données restent à l’intérieur de votre cloud personnel, sans que personne n’y ait accès.\",\"part5_5\":\"Enfin, afin de permettre une mise à jour quotidienne de vos données de consommations, vos identifiants Eau Publique du Grand Lyon, un jeton d’identification GRDF ainsi que vos numéros de compteurs sont stockés.\",\"title6\":\"Personne n’a donc accès à mes données, pas même la Métropole de Lyon, vraiment ?\",\"part6_1\":\"Conformément aux indications du paragraphe précédent, la Métropole de Lyon n’accède ni à vos données de consommations ni aux données utilisées via certaines fonctionnalités du service comme le formulaire (celui-là même qui permet l’analyse de vos consommations personnalisée ainsi qu’une sélection d’éco-gestes personnalisés). Toutes ces informations sont bien gardées au chaud dans votre cloud personnel Grand Lyon.\",\"part6_2\":\"Seul vous pouvez accepter de partager vos données, documents ou fichiers privés avec la Métropole de Lyon, ses partenaires ou d’autres utilisateurs ou acteurs (publics ou privés) après recueil de votre consentement éclairé et par une action expresse de votre part.\",\"part6_3\":\"La Métropole de Lyon n'a cependant accès qu’à l’adresse email utilisée lors la création de votre cloud personnel Grand Lyon. Elle utilise cet email afin de vous tenir informé·e :\",\"part6_3_list1\":\"En réponse à vos demandes, si vous avez pris l’initiative de nous contacter. \",\"part6_3_list2\":\"En cas de problème majeur avec la gestion de votre compte.\",\"part6_3_list3\":\"De l’évolution de vos consommations, des nouveautés et  de la qualité du service via une lettre mensuelle. Vous pouvez à tout moment vous désinscrire de cette lettre via la page Options du service.\",\"part6_4\":\"Elle stocke également les informations transmises lors de la connexion à l’électricité (nom, adresse postale). Ces informations doivent être stockées car la Métropole de Lyon est régulièrement contrôlée par Enedis et doit prouver détenir le consentement des personnes pour lesquelles elle va chercher la donnée.\",\"part6_5\":\"Par ailleurs, et dans le cadre de l’évaluation et de l’amélioration du service, des données d’utilisation anonymisées seront remontées à des fins d’exploitation statistiques. La récupération de ces statistiques anonymisées nous permettra de s’assurer du bon fonctionnement technique de la connexion à vos données de consommation ainsi que d’évaluer l’impact global en termes de baisse des consommations énergétiques de notre service. Parmi ces statistiques, des mesures d’audience de la fréquentation des différentes pages du service sont réalisées. Vous pouvez, via la page Options, à tout instant, décider de vous opposer à la récupération de ces données d’utilisation.\",\"title8\":\"Encore des questions ?\",\"part8_1\":\"N’hésitez pas à consulter la FAQ ou à nous contacter via le formulaire de contact présente sur l’ensemble des pages.\",\"part8_2\":\"Dernière option, contactez-nous directement à <a href=\\\"mailto:ecolyo@grandlyon.com\\\">ecolyo(at)grandlyon.com</a>.\",\"title9\":\"LEXIQUE\",\"part9_1_title\":\"Cloud personnel Grand Lyon : \",\"part9_1_content\":\"Cloud personnel : appelé aussi le « domicile numérique », le cloud personnel est souvent réduit à un simple espace de stockage de documents mais il est bien plus que ça. C'est un espace individuel et sécurisé où vous pouvez accéder à des services sans exposer aucune donnée à l’extérieur. Vous seul pouvez y accéder, personne d'autre.\",\"part9_2_title\":\"Connecteur : \",\"part9_2_content\":\"Un connecteur est un service, installé dans votre cloud personnel également, qui a pour but uniquement d’aller récupérer les données auprès de différents partenaires/sources de données. Dans le cadre d’Ecolyo, trois connecteurs sont pré-installés dans votre cloud personnel : celui d’Enedis, celui de GRDF et celui d’Eau Publique du Grand Lyon.\",\"part9_3_title\":\"Compteur communicant : \",\"part9_3_content\":\"Un compteur communicant est un compteur qui mesure de manière précise et détaillée vos consommations et peut transmettre ces données  au gestionnaire de réseau via une technologie radio (c'est le cas pour Gazpar et Téléo par exemple) ou via les réseaux électriques (via Courant Porteur en ligne, c'est le cas pour Linky par exemple).\",\"part9_4_title\":\"Fournisseur : \",\"part9_4_content\":\"Votre fournisseur d’électricité, de gaz ou d’eau est l’entreprise qui vous facture votre électricité, gaz ou eau. Côté électricité il en existe <a href=\\\"https://www.enedis.fr/liste-des-fournisseurs-delectricite\\\">aujourd’hui plus de 50</a>, chacun proposant des tarifs différents.\",\"part9_5_title\":\"Gestionnaire de réseau de distribution : \",\"part9_5_content\":\"Appelé aussi parfois distributeur, il est en charge de la livraison de votre électricité, gaz ou eau jusqu’à votre domicile. Il est aussi en charge du compteur qui relève vos consommations. Il transmet vos données de consommations à votre fournisseur afin qu’il effectue la facturation de vos consommations d’énergie. Il peut également les transmettre à tout acteur avec qui vous avez décidé de partager ces données.\"}},\"gcu_modal\":{\"button_accept\":\"J'accepte\",\"accessibility\":{\"window_title\":\"Conditions générales d’utilisation\",\"button_accept\":\"Accepter les conditions générales d'utilisation\"}},\"matomo\":{\"matomo_title\":\"Suivi statistiques d'usage Matomo\"},\"header\":{\"accessibility\":{\"button_back\":\"Retour à la page précédente\",\"button_open_feedbacks\":\"Ouvrir le partage de retours\"}},\"konnector_form\":{\"label_updated_at\":\"Dernière mise-à-jour le\",\"button_update\":\"Mettre à jour\",\"loading\":\"Chargement...\",\"wait_end_issue\":\"Attendre la fin de la maintenance avant de mettre à jour.\",\"button_delete\":\"Supprimer\",\"issue\":\"Le problème semble venir de \",\"resolve\":\"Une mise à jour peut résoudre ce problème.\",\"login_failed\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"not_installed\":\"Le connecteur n'est pas installé. Veuillez l'installer en cliquant sur le bouton ci-dessous.\",\"button_install\":\"Installer\",\"error_account_creation\":\"Une erreur est survenue, veuillez essayer de nouveau.\",\"error_no_login_password\":\"Identifiant et mot de passe requis\",\"error_login_failed\":\"Identifiants invalides\",\"error_update\":\"Un problème est survenu lors du rapatriement de vos données.\",\"error_update_oauth\":\"Votre autorisation pour afficher vos données %{fluid} a expiré.\",\"error_consent_form_gas\":\"Vos données ne peuvent être récupérées car vous n'avez pas coché l'autorisation d'accès aux données informatives lors de votre partage de consentement.\",\"button_oauth_reload\":\"Redonner mon consentement\",\"OK\":\"Ok\",\"konnector_delta\":{\"ELECTRICITY\":\"La donnée de consommation électrique arrive normalement à J+1. Un retard d'un ou deux jours est parfois constaté.\",\"GAS\":\"La donnée de consommation de gaz arrive normalement à J+3. Un retard d'un ou deux jours est parfois constaté.\",\"WATER\":\"La donnée de consommation d'eau arrive normalement à J+3. Un retard d'un ou deux jours est parfois constaté.\"},\"accessibility\":{\"button_install\":\"Installer le connecteur\",\"button_update\":\"Mettre à jour votre connexion\",\"button_delete\":\"Supprimer votre connexion\"}},\"konnector_options\":{\"label_connect_to_electricity\":\"Se connecter à l'électricité\",\"label_connect_to_water\":\"Se connecter à l'eau\",\"label_connect_to_gas\":\"Se connecter au gaz\",\"label_offline_electricity\":\"Électricité déconnectée\",\"label_offline_water\":\"Eau déconnectée\",\"label_offline_gas\":\"Gaz déconnecté\",\"partner_issue\":\"En maintenance\",\"outdated\":\"Données manquantes depuis %{isOutdatedData} jours\",\"accessibility\":{\"label_ko_status\":\"Connecteur en erreur\",\"button_toggle_detail_electricity\":\"Afficher ou masquer le détail de la connexion à l'électricité\",\"button_toggle_detail_water\":\"Afficher ou masquer le détail de la connexion à l'eau\",\"button_toggle_detail_gas\":\"Afficher ou masquer le détail de la connexion au gaz\"}},\"konnector_modal\":{\"loading_data\":\"Veuillez patienter, vos données sont en cours de chargement.\",\"loading_data_update\":\"Veuillez patienter, vos données sont en cours de mise à jour.\",\"logging_txt\":\"Nous vérifions vos informations d'identité\",\"success_txt\":\"Félicitations !\",\"success_data_electricity\":\"Vos données de consommation d'électricité sont maintenant connectées à Ecolyo.\",\"success_data_water\":\"Vos données de consommation d'eau sont maintenant connectées à Ecolyo.\",\"success_data_gas\":\"Vos données de consommation de gaz sont maintenant connectées à Ecolyo.\",\"success_data_additional_electricity\":\"Les données de consommations mettent entre un et deux jours pour arriver.\",\"success_data_additional_water\":\"Les données de consommations mettent entre trois et cinq jours pour arriver.\",\"success_data_additional_gas\":\"Les données de consommations mettent entre trois et cinq jours pour arriver.\",\"success_update_txt\":\"Connexion réussie !\",\"success_data_update_electricity\":\"Ecolyo est bien connecté à votre compteur d'électricité.\",\"success_data_update_water\":\"Ecolyo est bien connecté à votre compteur d'eau.\",\"success_data_update_gas\":\"Ecolyo est bien connecté à votre compteur de gaz.\",\"success_data_additional_update_electricity\":\"Sachez que la donnée de consommation d'électricité arrive entre J+1 et J+2.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"success_data_additional_update_water\":\"Sachez que la donnée de consommation d'eau arrive entre J+3 et J+5.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"success_data_additional_update_gas\":\"Sachez que la donnée de consommation de gaz arrive entre J+3 et J+5.<br /><br />S'il vous manque encore des données, c'est qu'elles n'ont pas encore été mises à disposition par le gestionnaire de votre compteur. Merci pour votre patience !\",\"error_txt\":\"Aïe !\",\"mismatch\":{\"title\":\"Vos données n'ont pas pu être récupérées.\",\"text1\":\"Vos nom et numéro de compteur ne correspondent plus. Merci de reconfigurer votre connecteur.\",\"text2\":\"Reconfigurer mon connecteur ?\",\"text3\":\"La reconfiguration de votre connecteur passe par sa suppression et sa nouvelle installation. Vos données seront conservées.\"},\"error_data_electricity\":\"Un problème est survenu. Vos données de consommation d’électricité ne seront pas chargées.\",\"error_data_water\":\"Un problème est survenu. Vos données de consommation d’eau ne seront pas chargées.\",\"error_credentials_water\":\"Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter. L'identifiant est un numéro à 7 chiffres (différent de votre numéro de contrat).\",\"error_credentials_electricity\":\"Il semblerait que les nom(s) et adresse ne concordent pas avec le numéro de votre compteur.\",\"error_credentials_electricity_2\":\"Nous ne pouvons vous donner accès aux données de consommation.\",\"error_credentials_update_water\":\"Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter.\",\"error_credentials_update_electricity\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"error_credentials_update_gas\":\"Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.\",\"error_data_gas\":\"Un problème est survenu. Vos données de consommation de gaz ne seront pas chargées.\",\"error_consent_form_gas_title\":\"Nous n'avons pas pu connecter vos données de consommation de gaz à Ecolyo.\",\"error_consent_form_gas_content\":\"En effet, le partage de vos données de consommation de gaz \\\"informatives\\\" doit être accepté.\",\"error_consent_form_gas_content_2\":\"Merci de cocher \\\"OUI\\\" au partage de vos données de consommation de gaz, et à \\\"Autoriser l'accès à mes données informatives\\\".\",\"error_data_update_electricity\":\"Un problème est survenu. Vos données de consommation d’électricité n’ont pas été mises à jour.\",\"error_data_update_water\":\"Un problème est survenu. Vos données de consommation d’eau n’ont pas été mises à jour.\",\"error_data_update_gas\":\"Un problème est survenu. Vos données de consommation de gaz n’ont pas été mises à jour.\",\"error_data_2\":\"Merci de réessayer plus tard.\",\"button_validate\":\"Ok\",\"button_understood\":\"J'ai compris\",\"button_try_again\":\"Réessayer\",\"show_common_error\":\"Voir les erreurs récurrentes\",\"show_common_error_list\":\"<span style=\\\"text-align:left; font-weight:700;\\\">Le problème peut provenir des cas suivants :</span> <ul style=\\\"text-align:left;\\\"><li>Vous avez un co-titulaire sur votre contrat. Veillez à bien entrer le nom du <span style=\\\"color:#E3B82A; font-weight:700;\\\">titulaire du contrat</span> et non le co-titulaire.</li><li>  Votre nom comporte un tiret ? Tentez sans le tiret.</li><li>  Entrez bien le nom de votre commune de résidence en entier (tirets et accents inclus)</li><li>  Avez-vous bien entré le <span style=\\\"color:#E3B82A; font-weight:700;\\\">numéro de votre compteur</span> (PDL) ? Tout autre numéro (de contrat, de client) ne fonctionne pas.</li></ul><p style=\\\"text-align:center; font-style: italic; font-weight:400; font-size: 0.9rem;\\\">Si vous rencontrez toujours des difficultés, contactez notre service d'aide </p><div style=\\\"text-align:center; font-weight:700;\\\">Avez-vous pensez à vérifier ces informations ?</div>\",\"accessibility\":{\"window_title\":\"Fenêtre d'attente de connexion\",\"button_close\":\"Fermer la fenêtre\"}},\"consent_outdated\":{\"title\":{\"0\":\"Votre autorisation pour afficher vos données d’électricité a expiré\",\"2\":\"Votre autorisation pour afficher vos données de gaz a expiré\"},\"text1\":{\"0\":\"Veuillez re-donner votre consentement pour la transmission et la reconnexion de vos données ENEDIS à Ecolyo.\",\"2\":\"Veuillez re-donner votre accord pour que GRDF nous transmette vos données de consommation.\"},\"text2\":{\"0\":\"Souhaitez-vous renouveler votre accord dès maintenant pour un an ?\",\"2\":\"Voulez-vous  donner votre accord sur votre compte GRDF maintenant ?\"},\"later\":\"Plus tard\",\"go\":\"J'y vais\",\"no\":\"Non\",\"yes\":\"Oui\"},\"delete_grdf_modal\":{\"text1\":\"La suppression de la connexion avec GRDF s’accompagne de la suppression de votre consentement à partager vos données gaz avec Ecolyo.\",\"text2\":\"Si vous souhaitez vous reconnecter, il vous faudra re-donner votre accord pour que GRDF nous transmette vos données de consommation.\",\"text3\":\"Voulez-vous  supprimer votre connexion et votre consentement à GRDF ?\",\"cancel\":\"Plus tard\",\"go\":\"Oui\"},\"legal\":{\"read_legal\":\"Lire les mentions légales\",\"title_legal\":\"Mentions légales & CGU\",\"version\":\"Version du 12.12.2022\",\"site\":\"Site du service Ecolyo : <a href=\\\"https://ecolyo.com/\\\"> https://ecolyo.com/</a>\",\"adress\":\"Métropole de Lyon - 20, rue du Lac – CS 33569 - 69505 Lyon cedex 03\",\"phone\":\"Tél : (33) 4 78 63 40 40\",\"mail\":\"<a href=\\\"mailto:ecolyo@grandlyon.com\\\"> ecolyo(at)grandlyon.com</a>\",\"p1b\":\"Directrice de publication : \",\"p1\":\"Blandine MELAY, Responsable du Service Transition Énergétique\",\"p2b\":\"Animation éditoriale, gestion et mise à jour : \",\"p2\":\"Marion BERTHOLON,  Chargée de services numériques pour la transition énergétique\",\"p3b\":\"Photographies : \",\"p3\":\"sauf mention contraire, les photos sont la propriété de la Métropole de Lyon\",\"p4b\":\"Conception et Charte graphique : \",\"p4\":\"Florent Dufier\",\"p5b\":\"Réalisation technique : \",\"p5\":\"Métropole de Lyon, Sopra Steria\",\"p6b\":\"Maintenance technique : \",\"p6\":\"Délégation Développement économique, emploi & savoirs - Innovation numérique & systèmes d’information - Usages et services numériques - Développement des services numériques\",\"title1\":\"Crédits\",\"part1\":\"Ce site est le résultat de développements spécifiques réalisés dans les langages Go, TypeScript, HTML et Sass. Les développements s’appuient sur plusieurs bibliothèques et frameworks libres : axios, cozy-bar, cozy-client, cozy-harvest-lib, cozy-scripts, cozy-ui, d3, detect-browser, global, lodash, luxon, moment, moment-timezone, node-sass, object-hash, react, react-dom, react-redux, react-router-dom, react-swipeable-views, redux-devtools-extension, sass-loader. Les tests de l’application s’appuient sur les bibliothèques et frameworks libres suivants: enzyme, enzyme-adapter-react-16, jest-junit, react-test-renderer, redux-mock-store. La pile technique intègre également les applications Cozy stack, Yarn, Docker, ACH. Les déploiements sont réalisés sur le registre hébergé chez Cozy. L’équipe de réalisation utilise au quotidien les applications GitLab, IceScrum, RocketChat, SonarQube.\",\"title2\":\"Traitement des données personnelles et droit d’accès, de modification et de suppression\",\"part2\":\"Conformément à la réglementation en vigueur en matière de protection des données personnelles, le service Ecolyo a fait l’objet d’une inscription au registre des traitements de la Métropole de Lyon. Ecolyo fait partie de l’écosystème de services orientés « self data » déployés par la Métropole de Lyon avec l’ambition d’offrir aux usagers métropolitains les outils et les services leur permettant d’exercer directement leur droit à la portabilité, dans un cadre apte à garantir aussi bien la transparence et le contrôle sur l’usage de leurs données personnelles que l’exploitation directe du contenu de ces données selon leurs libres choix. Le self data est en effet selon la Fondation Internet Nouvelle Génération (FING) « la production, l’exploitation et le partage de données personnelles par les individus, sous leur contrôle et à leurs propres fins ». Au sein de cet environnement self data, la gestion des données s’appuie sur l’organisation suivante des rôles et responsabilités associées : \",\"part2-1\":\"Les partenaires du service GRDF et Eau Publique du Grand Lyon sont responsables exclusivement des seuls traitements de Données Personnelles relatifs à la collecte des données de consommation de gaz et d’eau de l’utilisateur et à leur transmission sur la plateforme de cloud personnel, après consentement de l’utilisateur.\",\"part2-2\":\"Enedis est responsable de la collecte des données de consommation d’électricité et de leur mise à disposition à la Métropole de Lyon qui, elle en gère la transmission sur la plateforme du cloud personnel de l’utilisateur, après avoir récupéré le consentement de l’utilisateur.\",\"part2-3\":\"La Métropole de Lyon est responsable de traitement sur le périmètre du service Ecolyo qu’elle propose à l’usager, ainsi que des traitements nécessaires à la fourniture de la plateforme de cloud personnel qu’elle met à disposition de l’usager pour accéder au service Ecolyo. En sa qualité de responsable de ces traitements, elle collecte et traite : \",\"part2-3-1\":\"Les données de compte de l’usager renseignées par l’usager au sein de son espace de cloud personnel Grand Lyon à des fins de gestion du compte et de communication avec l’usager ;\",\"part2-3-2\":\"Les données de compte de l’utilisateur lui permettant de connecter ses données d’électricité à Ecolyo ;\",\"part2-3-3\":\"Les données privées de consommation d’énergie et d’eau dont la récupération, la sauvegarde, le stockage, la synchronisation et le partage sur la plateforme de cloud personnel sont initiés par l’usager sans visibilité de la Métropole de Lyon sur leur contenu.\",\"part2-3-4\":\"Les données privées sur la composition du logement et du foyer de l’utilisateur, fournies par l’utilisateur lui-même au sein du service, sont traitées par le service sans visibilité de la Métropole de Lyon sur leur contenu.\",\"part2-3-5\":\"Des métriques d’usage du service anonymisées et remontées périodiquement afin d’améliorer la qualité du service et d’évaluer son impact (Plus d’informations sur la manière dont votre anonymat est bien préservé dans ce processus <a href=\\\"https://ecolyo.com/cloud_statistiques.html\\\">ici</a>).\",\"part2-4\":\"La Métropole réalise également des mesures d’audience à l’aide de la solution Matomo. Afin de vous fournir un meilleur service et d’améliorer votre expérience d'utilisateur, nous utilisons des solutions de mesure d’audience qui utilisent la technologie des « cookies », des fichiers texte qui sont enregistrés sur votre ordinateur et qui permettent de générer des informations envoyées aux serveurs de mesure d’audience. Sur ces serveurs, l’adresse IP est anonymisée. Les données recueillies ont uniquement pour finalité de permettre d'analyser la fréquentation de nos pages afin d'en améliorer le contenu. Il s'agit de statistiques agrégées permettant de connaître le nombre de visites et de visiteurs différents, les pages les plus populaires, les chemins préférés, les niveaux d'activité par jour de la semaine et par heure de la journée, les principales erreurs etc. Vous avez cependant le droit de vous opposer à l’utilisation de ces cookies, et donc au traitement de vos données personnelles de navigation, en vous rendant dans la page Options de notre service.\",\"part2-5\":\"L’usager est seul décisionnaire des finalités d’utilisation qu’il souhaite définir pour le traitement de ses données personnelles de consommation, à la suite de leur transmission par les partenaires du service Ecolyo sur son cloud personnel. Ainsi, dans le cadre de l’utilisation d’Ecolyo, l’usager ne recevra les données des partenaires du service : Enedis, GRDF et Eau Publique du Grand Lyon seulement qu’à sa demande expresse après la saisie de ses identifiants.\",\"part2-6\":\"L’utilisateur est donc le seul à accéder :\",\"part2-6-1\":\"À ses données de consommation d’électricité horaires, journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-6-2\":\"À ses données de consommation de gaz journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-6-3\":\"À ses données de consommation eau journalières, hebdomadaires, mensuelles et annuelles.\",\"part2-7\":\"Les engagements et responsabilités de la Métropole de Lyon concernant la protection des données et la confidentialité des données Ecolyo sont précisés dans les Mentions légales et les conditions d’utilisation du cloud personnel Grand Lyon qui accueille aujourd’hui le service Ecolyo et sans lequel le service ne peut pas fonctionner. Pour plus d’informations sur les engagements et responsabilités de la Métropole de Lyon concernant la protection et la confidentialité dans le cloud personnel, nous vous invitons à vous référer <a href=\\\"https://manager.cozygrandlyon.cloud/tos/266b4226-8417-42fb-b911-41e86dae8581.pdf?locale=fr\\\">aux mentions légales et CGU du cloud personnel métropolitain.</a> \",\"part2-8\":\"Conformément à la loi 78-17 du 6 janvier 1978 modifiée relative à l’information, aux fichiers et aux libertés, vous disposez d’un droit d’accès, de rectification et d’opposition au traitement de vos données à caractère personnel. Votre cloud personnel vous permet d’exercer ces droits directement dans cet espace sur vos données de compte. S’agissant des données de consommations d’électricité et de gaz, l’utilisateur peut supprimer son consentement à partager ses données en supprimant son connecteur dans la page Consos.\",\"part2-9\":\"Vous pouvez également exercer vos droits d’accès, de rectification, de limitation, d’opposition et d’effacement de vos données personnelles en contactant directement le Délégué à la Protection des Données par courrier en écrivant à l’adresse :\",\"part2-10\":\"Métropole de Lyon – Délégué à la Protection des Données - Direction des Assemblées, des Affaires Juridiques et des Assurances - 20, rue du Lac - BP 33569 - 69505 Lyon Cedex 03 ou en ligne, au moyen du formulaire disponible à l'adresse suivante : <a href=\\\"https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/\\\">https://demarches.toodego.com/sve/proteger-mes-donnees-personnelles/.</a>\",\"part2-11\":\"L’exercice de ces droits sur vos données personnelles auprès de la Métropole de Lyon concerne exclusivement les données traitées dans le cadre du service  « Ecolyo ».\",\"title3\":\"Dispositions légales\",\"part3-1\":\"Les divers éléments du site web (la forme, la mise en page, le fonds, la structure …) sont protégés par le droit des dessins et modèles, le droit d’auteur, le droit des marques ainsi que le droit à l’image et ils ne peuvent être copiés ou imités en tout ou partie sauf autorisation expresse de la Métropole de Lyon.\",\"part3-2\":\"Toute personne ne respectant pas les dispositions légales applicables se rend coupable du délit de contrefaçon et est passible des sanctions pénales prévues par la loi.\",\"title4\":\"Droits d’auteurs\",\"part4-1\":\"Les photographies, textes, logos, pictogrammes, ainsi que toutes œuvres intégrées dans le site sont la propriété de la \\\"Métropole de Lyon\\\" ou de tiers ayant autorisé la \\\"Métropole de Lyon\\\" à les utiliser.\",\"part4-2\":\"Les reproductions, les transmissions, les modifications, les réutilisations, sur un support papier ou informatique, dudit site et des œuvres qui y sont reproduites ne sont autorisées que pour un usage personnel et privé conforme aux dispositions de l’article L 122-5 du Code de la Propriété Intellectuelle. Ces reproductions devront ainsi notamment indiquer clairement la source et l’auteur du site et/ou de ces œuvres multimédias. En aucun cas ces reproductions ne sauraient porter préjudice aux droits des tiers. Les reproductions, les transmissions, les modifications, les réutilisations à des fins publicitaires, commerciales ou d’information, de tout ou partie du site, sont totalement interdites.\",\"title5\":\"Logo de la Métropole de Lyon et d’Ecolyo\",\"part5\":\"Les logos de la Métropole de Lyon et d’Ecolyo ne peuvent pas être modifiés – proportions, couleurs, éléments, constituants – et ne peuvent pas être sujet à aucune transformation, animation ou tout autre processus. Les logos de la Métropole de Lyon et d’Ecolyo ne peuvent être utilisés et associés qu’aux seules informations vérifiables. Ils ne peuvent être notamment utilisés que pour illustrer des relations avec la Métropole de Lyon ou des actions de sponsorings dûment établies. Quel que soit le cas d’espèce, la Métropole de Lyon se réserve le droit d’approuver ou de désapprouver toute utilisation des logos de la Métropole de Lyon et d’Ecolyo, pour assurer son utilisation correcte, conformément à l’éthique, la morale et aux intérêts de la Métropole de Lyon. Les conditions susmentionnées s’appliquent dans le cadre de pages web, elles ne font pas référence à l’utilisation des logos dans tout autre document. La Métropole de Lyon se réserve le droit de modifier les conditions d’utilisation des logos de la Métropole de Lyon et d’Ecolyo à tout moment et sans préavis.\",\"title6\":\"Droit des bases de données\",\"part6\":\"Les bases de données sont protégées par la loi du 1er juillet 1998 et le régime français du droit d’auteur.\",\"title7\":\"Établissements de liens vers le site Ecolyo\",\"part7-1\":\"La Métropole de Lyon autorise la mise en place d’un lien hypertexte vers son service Ecolyo pour tous les sites internet, à l’exclusion de ceux diffusant des informations à caractère polémique, pornographique, xénophobe ou pouvant, dans une plus large mesure porter atteinte à la sensibilité du plus grand nombre.\",\"part7-2\":\"Le lien doit aboutir à la page d’accueil du service (<a href=\\\"https://ecolyo.com\\\">https://ecolyo.com</a>), cette page devant apparaître dans une nouvelle fenêtre. Les pages du service Ecolyo ne doivent en aucun cas être intégrées à l’intérieur des pages d’un autre site (iframe).\",\"part7-3\":\"Dans tous les cas d’espèce, La Métropole de Lyon se réserve le droit de demander la suppression d’un lien si elle estime que le site cible ne respecte pas les règles ainsi définies.\",\"title8\":\"Liens vers des sites tiers depuis le site Ecolyo\",\"part8\":\"Les liens hypertextes mis en œuvre au sein du site en direction d’autres sites et/ou de pages personnelles et d’une manière générale vers toutes ressources existantes sur internet ne sauraient engager la responsabilité de la Métropole de Lyon quant aux liens qu’ils contiennent ou aux changements ou mises à jour qui leur sont apportés.\",\"title9\":\"Mise en garde générale\",\"part9-1\":\"Nos services mettent tout en œuvre pour offrir aux visiteurs de ce site web des informations fiables et vérifiées. Cependant, malgré tous les soins apportés, le site peut comporter des inexactitudes, des défauts de mise à jour ou des erreurs.\",\"part9-2\":\"Nous remercions les utilisateurs du site de nous faire part d’éventuelles omissions, erreurs ou corrections par mail sur la boite aux lettres du webmestre ou directement via le formulaire proposé dans le service.\",\"accessibility\":{\"button_close\":\"Fermer la fenêtre\"}},\"oauth\":{\"window\":{\"title\":\"OAuth\"}},\"onboarding\":{\"welcomeModal\":{\"title\":\"Vous êtes à mi-chemin !\",\"part1\":\"Votre cloud personnel a bien été créé.\",\"part2\":\"Il vous faut maintenant donner votre accord pour connecter vos compteurs au service.\",\"button_valid\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre de bienvenue\",\"button_valid\":\"Valider\"}}},\"old_fluid_data_modal\":{\"errorTxt\":\"Aïe !\",\"oldData\":\"Vos données semblent anciennes\",\"verify\":\"Veuillez vérifier l’état de vos connecteurs : \",\"problem\":\"Vos connecteurs semblent bien connectés, il se peut qu’il y ait un problème au niveau du ou des fournisseurs de données :\",\"problem_electricity\":\"pour l'électricité.\",\"problem_water\":\"pour l'eau.\",\"problem_gas\":\"pour le gaz.\",\"contact\":\"Veuillez prendre contact directement avec eux.\",\"accessButton\":\"Accéder aux connecteurs\",\"later\":\"Plus tard\",\"ok\":\"Ok\",\"accessibility\":{\"window_title\":\"Fenêtre d'information\",\"button_ok\":\"Fermer la fenêtre\",\"button_later\":\"Fermer la fenêtre\",\"button_goto_konnector\":\"Aller aux connecteurs\"}},\"performance_indicator\":{\"bilan\":{\"text1\":\"Par rapport à \",\"text2\":\"soit une différence de : \"},\"error_no_compare\":\"comparaison impossible\",\"error_no_compare_reason\":\"(manque de données)\",\"error_no_compare_no_data\":\"Vos consommations pour cette période sont incomplètes à cause d’un problème technique concernant :\",\"fpi\":{\"no_data\":\"Données non disponibles\",\"no_comparison\":\"Pas de comparaison possible\"}},\"profile\":{\"report\":{\"title_alert\":\"Alerte Consommation Excessive d'Eau\",\"title_bilan\":\"Notification par mail\",\"switch_label_bilan\":\"Je reçois la lettre mensuelle contenant un bilan et des conseils sur ma consommation.\",\"switch_label_alert\":\"Être prévenu d’un dépassement anormal de ma consommation d’eau\",\"input_label_alert\":\"Si ma consommation d’eau quotidienne dépasse :\",\"input_label_subtext_alert\":\"Votre consommation quotidienne maximum sur les 6 derniers mois : \",\"activate\":\"Activer\",\"deactivate\":\"Désactiver\"},\"accessibility\":{\"button_toggle_mail_report\":\"Recevoir mon bilan mensuel par mail\",\"button_toggle_consumption_alert\":\"Recevoir des alertes sur mes consommations journalières\",\"input_water_alert_report\":\"Indiquer une limite de consommation d'eau journalière\"}},\"profile_type\":{\"title_profile\":\"Mes données\",\"read_profile\":\"Ajuster mon profil\",\"button_update_profile\":\"J'ajuste mon profil\",\"your_profile\":\"Mon profil\",\"multi_choices\":\"Plusieurs réponses possibles\",\"housing_type\":{\"title\":\"Logement\",\"question\":\"De quel type de logement disposez-vous ?\",\"individual_house\":\"Maison individuelle\",\"apartment\":\"Appartement\"},\"construction_year\":{\"title\":\"Construction\",\"question\":\"Quelle est son année de construction ?\",\"text_before_1948\":\"Construit avant 1948\",\"text_between_1948_and_1974\":\"Construit entre 1948 et 1974\",\"text_between_1975_and_1989\":\"Construit entre 1975 et 1989\",\"text_between_1990_and_1998\":\"Construit entre 1990 et 1998\",\"text_after_1998\":\"Construit après 1998\",\"text_unknown\":\"Construit après 1998\",\"before_1948\":\"Avant 1948\",\"between_1948_and_1974\":\"Entre 1948 et 1974\",\"between_1975_and_1989\":\"Entre 1975 et 1989\",\"between_1990_and_1998\":\"Entre 1990 et 1998\",\"after_1998\":\"Après 1998\",\"unknown\":\"Je ne sais pas\"},\"occupantsNumber\":{\"single\":\" occupant\",\"multi\":\" occupants\"},\"area\":{\"title\":\"Surface\",\"question\":\"Quelle est sa surface en m² ?\",\"name\":\" m²\"},\"occupants_number\":{\"title\":\"Nombre d'occupants\",\"question\":\"Combien il y a-t-il d'occupants ?\"},\"outside_facing_walls\":{\"1\":\"1 façade\",\"2\":\"2 façades\",\"3\":\"3 façades\",\"4\":\"4 façades\",\"title\":\"Murs extérieurs\",\"question\":\"Combien de façades donnent sur l'extérieur ?\",\"text\":{\"single\":\" façade donne sur l'extérieur\",\"multi\":\" façades donnent sur l'extérieur\"}},\"floor\":{\"title\":\"Étage\",\"question\":\"À quel étage est votre appartement ?\",\"ground_floor\":\"Au rez-de-chaussée\",\"intermediate_floor\":\"Étage intermédiaire\",\"last_floor\":\"Dernier étage\",\"not_applicable\":\"Sans objet\"},\"heating\":{\"title\":\"Chauffage\",\"question\":\"Quel est votre type de chauffage ?\",\"individual\":\"Individuel\",\"collective\":\"Collectif\"},\"individual_insulation_work\":{\"title\":\"Travaux de rénovation\",\"question\":\"Quels travaux de rénovation avez-vous réalisés ces 10 dernières années ?\",\"none\":\"Aucun\",\"roof_insulation\":\"Isolation toiture\",\"window_replacement\":\"Remplacement fenêtres\",\"wall_insulation\":\"Isolation des murs\",\"window_replacement_and_wall_insulation\":\"Remplacement fenêtres et isolation des murs\",\"window_replacement_and_roof_insulation\":\"Remplacement fenêtres et isolation toiture\",\"roof_and_wall_insulation\":\"Isolation toiture et murs\",\"window_replacement_and_roof_and_wall_insulation\":\"Remplacement fenêtre et isolation des murs et isolation toiture\",\"built_after_1998\":\"construit après 1998\"},\"facilities_installation\":{\"title\":\"Équipement\"},\"ventilation\":{\"title\":\"Ventilation double flux\",\"question\":\"Êtes-vous équipé d'une ventilation double flux ?\",\"yes\":\"Oui\",\"no\":\"Non\",\"unknown\":\"Je ne sais pas\",\"text\":\"Équipé d'une ventilation double flux\"},\"heater_replacement\":{\"title\":\"Pompe à chaleur ou poêle à bois\",\"question\":\"Au cours de ces 10 dernières années, avez-vous remplacé votre chaudière ou vous êtes-vous équipé d'une pompe à chaleur ou d'un poêle à bois ?\",\"yes\":\"Oui\",\"no\":\"Non\",\"unknown\":\"Je ne sais pas\",\"text\":\"Équipé d'une pompe à chaleur ou poêle à bois\"},\"cold_water\":{\"title\":\"Eau\",\"question\":\"Votre eau est-elle comprise dans vos charges collectives ?\",\"individual\":\"Non\",\"collective\":\"Oui\",\"individual_text\":\"Individuelle\",\"collective_text\":\"Collective\"},\"hot_water\":{\"title\":\"Eau chaude\",\"question\":\"Quel est votre type de production d’eau chaude ?\",\"individual\":\"Individuelle\",\"collective\":\"Collective\"},\"hot_water_equipment\":{\"title\":\"Eau chaude\",\"question\":\"Utilisez-vous l’un de ces équipements pour produire votre eau chaude ?\",\"solar\":\"Chauffe-eau solaire\",\"thermodynamic\":\"Chauffe-eau thermodynamique\",\"other\":\"Aucun des deux\"},\"warming_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Bois\",\"4\":\"Fioul\",\"5\":\"Autre\",\"title\":\"Source chauffage\",\"question\":\"Quelle source d’énergie principale utilisez-vous pour vous chauffer ?\",\"no_fluid_text\":\"Produit ni par de l'électricité, ni par du gaz, ni par du bois ou du fuel\",\"0_text\":\"Produit grâce à de l'électricité\",\"2_text\":\"Produit grâce au gaz\",\"3_text\":\"Produit grâce au bois\",\"4_text\":\"Produit grâce au fioul\",\"5_text\":\"Produit grâce à un autre moyen\"},\"hot_water_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"3\":\"Autre (Fioul, Bois)\",\"title\":\"Source eau chaude\",\"question\":\"Avec quelle source d’énergie votre eau chaude est-elle produite ?\",\"no_fluid_text\":\"Produite ni par de l'électricité, ni par du gaz\",\"0_text\":\"Produite grâce à de l'électricité\",\"2_text\":\"Produite grâce au gaz\",\"3_text\":\"Produite à partir d'un autre moyen que l'électricité ou le gaz\"},\"cooking_fluid\":{\"0\":\"Électricité\",\"2\":\"Gaz\",\"title\":\"Source cuisson\",\"question\":\"Quel mode de cuisson principal utilisez-vous ?\"},\"update_date\":{\"title\":\"Date de prise d'effet\",\"question\":\"A partir de quelle date souhaitez-vous que ce nouveau profil soit pris en compte dans l'analyse de vos données ?\"},\"fluidType\":{\"0\":\"Électricité\",\"1\":\"Eau\",\"2\":\"Gaz\"},\"form\":{\"button_previous\":\"Précédent\",\"button_next\":\"Suivant\",\"button_end\":\"Terminer\",\"button_loading\":\"Chargement...\"},\"finished\":{\"title\":\"Terminé !\",\"label1\":\"Grâce à ces informations, vous pourrez comparer votre consommation avec celle d'un foyer vous ressemblant davantage !\",\"label2\":\"Nous pourrons aussi vous proposer des astuces pour maîtriser vos consommations adaptées à votre profil.\",\"button_validate\":\"OK\"},\"accessibility\":{\"button_end\":\"Terminer la mise à jour du profil\",\"button_next\":\"Aller à la section suivante\",\"button_previous\":\"Retour à la section précédente\",\"button_update_profile\":\"Ouvrir la page de mise à jour du profil\",\"button_toggle_detail_profile\":\"Afficher ou masquer le détail du profil\",\"button_toggle_export\":\"Afficher ou masquer l'export des données'\",\"button_toggle_average_home\":\"Afficher ou masquer les informations sur le comparatif'\",\"button_validate\":\"Valider\"}},\"export\":{\"title_export\":\"Télécharger mes données\",\"text1\":\"Vous allez télécharger l'historique mensuel de vos fluides sélectionnés\",\"fluid_select\":\"Pour quel(s) fluide(s) souhaitez vous exporter vos données ?\",\"no_data\":\"Vous n'avez aucune donnée de fluide...\",\"button_download\":\"Télécharger\",\"month\":\"Mois\",\"year\":\"Année\",\"consumption\":\"Consommation\",\"button_close\":\"Fermer la fenêtre\",\"modal_start\":{\"accessibility_title\":\"Commencer le téléchargement\",\"text1\":\"Vous allez télécharger des données personnelles, Ecolyo n’est plus responsable de celles-ci une fois téléchargées\",\"text2\":\"Les données seront téléchargées sous forme de document excel (.xls)\",\"text3\":\"Lancer le téléchargement ?\",\"button_cancel\":\"Annuler\"},\"modal_loading\":{\"accessibility_title\":\"Téléchargement en cours\",\"text1\":\"Données en cours de téléchargement\",\"text2\":\"Veuillez ne pas quitter l’application pendant la récupération et le téléchargement de vos données\",\"button_cancel\":\"Annuler le téléchargement\"},\"modal_done\":{\"accessibility_title\":\"Téléchargement terminé\",\"text1\":\"Vos données ont bien été téléchargées !\",\"text2\":\"Vous pouvez maintenant retrouver l’historique de vos données sur votre appareil\",\"error1\":\"Aïe !\",\"error2\":\"Il semblerait qu’une erreur se soit produite lors du téléchargement de vos données.\",\"button_close\":\"Fermer\",\"button_close_error\":\"Revenir plus tard\"}},\"quiz\":{\"explanation\":\"Répondez correctement aux 5 questions et remportez 5 des 15 étoiles nécessaires pour débloquer le duel final\",\"score_final\":\"SCORE FINAL\",\"correct\":\"Bravo !\",\"wrong\":\"Raté !\",\"rightAnswer\":\"Bonne réponse :\",\"earn\":\"Vous remportez\",\"button_go_back\":\"Retour\",\"button_end_quiz\":\"Youpi !\",\"button_try_again\":\"Réessayer\",\"button_validate\":\"Valider\",\"next\":\"Suivant\",\"consumption_question\":\"Question sur votre consommation\",\"accessibility\":{\"window_title\":\"Fenêtre de résultat\",\"button_end_quiz\":\"Terminer le quiz\",\"button_go_back\":\"Retour\",\"button_go_next\":\"Suivant\",\"button_try_again\":\"Relancer le quiz\",\"button_validate\":\"Valider\"}},\"splashscreen\":{\"error_loading\":\"Une erreur est survenue\",\"button_reload\":\"Réessayer\",\"accessibility\":{\"button_reload\":\"Recharger la page\"},\"migration_error\":\"Mise à jour de l'application\",\"consent_error\":\"Vérification de vos consentements pour partager vos données avec Ecolyo\",\"profile_error\":\"Chargement de votre profil utilisateur\",\"profileType_error\":\"Chargement de votre profil de consommation.\",\"challenges_error\":\"Actualisation de votre progression dans les défis\",\"analysis_error\":\"Chargement de votre analyse mensuelle\",\"index_error\":\"Chargement des index\",\"prices_error\":\"Mise à jour des prix\",\"consos_error\":\"Connexion à vos données de consommation\",\"partners_error\":\"Récupération de l'état des services partenaires\",\"unknown_error\":\"Veuillez vérifier votre connexion internet\",\"network_error\":\"Erreur de réseau\",\"step\":{\"0\":\"Mise à jour de l'application\",\"1\":\"Vérification de vos consentements pour partager vos données avec Ecolyo\",\"2\":\"Chargement de votre profil\",\"3\":\"Actualisation de votre progression dans les défis\",\"4\":\"Mise à jour des prix\",\"5\":\"Connexion à vos données de consommation\"}},\"timestep\":{\"today\":\"Aujourd'hui\",\"year\":{\"period\":\"5 ans\",\"comparelabel\":\"Comparer à l'année précédente\"},\"month\":{\"period\":\"Année\",\"comparelabel\":\"Comparer à l'année précédente\",\"current\":\"année actuelle\",\"last\":\"année précédente\"},\"day\":{\"period\":\"Mois\",\"comparelabel\":\"Comparer au mois précédent\",\"current\":\"mois actuel\",\"last\":\"mois précédent\"},\"week\":{\"period\":\"Semaine\",\"comparelabel\":\"Comparer à la semaine précédente\",\"current\":\"semaine actuelle\",\"last\":\"semaine précédente\"},\"half_an_hour\":{\"period\":\"Jour\",\"comparelabel\":\"Comparer à la journée précédente\",\"gather_data_title\":\"La récupération de vos données demi-horaires prend environ 24h.\",\"current\":\"jour actuel\",\"last\":\"jour précédent\",\"gather_data_subtitle\":\"Votre connexion a bien été prise en compte mais un délai de 24h est en général nécessaire à l’obtention de vos données.\\nÀ demain !\",\"analysis_waiting_data\":\"Pour bénéficier d'une analyse approfondie de votre consommation électrique, il nous faut récupérer vos données de consommation horaires. La récupération de ces données prend environ 24h. A bientôt !\"},\"accessibility\":{\"button_zoom_in\":\"Sélectionner le pas de temps précédent\",\"button_zoom_out\":\"Sélectionner le pas de temps suivant\"}},\"unsubscribe\":{\"title\":\"Êtes-vous sûr de ne plus vouloir recevoir notre email mensuel ?\",\"content\":\"Dans ce cas, vous ne recevrez plus la notification de votre bilan ainsi que les conseils associés au mois en cours.\",\"button_text\":\"Oui, je me désabonne\",\"button_accessibility\":\"Bouton de désinscription\"},\"welcome_modal\":{\"title\":\"Félicitations\",\"perso\":\"Votre espace personnel a bien été créé.\",\"connect\":\"Vous pouvez maintenant connecter vos compteurs d’énergie à Ecolyo en toute sécurité.\",\"button_valid\":\"Ok\",\"accessibility\":{\"title\":\"Fenêtre de félicitations\",\"button_valid\":\"Valider\"}}}");
 
 /***/ }),
 
@@ -9932,7 +9939,7 @@ var ConsumptionDataManager = /*#__PURE__*/function () {
           while (1) {
             switch (_context11.prev = _context11.next) {
               case 0:
-                query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+                query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
                   year: 'asc'
                 }, {
                   month: 'asc'
@@ -9968,11 +9975,8 @@ var ConsumptionDataManager = /*#__PURE__*/function () {
             switch (_context12.prev = _context12.next) {
               case 0:
                 query = (0, _cozyClient.Q)(doctype).where({
-                  year: {
-                    $gt: null
-                  },
-                  month: {
-                    $gt: null
+                  price: {
+                    $exists: false
                   }
                 }).partialIndex({
                   price: {
@@ -10283,8 +10287,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.defaultAction = exports.default = void 0;
 
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
 var Sentry = _interopRequireWildcard(__webpack_require__("agHs"));
 
 var _redux = __webpack_require__("ANjH");
@@ -10297,7 +10299,7 @@ var _global = __webpack_require__("YNKm");
 
 var _analysis = __webpack_require__("JQjK");
 
-var _challenge = __webpack_require__("F6Xr");
+var _challenge = __webpack_require__("TYd+");
 
 var _chart = __webpack_require__("idK9");
 
@@ -10307,16 +10309,12 @@ var _profile = __webpack_require__("QCMq");
 
 var _profileEcogesture = __webpack_require__("L0ad");
 
-var _profileType = __webpack_require__("ZI2v");
+var _profileType = __webpack_require__("Uoe2");
 
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var defaultAction = {
   type: null,
   payload: undefined
@@ -10324,18 +10322,14 @@ var defaultAction = {
 exports.defaultAction = defaultAction;
 var ecolyoReducer = (0, _redux.combineReducers)({
   analysis: _analysis.analysisSlice.reducer,
-  challenge: _challenge.challengeSlice.reducer,
+  challenge: _challenge.challengeReducer,
   chart: _chart.chartSlice.reducer,
   global: _global.globalReducer,
   modal: _modal.modalSlice.reducer,
   profile: _profile.profileReducer,
   profileEcogesture: _profileEcogesture.profileEcogestureReducer,
-  profileType: _profileType.profileTypeSlice.reducer
+  profileType: _profileType.profileTypeReducer
 });
-
-var appActions = _objectSpread(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, _analysis.analysisSlice.actions), _challenge.challengeSlice.actions), _chart.chartSlice.actions), _modal.modalSlice.actions), _profileType.profileTypeSlice.actions); // TODO refactor types with AppActionsTypes = typeof appActions
-
-
 var sentryReduxEnhancer = Sentry.createReduxEnhancer({});
 
 var configureStore = function configureStore(client, persistedState) {
@@ -10344,8 +10338,7 @@ var configureStore = function configureStore(client, persistedState) {
   })];
 
   var composeEnhancers = (0, _reduxDevtoolsExtension.composeWithDevTools)({
-    trace: true,
-    actionCreators: appActions
+    trace: true
   }) || _redux.compose;
 
   var store = (0, _redux.createStore)((0, _redux.combineReducers)({
@@ -10548,26 +10541,30 @@ var CozyBar = function CozyBar(_ref) {
     dispatch((0, _modal.openFeedbackModal)(true));
   };
 
-  if (screenType === _screen.ScreenType.MOBILE) {
-    return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, displayBackArrow && /*#__PURE__*/_react.default.createElement(BarLeft, null, /*#__PURE__*/_react.default.createElement(_StyledIconButton.default, {
-      "aria-label": t('header.accessibility.button_back'),
-      className: "cv-button",
-      icon: _backArrow.default,
-      onClick: handleClickBack
-    })), /*#__PURE__*/_react.default.createElement(BarCenter, null, /*#__PURE__*/_react.default.createElement("div", {
-      className: "cozy-bar"
-    }, /*#__PURE__*/_react.default.createElement("span", {
-      className: "app-title"
-    }, t(titleKey)))), /*#__PURE__*/_react.default.createElement(BarRight, null, /*#__PURE__*/_react.default.createElement(_StyledIconButton.default, {
-      "aria-label": t('header.accessibility.button_open_feedbacks'),
-      className: "cv-button",
-      icon: _feedback.default,
-      sized: 22,
-      onClick: handleClickFeedbacks
-    })));
-  } else {
+  var cozyBarCustom = function cozyBarCustom(screen) {
+    if (screen === _screen.ScreenType.MOBILE) {
+      return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, displayBackArrow && /*#__PURE__*/_react.default.createElement(BarLeft, null, /*#__PURE__*/_react.default.createElement(_StyledIconButton.default, {
+        "aria-label": t('header.accessibility.button_back'),
+        className: "cv-button",
+        icon: _backArrow.default,
+        onClick: handleClickBack
+      })), /*#__PURE__*/_react.default.createElement(BarCenter, null, /*#__PURE__*/_react.default.createElement("div", {
+        className: "cozy-bar"
+      }, /*#__PURE__*/_react.default.createElement("span", {
+        className: "app-title"
+      }, t(titleKey)))), /*#__PURE__*/_react.default.createElement(BarRight, null, /*#__PURE__*/_react.default.createElement(_StyledIconButton.default, {
+        "aria-label": t('header.accessibility.button_open_feedbacks'),
+        className: "cv-button",
+        icon: _feedback.default,
+        sized: 22,
+        onClick: handleClickFeedbacks
+      })));
+    }
+
     return null;
-  }
+  };
+
+  return cozyBarCustom(screenType);
 };
 
 var _default = CozyBar;
@@ -10982,25 +10979,26 @@ var QuizService = /*#__PURE__*/function () {
     key: "startUserQuiz",
     value: function () {
       var _startUserQuiz = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee4(userQuiz) {
-        var questions;
+        var questions, randomizedQuestions, updatedUserQuiz;
         return _regenerator.default.wrap(function _callee4$(_context4) {
           while (1) {
             switch (_context4.prev = _context4.next) {
               case 0:
-                questions = userQuiz.questions.map(function (question) {
-                  return _objectSpread(_objectSpread({}, question), {}, {
-                    answers: (0, _lodash.shuffle)(question.answers)
-                  });
+                questions = userQuiz.questions;
+                questions.forEach(function (question) {
+                  return question.answers = (0, _lodash.shuffle)(question.answers);
                 });
-                return _context4.abrupt("return", _objectSpread(_objectSpread({}, userQuiz), {}, {
-                  questions: (0, _lodash.shuffle)(questions),
+                randomizedQuestions = (0, _lodash.shuffle)(questions);
+                updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
+                  questions: randomizedQuestions,
                   state: _userQuiz.UserQuizState.ONGOING,
                   startDate: _luxon.DateTime.local().setZone('utc', {
                     keepLocalTime: true
                   })
-                }));
+                });
+                return _context4.abrupt("return", updatedUserQuiz);
 
-              case 2:
+              case 5:
               case "end":
                 return _context4.stop();
             }
@@ -11024,27 +11022,27 @@ var QuizService = /*#__PURE__*/function () {
     key: "resetUserQuiz",
     value: function () {
       var _resetUserQuiz = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee5(userQuiz) {
-        var updatedQuestions, updatedCustomQuestion;
+        var updatedQuestions, updatedCustomQuestion, updatedUserQuiz;
         return _regenerator.default.wrap(function _callee5$(_context5) {
           while (1) {
             switch (_context5.prev = _context5.next) {
               case 0:
-                updatedQuestions = userQuiz.questions.map(function (question) {
-                  return _objectSpread(_objectSpread({}, question), {}, {
-                    result: _userQuiz.UserQuestionState.UNLOCKED
-                  });
+                updatedQuestions = userQuiz.questions;
+                updatedQuestions.forEach(function (question) {
+                  question.result = _userQuiz.UserQuestionState.UNLOCKED;
                 });
                 updatedCustomQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
                   result: _userQuiz.UserQuestionState.UNLOCKED
                 });
-                return _context5.abrupt("return", _objectSpread(_objectSpread({}, userQuiz), {}, {
+                updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
                   customQuestion: updatedCustomQuestion,
                   questions: updatedQuestions,
                   result: 0,
                   state: _userQuiz.UserQuizState.UNLOCKED
-                }));
+                });
+                return _context5.abrupt("return", updatedUserQuiz);
 
-              case 3:
+              case 5:
               case "end":
                 return _context5.stop();
             }
@@ -11104,31 +11102,32 @@ var QuizService = /*#__PURE__*/function () {
     key: "updateUserQuiz",
     value: function () {
       var _updateUserQuiz = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee7(userQuiz, questionResult, questionIndex) {
-        var result, updatedQuestions, updatedCustomQuestion;
+        var updatedQuestion, _updatedQuestion, quizScoreLimit, updatedUserQuiz;
+
         return _regenerator.default.wrap(function _callee7$(_context7) {
           while (1) {
             switch (_context7.prev = _context7.next) {
               case 0:
-                result = questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT;
-                updatedQuestions = userQuiz.questions.map(function (question, index) {
-                  if (index === questionIndex) {
-                    return _objectSpread(_objectSpread({}, question), {}, {
-                      result: result
-                    });
-                  }
+                if (questionIndex !== undefined) {
+                  updatedQuestion = _objectSpread(_objectSpread({}, userQuiz.questions[questionIndex]), {}, {
+                    result: questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT
+                  });
+                  userQuiz.questions[questionIndex] = updatedQuestion;
+                } else {
+                  _updatedQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
+                    result: questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT
+                  });
+                  userQuiz.customQuestion = _updatedQuestion;
+                }
 
-                  return question;
-                });
-                updatedCustomQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
-                  result: result
+                quizScoreLimit = userQuiz.result;
+                quizScoreLimit = quizScoreLimit + 1 > 5 ? 5 : quizScoreLimit + 1;
+                updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
+                  result: questionResult ? quizScoreLimit : userQuiz.result
                 });
-                return _context7.abrupt("return", _objectSpread(_objectSpread({}, userQuiz), {}, {
-                  questions: updatedQuestions,
-                  customQuestion: questionIndex === undefined ? updatedCustomQuestion : userQuiz.customQuestion,
-                  result: questionResult ? Math.min(userQuiz.result + 1, 5) : userQuiz.result
-                }));
+                return _context7.abrupt("return", updatedUserQuiz);
 
-              case 4:
+              case 5:
               case "end":
                 return _context7.stop();
             }
@@ -12805,19 +12804,6 @@ Object.keys(_profile).forEach(function (key) {
   });
 });
 
-var _profileEcogesture = __webpack_require__("ZzqV");
-
-Object.keys(_profileEcogesture).forEach(function (key) {
-  if (key === "default" || key === "__esModule") return;
-  if (key in exports && exports[key] === _profileEcogesture[key]) return;
-  Object.defineProperty(exports, key, {
-    enumerable: true,
-    get: function get() {
-      return _profileEcogesture[key];
-    }
-  });
-});
-
 var _profileType = __webpack_require__("G32H");
 
 Object.keys(_profileType).forEach(function (key) {
@@ -13678,105 +13664,6 @@ if(false) {}
 
 /***/ }),
 
-/***/ "F6Xr":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-var _interopRequireDefault = __webpack_require__("TqRt");
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.updateUserChallengeList = exports.unlockNextUserChallenge = exports.setUserChallengeList = exports.setChallengeConsumption = exports.challengeSlice = void 0;
-
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
-var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("RIqP"));
-
-var _toolkit = __webpack_require__("i7Pf");
-
-var _userChallenge = __webpack_require__("dQx6");
-
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
-var initialState = {
-  userChallengeList: [],
-  currentChallenge: null,
-  currentDataload: []
-};
-var challengeSlice = (0, _toolkit.createSlice)({
-  name: 'challenge',
-  initialState: initialState,
-  reducers: {
-    setUserChallengeList: function setUserChallengeList(state, action) {
-      var filteredCurrentChallenge = action.payload.filter(function (challenge) {
-        return challenge.state === _userChallenge.UserChallengeState.ONGOING || challenge.state === _userChallenge.UserChallengeState.DUEL;
-      });
-      var currentChallenge = filteredCurrentChallenge[0] || null;
-      state.userChallengeList = action.payload;
-      state.currentChallenge = currentChallenge;
-    },
-    updateUserChallengeList: function updateUserChallengeList(state, action) {
-      var id = action.payload.id;
-      var currentChallenge = action.payload.state === _userChallenge.UserChallengeState.ONGOING || action.payload.state === _userChallenge.UserChallengeState.DUEL ? action.payload : null;
-      var updatedList = (0, _toConsumableArray2.default)(state.userChallengeList);
-      var findIndex = updatedList.findIndex(function (challenge) {
-        return challenge.id === id;
-      });
-      updatedList[findIndex] = action.payload;
-      state.userChallengeList = updatedList;
-      state.currentChallenge = currentChallenge || state.currentChallenge;
-    },
-    unlockNextUserChallenge: function unlockNextUserChallenge(state, action) {
-      var id = action.payload.id;
-      var updatedList = (0, _toConsumableArray2.default)(state.userChallengeList);
-      var findIndex = updatedList.findIndex(function (challenge) {
-        return challenge.id === id;
-      });
-      updatedList[findIndex] = action.payload;
-
-      if (typeof updatedList[findIndex + 1] !== 'undefined') {
-        updatedList[findIndex + 1] = _objectSpread(_objectSpread({}, updatedList[findIndex + 1]), {}, {
-          state: _userChallenge.UserChallengeState.UNLOCKED
-        });
-      }
-
-      state.userChallengeList = updatedList;
-      state.currentChallenge = null;
-    },
-    setChallengeConsumption: function setChallengeConsumption(state, action) {
-      var id = action.payload.userChallenge.id;
-      var updatedList = (0, _toConsumableArray2.default)(state.userChallengeList);
-      var findIndex = updatedList.findIndex(function (challenge) {
-        return challenge.id === id;
-      });
-      updatedList[findIndex] = action.payload.userChallenge;
-      state.userChallengeList = updatedList;
-      state.currentDataload = action.payload.currentDataload;
-
-      if (state.currentChallenge && state.currentChallenge.id === action.payload.userChallenge.id) {
-        state.currentChallenge = action.payload.userChallenge;
-      }
-    }
-  }
-});
-exports.challengeSlice = challengeSlice;
-var _challengeSlice$actio = challengeSlice.actions,
-    setChallengeConsumption = _challengeSlice$actio.setChallengeConsumption,
-    setUserChallengeList = _challengeSlice$actio.setUserChallengeList,
-    unlockNextUserChallenge = _challengeSlice$actio.unlockNextUserChallenge,
-    updateUserChallengeList = _challengeSlice$actio.updateUserChallengeList;
-exports.updateUserChallengeList = updateUserChallengeList;
-exports.unlockNextUserChallenge = unlockNextUserChallenge;
-exports.setUserChallengeList = setUserChallengeList;
-exports.setChallengeConsumption = setChallengeConsumption;
-
-/***/ }),
-
 /***/ "FCQH":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -14058,7 +13945,7 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _utils = __webpack_require__("c+yx");
 
@@ -14762,6 +14649,32 @@ exports.default = _default;
 
 /***/ }),
 
+/***/ "HdrC":
+/***/ (function(module, exports, __webpack_require__) {
+
+
+var content = __webpack_require__("Vppt");
+
+if(typeof content === 'string') content = [[module.i, content, '']];
+
+var transform;
+var insertInto;
+
+
+
+var options = {"hmr":true}
+
+options.transform = transform
+options.insertInto = undefined;
+
+var update = __webpack_require__("aET+")(content, options);
+
+if(content.locals) module.exports = content.locals;
+
+if(false) {}
+
+/***/ }),
+
 /***/ "HvHZ":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -15218,17 +15131,12 @@ exports.default = ConfigService;
 Object.defineProperty(exports, "__esModule", {
   value: true
 });
-exports.setPeriod = exports.setAnalysisMonth = exports.analysisSlice = void 0;
+exports.setPeriod = exports.analysisSlice = void 0;
 
 var _toolkit = __webpack_require__("i7Pf");
 
-var _luxon = __webpack_require__("ExVU");
-
 var initialState = {
-  period: 'month',
-  analysisMonth: _luxon.DateTime.local().minus({
-    months: 1
-  }).startOf('day')
+  period: 'month'
 };
 var analysisSlice = (0, _toolkit.createSlice)({
   name: 'analysis',
@@ -15236,17 +15144,11 @@ var analysisSlice = (0, _toolkit.createSlice)({
   reducers: {
     setPeriod: function setPeriod(state, action) {
       state.period = action.payload;
-    },
-    setAnalysisMonth: function setAnalysisMonth(state, action) {
-      state.analysisMonth = action.payload;
     }
   }
 });
 exports.analysisSlice = analysisSlice;
-var _analysisSlice$action = analysisSlice.actions,
-    setPeriod = _analysisSlice$action.setPeriod,
-    setAnalysisMonth = _analysisSlice$action.setAnalysisMonth;
-exports.setAnalysisMonth = setAnalysisMonth;
+var setPeriod = analysisSlice.actions.setPeriod;
 exports.setPeriod = setPeriod;
 
 /***/ }),
@@ -16137,32 +16039,22 @@ var _lodash = __webpack_require__("LvDl");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var ProfileTypeFormMultiChoice = function ProfileTypeFormMultiChoice(_ref) {
   var step = _ref.step,
       viewedStep = _ref.viewedStep,
-      currentProfileType = _ref.currentProfileType,
+      profileType = _ref.profileType,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
-      setPreviousStep = _ref.setPreviousStep;
+      setPreviousStep = _ref.setPreviousStep,
+      isProfileTypeComplete = _ref.isProfileTypeComplete;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.profile;
-  }),
-      isProfileTypeCompleted = _useSelector.isProfileTypeCompleted;
-
   var _useState = (0, _react.useState)([]),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
@@ -16188,21 +16080,27 @@ var ProfileTypeFormMultiChoice = function ProfileTypeFormMultiChoice(_ref) {
   };
 
   var isChecked = function isChecked(value) {
-    return answer.includes(value);
+    if (answer.includes(value)) {
+      return true;
+    } else {
+      return false;
+    }
   };
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileType);
+  }, [profileType, setPreviousStep]);
   var handleNext = (0, _react.useCallback)(function () {
-    setNextStep(_objectSpread(_objectSpread({}, currentProfileType), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  }, [currentProfileType, setNextStep, answer, answerType.attribute]);
+    profileType[answerType.attribute] = answer;
+    setNextStep(profileType);
+  }, [profileType, setNextStep, answer, answerType.attribute]);
   (0, _react.useEffect)(function () {
-    // Set answer if profileType is completed
-    if (step < viewedStep || isProfileTypeCompleted) {
-      setAnswer(currentProfileType[answerType.attribute]);
+    var attribute = profileType[answerType.attribute];
+
+    if (step < viewedStep || isProfileTypeComplete) {
+      setAnswer(attribute);
     }
-  }, [step, viewedStep, currentProfileType, answerType, isProfileTypeCompleted]);
+  }, [step, viewedStep, profileType, answerType, isProfileTypeComplete]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container'
   }, /*#__PURE__*/_react.default.createElement(_FormProgress.default, {
@@ -16213,20 +16111,18 @@ var ProfileTypeFormMultiChoice = function ProfileTypeFormMultiChoice(_ref) {
   }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), /*#__PURE__*/_react.default.createElement("span", {
     className: "profile-question-hint"
   }, t('profile_type.multi_choices')), answerType.choices.map(function (value, index) {
-    if (!value) return null;
-    var stringValue = value.toString();
-    return /*#__PURE__*/_react.default.createElement("label", {
+    return value ? /*#__PURE__*/_react.default.createElement("label", {
       key: index,
-      className: (0, _classnames.default)('checkbox', (0, _defineProperty2.default)({}, 'answer-checked', answer.includes(stringValue)))
+      className: (0, _classnames.default)('checkbox', (0, _defineProperty2.default)({}, 'answer-checked', answer.includes(value)))
     }, /*#__PURE__*/_react.default.createElement("input", {
       type: 'checkbox',
-      value: stringValue,
-      name: stringValue,
+      value: value,
+      name: value.toString(),
       onChange: function onChange() {
-        return handleChange(stringValue);
+        return handleChange(value);
       },
-      checked: isChecked(stringValue)
-    }), t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".").concat(value)));
+      checked: isChecked(value)
+    }), t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".").concat(value))) : null;
   })), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
     step: step,
     handlePrevious: handlePrevious,
@@ -16264,8 +16160,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.default = void 0;
 
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
 var _slicedToArray2 = _interopRequireDefault(__webpack_require__("J4zp"));
 
 var _core = __webpack_require__("TTf+");
@@ -16282,32 +16176,22 @@ var _profileType2 = __webpack_require__("D9qV");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var ProfileTypeFormNumberSelection = function ProfileTypeFormNumberSelection(_ref) {
   var step = _ref.step,
       viewedStep = _ref.viewedStep,
-      currentProfileType = _ref.currentProfileType,
+      profileType = _ref.profileType,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
-      setPreviousStep = _ref.setPreviousStep;
+      setPreviousStep = _ref.setPreviousStep,
+      isProfileTypeComplete = _ref.isProfileTypeComplete;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.profile;
-  }),
-      isProfileTypeCompleted = _useSelector.isProfileTypeCompleted;
-
   var _useState = (0, _react.useState)(''),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
@@ -16333,22 +16217,23 @@ var ProfileTypeFormNumberSelection = function ProfileTypeFormNumberSelection(_re
   };
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileType);
+  }, [profileType, setPreviousStep]);
   var handleNext = (0, _react.useCallback)(function () {
-    setNextStep(_objectSpread(_objectSpread({}, currentProfileType), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  }, [currentProfileType, setNextStep, answer, answerType.attribute]);
+    profileType[answerType.attribute] = answer;
+    setNextStep(profileType);
+  }, [profileType, setNextStep, answer, answerType.attribute]);
   (0, _react.useEffect)(function () {
-    if (step < viewedStep || isProfileTypeCompleted) {
+    if (step < viewedStep || isProfileTypeComplete) {
       var foundIndex = answerType.choices.findIndex(function (element) {
-        return element && element === currentProfileType[answerType.attribute];
+        return element && element === profileType[answerType.attribute];
       });
       foundIndex > -1 && setIndex(foundIndex);
-      setAnswer(currentProfileType[answerType.attribute]);
+      setAnswer(profileType[answerType.attribute]);
     } else {
       setAnswer(answerType.choices[0]);
     }
-  }, [step, viewedStep, currentProfileType, answerType, isProfileTypeCompleted]);
+  }, [step, viewedStep, profileType, answerType, isProfileTypeComplete]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container'
   }, /*#__PURE__*/_react.default.createElement(_FormProgress.default, {
@@ -16368,7 +16253,7 @@ var ProfileTypeFormNumberSelection = function ProfileTypeFormNumberSelection(_re
     className: 'number'
   }, /*#__PURE__*/_react.default.createElement("input", {
     type: 'text',
-    value: answer.toString(),
+    value: answer,
     name: answerType.attribute,
     disabled: true
   })), /*#__PURE__*/_react.default.createElement(_core.Button, {
@@ -16800,58 +16685,39 @@ var _profileType2 = __webpack_require__("D9qV");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var ProfileTypeFormSingleChoice = function ProfileTypeFormSingleChoice(_ref) {
   var step = _ref.step,
       viewedStep = _ref.viewedStep,
-      currentProfileType = _ref.currentProfileType,
+      profileType = _ref.profileType,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
-      setPreviousStep = _ref.setPreviousStep;
+      setPreviousStep = _ref.setPreviousStep,
+      isProfileTypeComplete = _ref.isProfileTypeComplete;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo;
-  }),
-      _useSelector$profile = _useSelector.profile,
-      isProfileTypeCompleted = _useSelector$profile.isProfileTypeCompleted,
-      isProfileEcogestureCompleted = _useSelector$profile.isProfileEcogestureCompleted,
-      profileEcogesture = _useSelector.profileEcogesture;
-
   var _useState = (0, _react.useState)(''),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
       setAnswer = _useState2[1];
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileType);
+  }, [profileType, setPreviousStep]);
   var handleNext = (0, _react.useCallback)(function () {
-    setNextStep(_objectSpread(_objectSpread({}, currentProfileType), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  }, [currentProfileType, setNextStep, answer, answerType.attribute]);
+    profileType[answerType.attribute] = answer;
+    setNextStep(profileType);
+  }, [profileType, setNextStep, answer, answerType.attribute]);
   (0, _react.useEffect)(function () {
-    // Set answer if profileType is completed
-    if (step < viewedStep || isProfileTypeCompleted) {
-      setAnswer(currentProfileType[answerType.attribute]);
-      return;
-    } // Set answer if ecogestureProfile is completed
-
-
-    if (isProfileEcogestureCompleted) {
-      setAnswer(profileEcogesture[answerType.attribute]);
+    if (step < viewedStep || isProfileTypeComplete) {
+      setAnswer(profileType[answerType.attribute]);
     }
-  }, [step, viewedStep, currentProfileType, answerType, isProfileTypeCompleted, isProfileEcogestureCompleted, profileEcogesture]);
+  }, [step, viewedStep, profileType, answerType, isProfileTypeComplete]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container'
   }, /*#__PURE__*/_react.default.createElement(_FormProgress.default, {
@@ -16862,24 +16728,23 @@ var ProfileTypeFormSingleChoice = function ProfileTypeFormSingleChoice(_ref) {
   }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), answerType.choices.map(function (value, index) {
     var _classNames;
 
-    if (!value && value !== 0) return null;
-    return /*#__PURE__*/_react.default.createElement("label", {
+    return value || value === 0 ? /*#__PURE__*/_react.default.createElement("label", {
       key: index,
       className: (0, _classnames.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, 'radio_short', answerType.choices.length < 5), (0, _defineProperty2.default)(_classNames, 'radio_long', answerType.choices.length > 4), (0, _defineProperty2.default)(_classNames, 'answer-checked', answer === value), _classNames))
     }, /*#__PURE__*/_react.default.createElement("input", {
       type: 'radio',
-      value: value.toString(),
+      value: value,
       name: value.toString(),
       onChange: function onChange() {
         return setAnswer(value);
       },
       checked: answer === value ? true : false
-    }), t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".").concat(value)));
+    }), t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".").concat(value))) : null;
   })), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
     step: step,
     handlePrevious: handlePrevious,
     handleNext: handleNext,
-    disableNextButton: answer === '' || answer === undefined
+    disableNextButton: answer === ''
   }));
 };
 
@@ -17383,9 +17248,6 @@ var ProfileEcogestureFormService = /*#__PURE__*/function () {
         case _ecogestureForm.EcogestureStepForm.HOT_WATER_TYPE:
           return _ecogestureForm.EcogestureStepForm.EQUIPMENTS;
 
-        case _ecogestureForm.EcogestureStepForm.EQUIPMENTS:
-          return _ecogestureForm.EcogestureStepForm.END;
-
         default:
           return _ecogestureForm.EcogestureStepForm.HEATING_TYPE;
       }
@@ -17616,7 +17478,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _quiz = _interopRequireDefault(__webpack_require__("CUhI"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("mFBf");
 
@@ -17804,7 +17666,7 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("Giwf");
 
@@ -18052,14 +17914,14 @@ var QueryRunner = /*#__PURE__*/function () {
       var doctype = this.getRelevantDoctype(fluidType, timeStep);
 
       if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-        return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+        return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
           load: 'desc'
-        }]).limitBy(1);
+        }]);
       }
 
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
         load: 'desc'
-      }]).limitBy(limit);
+      }]);
     }
   }, {
     key: "buildFirstDateQuery",
@@ -18614,7 +18476,7 @@ var QueryRunner = /*#__PURE__*/function () {
               case 0:
                 doctype = this.getRelevantDoctype(fluidType, timeStep);
                 _context7.prev = 1;
-                query = (0, _cozyClient.Q)(doctype).limitBy(1);
+                query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
                 _context7.next = 5;
                 return this._client.query(query);
 
@@ -19165,7 +19027,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _utils = __webpack_require__("c+yx");
 
@@ -19216,10 +19078,7 @@ var DuelUnlocked = function DuelUnlocked(_ref) {
             });
 
           case 9:
-            dispatch((0, _challenge2.setChallengeConsumption)({
-              userChallenge: updatedChallenge,
-              currentDataload: dataloads
-            }));
+            dispatch((0, _challenge2.setChallengeConsumption)(updatedChallenge, dataloads));
 
           case 10:
           case "end":
@@ -19319,6 +19178,234 @@ var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WE
 
 /***/ }),
 
+/***/ "TYd+":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.challengeReducer = void 0;
+
+var _toConsumableArray2 = _interopRequireDefault(__webpack_require__("RIqP"));
+
+var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
+
+var _userChallenge = __webpack_require__("dQx6");
+
+var _challenge = __webpack_require__("ojwR");
+
+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; }
+
+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) { (0, _defineProperty2.default)(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; }
+
+var initialState = {
+  userChallengeList: [],
+  currentChallenge: null,
+  currentDataload: []
+};
+
+var challengeReducer = function challengeReducer() {
+  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
+  var action = arguments.length > 1 ? arguments[1] : undefined;
+  if (action.payload == undefined) return state;
+
+  var updateState = function updateState(updates) {
+    return _objectSpread(_objectSpread({}, state), updates);
+  };
+
+  switch (action.type) {
+    case _challenge.SET_USER_CHALLENGE_LIST:
+      {
+        var filteredCurrentChallenge = action.payload.filter(function (challenge) {
+          return challenge.state === _userChallenge.UserChallengeState.ONGOING || challenge.state === _userChallenge.UserChallengeState.DUEL;
+        });
+        var currentChallenge = filteredCurrentChallenge[0] || null;
+        return updateState({
+          userChallengeList: action.payload,
+          currentChallenge: currentChallenge
+        });
+      }
+
+    case _challenge.UPDATE_USER_CHALLENGE_LIST:
+      {
+        var id = action.payload.id;
+
+        var _currentChallenge = action.payload.state === _userChallenge.UserChallengeState.ONGOING || action.payload.state === _userChallenge.UserChallengeState.DUEL ? action.payload : null;
+
+        var updatedList = (0, _toConsumableArray2.default)(state.userChallengeList);
+        var findIndex = updatedList.findIndex(function (challenge) {
+          return challenge.id === id;
+        });
+        updatedList[findIndex] = action.payload;
+        return updateState({
+          userChallengeList: updatedList,
+          currentChallenge: _currentChallenge || state.currentChallenge
+        });
+      }
+
+    case _challenge.UNLOCK_NEXT_USER_CHALLENGE:
+      {
+        var _id = action.payload.id;
+
+        var _updatedList = (0, _toConsumableArray2.default)(state.userChallengeList);
+
+        var _findIndex = _updatedList.findIndex(function (challenge) {
+          return challenge.id === _id;
+        });
+
+        _updatedList[_findIndex] = action.payload;
+
+        if (typeof _updatedList[_findIndex + 1] !== 'undefined') {
+          _updatedList[_findIndex + 1] = _objectSpread(_objectSpread({}, _updatedList[_findIndex + 1]), {}, {
+            state: _userChallenge.UserChallengeState.UNLOCKED
+          });
+        }
+
+        return updateState({
+          userChallengeList: _updatedList,
+          currentChallenge: null
+        });
+      }
+
+    case _challenge.SET_CHALLENGE_CONSUMPTION:
+      {
+        var _id2 = action.payload.userChallenge.id;
+
+        var _updatedList2 = (0, _toConsumableArray2.default)(state.userChallengeList);
+
+        var _findIndex2 = _updatedList2.findIndex(function (challenge) {
+          return challenge.id === _id2;
+        });
+
+        _updatedList2[_findIndex2] = action.payload.userChallenge;
+        return updateState({
+          userChallengeList: _updatedList2,
+          currentChallenge: state.currentChallenge && state.currentChallenge.id === action.payload.userChallenge.id ? action.payload.userChallenge : state.currentChallenge,
+          currentDataload: action.payload.currentDataload
+        });
+      }
+
+    default:
+      return state;
+  }
+};
+
+exports.challengeReducer = challengeReducer;
+
+/***/ }),
+
+/***/ "TeAr":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.UPDATE_PROFILETYPE = exports.CREATE_NEW_PROFILETYPE = void 0;
+exports.newProfileTypeEntry = newProfileTypeEntry;
+exports.updateProfileType = updateProfileType;
+exports.updateProfileTypeSuccess = updateProfileTypeSuccess;
+
+var _regenerator = _interopRequireDefault(__webpack_require__("o0o1"));
+
+var _asyncToGenerator2 = _interopRequireDefault(__webpack_require__("yXPU"));
+
+var _doctypes = __webpack_require__("D2hQ");
+
+var _profileTypeEntity = _interopRequireDefault(__webpack_require__("aypK"));
+
+var UPDATE_PROFILETYPE = 'UPDATE_PROFILETYPE';
+exports.UPDATE_PROFILETYPE = UPDATE_PROFILETYPE;
+var CREATE_NEW_PROFILETYPE = 'CREATE_NEW_PROFILETYPE';
+exports.CREATE_NEW_PROFILETYPE = CREATE_NEW_PROFILETYPE;
+
+function updateProfileTypeSuccess(updatedProfileType) {
+  return {
+    type: UPDATE_PROFILETYPE,
+    payload: updatedProfileType
+  };
+}
+
+function updateProfileType(updates) {
+  return /*#__PURE__*/function () {
+    var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(dispatch, getState, _ref) {
+      var client, profileTypeEntityService, updatedProfileType;
+      return _regenerator.default.wrap(function _callee$(_context) {
+        while (1) {
+          switch (_context.prev = _context.next) {
+            case 0:
+              client = _ref.client;
+              profileTypeEntityService = new _profileTypeEntity.default(client);
+              _context.next = 4;
+              return profileTypeEntityService.updateProfileType(updates);
+
+            case 4:
+              updatedProfileType = _context.sent;
+
+              if (updatedProfileType) {
+                dispatch(updateProfileTypeSuccess(updatedProfileType));
+              }
+
+            case 6:
+            case "end":
+              return _context.stop();
+          }
+        }
+      }, _callee);
+    }));
+
+    return function (_x, _x2, _x3) {
+      return _ref2.apply(this, arguments);
+    };
+  }();
+}
+
+function newProfileTypeEntry(updates) {
+  return /*#__PURE__*/function () {
+    var _ref4 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(dispatch, getState, _ref3) {
+      var client, _yield$client$create, newProfileType;
+
+      return _regenerator.default.wrap(function _callee2$(_context2) {
+        while (1) {
+          switch (_context2.prev = _context2.next) {
+            case 0:
+              client = _ref3.client;
+              _context2.next = 3;
+              return client.create(_doctypes.PROFILETYPE_DOCTYPE, updates);
+
+            case 3:
+              _yield$client$create = _context2.sent;
+              newProfileType = _yield$client$create.data;
+
+              if (newProfileType) {
+                dispatch(updateProfileTypeSuccess(newProfileType));
+              }
+
+            case 6:
+            case "end":
+              return _context2.stop();
+          }
+        }
+      }, _callee2);
+    }));
+
+    return function (_x4, _x5, _x6) {
+      return _ref4.apply(this, arguments);
+    };
+  }();
+}
+
+/***/ }),
+
 /***/ "Tg1I":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -19787,8 +19874,8 @@ var DateChartService = /*#__PURE__*/function () {
      */
 
   }, {
-    key: "incrementDate",
-    value: function incrementDate(timeStep, selectedDate, increment) {
+    key: "incrementeDate",
+    value: function incrementeDate(timeStep, selectedDate, increment) {
       switch (timeStep) {
         case _timeStep.TimeStep.YEAR:
           return selectedDate.plus({
@@ -20071,6 +20158,72 @@ module.exports = (Handlebars["default"] || Handlebars).template({"compiler":[8,"
 
 /***/ }),
 
+/***/ "Uoe2":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+var _interopRequireDefault = __webpack_require__("TqRt");
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.profileTypeReducer = void 0;
+
+var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
+
+var _fluid = __webpack_require__("5Wkc");
+
+var _profileType = __webpack_require__("D9qV");
+
+var _luxon = __webpack_require__("ExVU");
+
+var _profileType2 = __webpack_require__("TeAr");
+
+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; }
+
+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) { (0, _defineProperty2.default)(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; }
+
+var initialState = {
+  housingType: _profileType.HousingType.INDIVIDUAL_HOUSE,
+  constructionYear: _profileType.ConstructionYear.BETWEEN_1975_AND_1989,
+  area: '100',
+  occupantsNumber: 4,
+  outsideFacingWalls: _profileType.OutsideFacingWalls.TWO,
+  floor: _profileType.Floor.NOT_APPLICABLE,
+  heating: _profileType.IndividualOrCollective.INDIVIDUAL,
+  coldWater: _profileType.IndividualOrCollective.INDIVIDUAL,
+  hotWater: _profileType.IndividualOrCollective.INDIVIDUAL,
+  individualInsulationWork: [_profileType.IndividualInsulationWork.WINDOW_REPLACEMENT, _profileType.IndividualInsulationWork.WALL_INSULATION],
+  hasInstalledVentilation: _profileType.ThreeChoicesAnswer.UNKNOWN,
+  hasReplacedHeater: _profileType.ThreeChoicesAnswer.UNKNOWN,
+  hotWaterEquipment: _profileType.HotWaterEquipment.SOLAR,
+  warmingFluid: _profileType.WarmingType.ELECTRICITY,
+  hotWaterFluid: _profileType.HotWaterFluid.ELECTRICITY,
+  cookingFluid: _fluid.FluidType.ELECTRICITY,
+  updateDate: _luxon.DateTime.fromISO('0000-01-01T00:00:00.000Z'),
+  equipments: []
+};
+
+var profileTypeReducer = function profileTypeReducer() {
+  var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : initialState;
+  var action = arguments.length > 1 ? arguments[1] : undefined;
+
+  switch (action.type) {
+    case _profileType2.UPDATE_PROFILETYPE:
+    case _profileType2.CREATE_NEW_PROFILETYPE:
+      return _objectSpread(_objectSpread({}, state), action.payload);
+
+    default:
+      return state;
+  }
+};
+
+exports.profileTypeReducer = profileTypeReducer;
+
+/***/ }),
+
 /***/ "Ush/":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -20611,14 +20764,14 @@ var FluidPricesService = /*#__PURE__*/function () {
           while (1) {
             switch (_context2.prev = _context2.next) {
               case 0:
-                query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).where({
+                query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).indexFields(['startDate']).where({
                   startDate: {
                     $lte: date.toISO({
                       suppressMilliseconds: true
                     }).toString()
                   },
                   fluidType: fluidType
-                }).indexFields(['startDate']).sortBy([{
+                }).sortBy([{
                   startDate: 'desc'
                 }]).limitBy(1);
                 _context2.next = 3;
@@ -20658,11 +20811,11 @@ var FluidPricesService = /*#__PURE__*/function () {
           while (1) {
             switch (_context3.prev = _context3.next) {
               case 0:
-                query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).where({
+                query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).indexFields(['fluidType']).where({
                   endDate: {
                     $eq: ''
                   }
-                }).indexFields(['fluidType']).sortBy([{
+                }).sortBy([{
                   fluidType: 'asc'
                 }]).limitBy(3);
                 _context3.next = 3;
@@ -21605,6 +21758,17 @@ var DuelService = /*#__PURE__*/function () {
 
 exports.default = DuelService;
 
+/***/ }),
+
+/***/ "Vppt":
+/***/ (function(module, exports, __webpack_require__) {
+
+exports = module.exports = __webpack_require__("JPst")(false);
+// Module
+exports.push([module.i, ".action-choose {\n  margin: auto;\n}", ""]);
+
+
+
 /***/ }),
 
 /***/ "VzTd":
@@ -21881,6 +22045,8 @@ var _ActionList = _interopRequireDefault(__webpack_require__("si6F"));
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
+__webpack_require__("HdrC");
+
 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); }
 
 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; }
@@ -21898,8 +22064,10 @@ var ActionChoose = function ActionChoose(_ref) {
       showList = _useState4[0],
       setShowList = _useState4[1];
 
-  return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !showList ? /*#__PURE__*/_react.default.createElement(_ActionBegin.default, {
-    action: selectedAction !== null && selectedAction !== void 0 ? selectedAction : undefined,
+  return /*#__PURE__*/_react.default.createElement("div", {
+    className: "action-choose"
+  }, !showList ? /*#__PURE__*/_react.default.createElement(_ActionBegin.default, {
+    action: selectedAction ? selectedAction : undefined,
     setShowList: setShowList,
     userChallenge: userChallenge
   }) : /*#__PURE__*/_react.default.createElement(_ActionList.default, {
@@ -22208,7 +22376,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__("5Wkc");
 
@@ -22344,6 +22512,20 @@ var convertDateToShortDateString = function convertDateToShortDateString(actualD
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+var convertDateToMonthString = function convertDateToMonthString(date) {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 var convertDateToMonthYearString = function convertDateToMonthYearString(date) {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -22476,8 +22658,6 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.default = void 0;
 
-var _defineProperty2 = _interopRequireDefault(__webpack_require__("lSNA"));
-
 var _slicedToArray2 = _interopRequireDefault(__webpack_require__("J4zp"));
 
 var _FormNavigation = _interopRequireDefault(__webpack_require__("Pnfk"));
@@ -22492,48 +22672,39 @@ var _profileType2 = __webpack_require__("D9qV");
 
 var _react = _interopRequireWildcard(__webpack_require__("q1tI"));
 
-var _reactRedux = __webpack_require__("/MKj");
-
 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); }
 
 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; }
 
-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; }
-
-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) { (0, _defineProperty2.default)(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; }
-
 var ProfileTypeFormNumber = function ProfileTypeFormNumber(_ref) {
   var step = _ref.step,
       viewedStep = _ref.viewedStep,
-      currentProfileType = _ref.currentProfileType,
+      profileType = _ref.profileType,
       answerType = _ref.answerType,
       setNextStep = _ref.setNextStep,
-      setPreviousStep = _ref.setPreviousStep;
+      setPreviousStep = _ref.setPreviousStep,
+      isProfileTypeComplete = _ref.isProfileTypeComplete;
 
   var _useI18n = (0, _I18n.useI18n)(),
       t = _useI18n.t;
 
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo.profile;
-  }),
-      isProfileTypeCompleted = _useSelector.isProfileTypeCompleted;
-
   var _useState = (0, _react.useState)(''),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       answer = _useState2[0],
       setAnswer = _useState2[1];
 
   var handlePrevious = (0, _react.useCallback)(function () {
-    setPreviousStep();
-  }, [setPreviousStep]);
+    setPreviousStep(profileType);
+  }, [profileType, setPreviousStep]);
   var handleNext = (0, _react.useCallback)(function () {
-    setNextStep(_objectSpread(_objectSpread({}, currentProfileType), {}, (0, _defineProperty2.default)({}, answerType.attribute, answer)));
-  }, [currentProfileType, setNextStep, answer, answerType.attribute]);
+    profileType[answerType.attribute] = answer;
+    setNextStep(profileType);
+  }, [profileType, setNextStep, answer, answerType.attribute]);
   (0, _react.useEffect)(function () {
-    if (step < viewedStep || isProfileTypeCompleted) {
-      setAnswer(currentProfileType[answerType.attribute]);
+    if (step < viewedStep || isProfileTypeComplete) {
+      setAnswer(profileType[answerType.attribute]);
     }
-  }, [step, viewedStep, currentProfileType, answerType, isProfileTypeCompleted]);
+  }, [step, viewedStep, profileType, answerType, isProfileTypeComplete]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-form-container'
   }, /*#__PURE__*/_react.default.createElement(_FormProgress.default, {
@@ -22541,17 +22712,17 @@ var ProfileTypeFormNumber = function ProfileTypeFormNumber(_ref) {
     formType: 'profile'
   }), /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-question-label'
-  }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), answer != null && /*#__PURE__*/_react.default.createElement("label", {
+  }, t("profile_type.".concat(_profileType2.ProfileTypeStepForm[step].toLowerCase(), ".question"))), answer != null ? /*#__PURE__*/_react.default.createElement("label", {
     className: 'text'
   }, /*#__PURE__*/_react.default.createElement("input", {
     type: 'number',
-    value: answer.toString(),
+    value: answer,
     name: answerType.attribute,
     onChange: function onChange(e) {
       return setAnswer(e.target.value);
     },
     autoFocus: true
-  }), "m\xB2")), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
+  }), "m\xB2") : null), /*#__PURE__*/_react.default.createElement(_FormNavigation.default, {
     step: step,
     handlePrevious: handlePrevious,
     handleNext: handleNext,
@@ -22569,7 +22740,7 @@ exports.default = _default;
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.action-list-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  max-width: 600px;\n  margin: auto;\n  gap: 1rem;\n  width: 100%;\n  box-sizing: border-box;\n  padding: 0 1.5rem;\n}\n\nbutton.action-card {\n  width: 100%;\n  box-sizing: border-box;\n  display: flex;\n  align-items: center;\n  justify-content: flex-start;\n  height: 10rem;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  padding: 1rem;\n}\nbutton.action-card .action-title {\n  text-align: left;\n  color: white;\n  margin-left: 1rem;\n  text-transform: initial;\n  font-size: 1.2rem;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.action-list-container {\n  padding: 1.5rem 2rem;\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: center;\n  max-width: 600px;\n  margin: auto;\n}\n\nbutton.action-card {\n  width: 100%;\n  box-sizing: border-box;\n  display: flex;\n  align-items: center;\n  justify-content: flex-start;\n  height: 10rem;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  padding: 1rem;\n  margin-bottom: 1.5rem;\n}\nbutton.action-card .action-title {\n  text-align: left;\n  color: white;\n  margin-left: 1rem;\n  text-transform: initial;\n  font-size: 1.2rem;\n}", ""]);
 
 
 
@@ -23016,60 +23187,6 @@ var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WE
 
 /***/ }),
 
-/***/ "ZI2v":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.setProfileType = exports.profileTypeSlice = void 0;
-
-var _toolkit = __webpack_require__("i7Pf");
-
-var _fluid = __webpack_require__("5Wkc");
-
-var _profileType = __webpack_require__("D9qV");
-
-var _luxon = __webpack_require__("ExVU");
-
-var initialState = {
-  housingType: _profileType.HousingType.INDIVIDUAL_HOUSE,
-  constructionYear: _profileType.ConstructionYear.BETWEEN_1975_AND_1989,
-  area: '100',
-  occupantsNumber: 4,
-  outsideFacingWalls: _profileType.OutsideFacingWalls.TWO,
-  floor: _profileType.Floor.NOT_APPLICABLE,
-  heating: _profileType.IndividualOrCollective.INDIVIDUAL,
-  coldWater: _profileType.IndividualOrCollective.INDIVIDUAL,
-  hotWater: _profileType.IndividualOrCollective.INDIVIDUAL,
-  individualInsulationWork: [_profileType.IndividualInsulationWork.WINDOW_REPLACEMENT, _profileType.IndividualInsulationWork.WALL_INSULATION],
-  hasInstalledVentilation: _profileType.ThreeChoicesAnswer.UNKNOWN,
-  hasReplacedHeater: _profileType.ThreeChoicesAnswer.UNKNOWN,
-  hotWaterEquipment: _profileType.HotWaterEquipment.SOLAR,
-  warmingFluid: _profileType.WarmingType.ELECTRICITY,
-  hotWaterFluid: _profileType.HotWaterFluid.ELECTRICITY,
-  cookingFluid: _fluid.FluidType.ELECTRICITY,
-  updateDate: _luxon.DateTime.fromISO('0000-01-01T00:00:00.000Z'),
-  equipments: []
-};
-var profileTypeSlice = (0, _toolkit.createSlice)({
-  name: 'profileType',
-  initialState: initialState,
-  reducers: {
-    setProfileType: function setProfileType(state, action) {
-      Object.assign(state, action.payload);
-    }
-  }
-});
-exports.profileTypeSlice = profileTypeSlice;
-var setProfileType = profileTypeSlice.actions.setProfileType;
-exports.setProfileType = setProfileType;
-
-/***/ }),
-
 /***/ "ZOOY":
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
@@ -23554,14 +23671,6 @@ var symbol = new _node_modules_svg_baker_runtime_browser_symbol_js__WEBPACK_IMPO
 var result = _node_modules_svg_sprite_loader_runtime_browser_sprite_build_js__WEBPACK_IMPORTED_MODULE_1___default.a.add(symbol);
 /* harmony default export */ __webpack_exports__["default"] = (symbol);
 
-/***/ }),
-
-/***/ "ZzqV":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
 /***/ }),
 
 /***/ "a3QZ":
@@ -23952,7 +24061,7 @@ var ProfileTypeEntityService = /*#__PURE__*/function () {
                   updateDate: {
                     $lte: date.toString()
                   }
-                }).indexFields(['updateDate']).sortBy([{
+                }).sortBy([{
                   updateDate: 'desc'
                 }]).limitBy(1));
 
@@ -24008,7 +24117,11 @@ var ProfileTypeEntityService = /*#__PURE__*/function () {
 
               case 29:
                 _context.next = 31;
-                return this._client.query(query.where({}).indexFields(['updateDate']).sortBy([{
+                return this._client.query(query.where({
+                  _id: {
+                    $gt: null
+                  }
+                }).sortBy([{
                   updateDate: 'desc'
                 }]).limitBy(1));
 
@@ -24074,7 +24187,7 @@ var ProfileTypeEntityService = /*#__PURE__*/function () {
                   updateDate: {
                     $gte: timePeriod.startDate.toString()
                   }
-                }).indexFields(['updateDate']).sortBy([{
+                }).sortBy([{
                   updateDate: 'asc'
                 }]).limitBy(100));
 
@@ -24148,9 +24261,9 @@ var ProfileTypeEntityService = /*#__PURE__*/function () {
      */
 
   }, {
-    key: "saveProfileType",
+    key: "updateProfileType",
     value: function () {
-      var _saveProfileType = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(attributes) {
+      var _updateProfileType = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee3(attributes) {
         var query, _yield$this$_client$q5, _yield$this$_client$q6, doc, _yield$this$_client$s, profileTypeEntity;
 
         return _regenerator.default.wrap(function _callee3$(_context3) {
@@ -24190,11 +24303,11 @@ var ProfileTypeEntityService = /*#__PURE__*/function () {
         }, _callee3, this);
       }));
 
-      function saveProfileType(_x3) {
-        return _saveProfileType.apply(this, arguments);
+      function updateProfileType(_x3) {
+        return _updateProfileType.apply(this, arguments);
       }
 
-      return saveProfileType;
+      return updateProfileType;
     }()
     /**
      * Deletes Array of ProfileTypes
@@ -24451,6 +24564,8 @@ var _userChallenge = __webpack_require__("dQx6");
 
 var _react = _interopRequireDefault(__webpack_require__("q1tI"));
 
+__webpack_require__("NPzc");
+
 var _ChallengeCardDone = _interopRequireDefault(__webpack_require__("En7H"));
 
 var _ChallengeCardLast = _interopRequireDefault(__webpack_require__("AM8p"));
@@ -24461,8 +24576,6 @@ var _ChallengeCardOnGoing = _interopRequireDefault(__webpack_require__("GSmk"));
 
 var _ChallengeCardUnlocked = _interopRequireDefault(__webpack_require__("x/UR"));
 
-__webpack_require__("NPzc");
-
 var ChallengeCard = function ChallengeCard(_ref) {
   var userChallenge = _ref.userChallenge,
       indexSlider = _ref.indexSlider,
@@ -24558,11 +24671,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -24626,14 +24738,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -24688,6 +24792,7 @@ function formatNumberValues(value, fluidStyle) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -24698,6 +24803,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -24708,6 +24814,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -24719,6 +24826,7 @@ function getRelationships(doc, relNameList) {
   })[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -24764,23 +24872,14 @@ var importIconById = /*#__PURE__*/function () {
     return _ref2.apply(this, arguments);
   };
 }();
-
-exports.importIconById = importIconById;
-
-var getMonthFullName = function getMonthFullName(month) {
-  var monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 var getMonthName = function getMonthName(date) {
   var monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -25199,25 +25298,11 @@ var _reactRouterDom = __webpack_require__("SOjZ");
 
 var _profileEcogestureForm = _interopRequireDefault(__webpack_require__("QCFg"));
 
-var _profile = __webpack_require__("jPH6");
-
-var _profileEcogesture2 = __webpack_require__("Zmlh");
-
 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); }
 
 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; }
 
 var EcogestureFormView = function EcogestureFormView() {
-  var dispatch = (0, _reactRedux.useDispatch)();
-
-  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
-    return state.ecolyo;
-  }),
-      isProfileTypeCompleted = _useSelector.profile.isProfileTypeCompleted,
-      profileEcogesture = _useSelector.profileEcogesture;
-
-  var navigate = (0, _reactRouterDom.useNavigate)();
-
   var _useState = (0, _react.useState)(0),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
       headerHeight = _useState2[0],
@@ -25227,6 +25312,12 @@ var EcogestureFormView = function EcogestureFormView() {
     setHeaderHeight(height);
   };
 
+  var _useSelector = (0, _reactRedux.useSelector)(function (state) {
+    return state.ecolyo;
+  }),
+      isProfileTypeCompleted = _useSelector.profile.isProfileTypeCompleted,
+      curProfileEcogesture = _useSelector.profileEcogesture;
+
   var shouldOpenModal = new URLSearchParams((0, _reactRouterDom.useLocation)().search).get('modal');
 
   var _useState3 = (0, _react.useState)(_ecogestureForm.EcogestureStepForm.HEATING_TYPE),
@@ -25236,7 +25327,7 @@ var EcogestureFormView = function EcogestureFormView() {
 
   var _useState5 = (0, _react.useState)({
     type: _ecogestureForm.ProfileEcogestureAnswerType.SINGLE_CHOICE,
-    attribute: 'heating',
+    attribute: '',
     choices: []
   }),
       _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
@@ -25258,13 +25349,13 @@ var EcogestureFormView = function EcogestureFormView() {
       viewedStep = _useState12[0],
       setViewedStep = _useState12[1];
 
-  var _useState13 = (0, _react.useState)(profileEcogesture),
+  var _useState13 = (0, _react.useState)(curProfileEcogesture),
       _useState14 = (0, _slicedToArray2.default)(_useState13, 2),
-      currentProfileEcogesture = _useState14[0],
-      setCurrentProfileEcogesture = _useState14[1];
+      profileEcogesture = _useState14[0],
+      setProfileEcogesture = _useState14[1];
 
   var setNextStep = (0, _react.useCallback)(function (_profileEcogesture) {
-    setCurrentProfileEcogesture(_profileEcogesture);
+    setProfileEcogesture(_profileEcogesture);
     var pefs = new _profileEcogestureForm.default(_profileEcogesture);
     var nextStep = pefs.getNextFormStep(step);
     setIsLoading(true);
@@ -25278,8 +25369,9 @@ var EcogestureFormView = function EcogestureFormView() {
     setAnswerType(_answerType);
     setStep(nextStep);
   }, [step, viewedStep]);
-  var setPreviousStep = (0, _react.useCallback)(function () {
-    var pefs = new _profileEcogestureForm.default(currentProfileEcogesture);
+  var setPreviousStep = (0, _react.useCallback)(function (_profileEcogesture) {
+    setProfileEcogesture(_profileEcogesture);
+    var pefs = new _profileEcogestureForm.default(_profileEcogesture);
     var previousStep = pefs.getPreviousFormStep(step);
     setIsLoading(true);
 
@@ -25287,24 +25379,13 @@ var EcogestureFormView = function EcogestureFormView() {
 
     setAnswerType(_answerType);
     setStep(previousStep);
-  }, [currentProfileEcogesture, step]);
-  var handleEndForm = (0, _react.useCallback)(function () {
-    dispatch((0, _profileEcogesture2.newProfileEcogestureEntry)(currentProfileEcogesture));
-    dispatch((0, _profile.updateProfile)({
-      isProfileEcogestureCompleted: true
-    }));
-    navigate('/ecogesture-selection');
-  }, [currentProfileEcogesture, dispatch, navigate]);
+  }, [step]);
   (0, _react.useEffect)(function () {
     var _answerType = _profileEcogestureForm.default.getAnswerForStep(step);
 
     setAnswerType(_answerType);
-    setIsLoading(false); // handle end of form
-
-    if (step === _ecogestureForm.EcogestureStepForm.END) {
-      handleEndForm();
-    }
-  }, [handleEndForm, step]);
+    setIsLoading(false);
+  }, [step]);
 
   if (isLoading) {
     return /*#__PURE__*/_react.default.createElement(_Content.default, {
@@ -25321,13 +25402,12 @@ var EcogestureFormView = function EcogestureFormView() {
     height: headerHeight
   }, isProfileTypeCompleted ? /*#__PURE__*/_react.default.createElement(_ProfileTypeView.default, null) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, step === _ecogestureForm.EcogestureStepForm.EQUIPMENTS && /*#__PURE__*/_react.default.createElement(_EcogestureFormEquipment.default, {
     step: _ecogestureForm.EcogestureStepForm.EQUIPMENTS,
-    currentProfileEcogesture: currentProfileEcogesture,
-    setNextStepEcogestureForm: setNextStep,
+    profileEcogesture: profileEcogesture,
     setPreviousStep: setPreviousStep
   }), step !== _ecogestureForm.EcogestureStepForm.EQUIPMENTS && /*#__PURE__*/_react.default.createElement(_EcogestureFormSingleChoice.default, {
     step: step,
     viewedStep: viewedStep,
-    currentProfileEcogesture: currentProfileEcogesture,
+    profileEcogesture: profileEcogesture,
     answerType: answerType,
     setNextStep: setNextStep,
     setPreviousStep: setPreviousStep
@@ -25516,11 +25596,10 @@ var UsageEventService = /*#__PURE__*/function () {
                 _context3.prev = 0;
                 // Get last Connection attempt Event
                 query = (0, _cozyClient.Q)(_doctypes.USAGEEVENT_DOCTYPE).where({
-                  target: konnectorSlug
-                }).partialIndex({
                   type: _usageEvent.UsageEventType.KONNECTOR_ATTEMPT_EVENT,
+                  target: konnectorSlug,
                   result: 'error'
-                }).indexFields(['eventDate', 'type']).sortBy([{
+                }).sortBy([{
                   eventDate: 'desc'
                 }]).limitBy(1);
                 _context3.next = 4;
@@ -25743,21 +25822,6 @@ exports.default = UsageEventService;
 
 /***/ }),
 
-/***/ "dK8s":
-/***/ (function(module, exports, __webpack_require__) {
-
-"use strict";
-
-
-Object.defineProperty(exports, "__esModule", {
-  value: true
-});
-exports.REMOTE_ORG_ECOLYO_DJU = void 0;
-var REMOTE_ORG_ECOLYO_DJU = '/remote/org.ecolyo.dju_v2';
-exports.REMOTE_ORG_ECOLYO_DJU = REMOTE_ORG_ECOLYO_DJU;
-
-/***/ }),
-
 /***/ "dLWW":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -25906,8 +25970,6 @@ var _cozyClient = __webpack_require__("SH7X");
 
 var _I18n = __webpack_require__("buk/");
 
-var _doctypes = __webpack_require__("D2hQ");
-
 var _usageEvent = __webpack_require__("/fHX");
 
 var _userExploration = __webpack_require__("/rev");
@@ -25928,7 +25990,7 @@ var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
 var _profile = __webpack_require__("jPH6");
 
-var _profileType2 = __webpack_require__("ZI2v");
+var _profileType2 = __webpack_require__("TeAr");
 
 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); }
 
@@ -25997,7 +26059,7 @@ var ProfileTypeFinished = function ProfileTypeFinished(_ref) {
                 myProfileTypes = _context.sent;
 
                 if (!(myProfileTypes !== null)) {
-                  _context.next = 21;
+                  _context.next = 13;
                   break;
                 }
 
@@ -26007,43 +26069,30 @@ var ProfileTypeFinished = function ProfileTypeFinished(_ref) {
               case 9:
                 destroyPT = _context.sent;
 
-                if (!destroyPT) {
-                  _context.next = 17;
-                  break;
+                if (destroyPT) {
+                  dispatch((0, _profileType2.newProfileTypeEntry)(consistentProfileType));
+                  setIsSaved(true);
+                  dispatch((0, _profile.updateProfile)({
+                    isProfileEcogestureCompleted: true,
+                    isProfileTypeCompleted: true
+                  }));
+                } else {
+                  console.log('ERROR');
+                  Sentry.captureException('error in profileTypeFinished');
                 }
 
-                _context.next = 13;
-                return createNewProfileType(client, consistentProfileType);
-
-              case 13:
-                setIsSaved(true);
-                dispatch((0, _profile.updateProfile)({
-                  isProfileEcogestureCompleted: true,
-                  isProfileTypeCompleted: true
-                }));
-                _context.next = 19;
-                break;
-
-              case 17:
-                console.log('ERROR');
-                Sentry.captureException('error in profileTypeFinished');
-
-              case 19:
-                _context.next = 25;
+                _context.next = 16;
                 break;
 
-              case 21:
-                _context.next = 23;
-                return createNewProfileType(client, consistentProfileType);
-
-              case 23:
+              case 13:
+                dispatch((0, _profileType2.newProfileTypeEntry)(consistentProfileType));
                 setIsSaved(true);
                 dispatch((0, _profile.updateProfile)({
                   isProfileEcogestureCompleted: true,
                   isProfileTypeCompleted: true
                 }));
 
-              case 25:
+              case 16:
               case "end":
                 return _context.stop();
             }
@@ -26053,39 +26102,6 @@ var ProfileTypeFinished = function ProfileTypeFinished(_ref) {
       return _checkForExistingProfileType.apply(this, arguments);
     }
 
-    function createNewProfileType(_x, _x2) {
-      return _createNewProfileType.apply(this, arguments);
-    }
-
-    function _createNewProfileType() {
-      _createNewProfileType = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee2(client, consistentProfileType) {
-        var _yield$client$create, newProfileType;
-
-        return _regenerator.default.wrap(function _callee2$(_context2) {
-          while (1) {
-            switch (_context2.prev = _context2.next) {
-              case 0:
-                _context2.next = 2;
-                return client.create(_doctypes.PROFILETYPE_DOCTYPE, consistentProfileType);
-
-              case 2:
-                _yield$client$create = _context2.sent;
-                newProfileType = _yield$client$create.data;
-
-                if (newProfileType) {
-                  dispatch((0, _profileType2.setProfileType)(newProfileType));
-                }
-
-              case 5:
-              case "end":
-                return _context2.stop();
-            }
-          }
-        }, _callee2);
-      }));
-      return _createNewProfileType.apply(this, arguments);
-    }
-
     if (!isSaved) {
       checkForExistingProfileType();
 
@@ -26953,7 +26969,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _global = __webpack_require__("c4IZ");
 
@@ -28564,23 +28580,18 @@ var _react = _interopRequireDefault(__webpack_require__("q1tI"));
 
 var _reactRedux = __webpack_require__("/MKj");
 
-var DuelBar = function DuelBar(_ref) {
-  var userChallenge = _ref.userChallenge,
+var DuelBar = function DuelBar(props) {
+  var _ref = props,
+      userChallenge = _ref.userChallenge,
       finishedDataLoad = _ref.finishedDataLoad,
       timeStep = _ref.timeStep,
       average = _ref.average,
-      _ref$width = _ref.width,
-      width = _ref$width === void 0 ? 600 : _ref$width,
-      _ref$height = _ref.height,
-      height = _ref$height === void 0 ? 400 : _ref$height,
-      _ref$marginLeft = _ref.marginLeft,
-      marginLeft = _ref$marginLeft === void 0 ? 10 : _ref$marginLeft,
-      _ref$marginRight = _ref.marginRight,
-      marginRight = _ref$marginRight === void 0 ? 50 : _ref$marginRight,
-      _ref$marginTop = _ref.marginTop,
-      marginTop = _ref$marginTop === void 0 ? 20 : _ref$marginTop,
-      _ref$marginBottom = _ref.marginBottom,
-      marginBottom = _ref$marginBottom === void 0 ? 50 : _ref$marginBottom;
+      width = _ref.width,
+      height = _ref.height,
+      marginLeft = _ref.marginLeft,
+      marginRight = _ref.marginRight,
+      marginTop = _ref.marginTop,
+      marginBottom = _ref.marginBottom;
 
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
     return state.ecolyo.challenge;
@@ -28687,6 +28698,14 @@ var DuelBar = function DuelBar(_ref) {
   }));
 };
 
+DuelBar.defaultProps = {
+  width: 600,
+  height: 400,
+  marginLeft: 10,
+  marginRight: 50,
+  marginTop: 20,
+  marginBottom: 50
+};
 var _default = DuelBar;
 exports.default = _default;
 
@@ -29135,7 +29154,6 @@ exports.EcogestureStepForm = EcogestureStepForm;
   EcogestureStepForm[EcogestureStepForm["WARMING_FLUID"] = 1] = "WARMING_FLUID";
   EcogestureStepForm[EcogestureStepForm["HOT_WATER_TYPE"] = 2] = "HOT_WATER_TYPE";
   EcogestureStepForm[EcogestureStepForm["EQUIPMENTS"] = 3] = "EQUIPMENTS";
-  EcogestureStepForm[EcogestureStepForm["END"] = 4] = "END";
 })(EcogestureStepForm || (exports.EcogestureStepForm = EcogestureStepForm = {}));
 
 var ProfileEcogestureAnswerType;
@@ -30304,37 +30322,33 @@ var ChallengeService = /*#__PURE__*/function () {
     key: "startUserChallenge",
     value: function () {
       var _startUserChallenge = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee11(userChallenge) {
-        var newChallenge, _yield$this$_client$c, updatedUserChallengeEntity, updatedUserChallenge, errorMessage;
+        var _yield$this$_client$c, updatedUserChallengeEntity, updatedUserChallenge, errorMessage;
 
         return _regenerator.default.wrap(function _callee11$(_context12) {
           while (1) {
             switch (_context12.prev = _context12.next) {
               case 0:
-                newChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
-                  state: _userChallenge3.UserChallengeState.ONGOING,
-                  progress: {
-                    actionProgress: 0,
-                    explorationProgress: 0,
-                    quizProgress: 0
-                  },
-                  startDate: _luxon.DateTime.local().setZone('utc', {
-                    keepLocalTime: true
-                  }).startOf('day'),
-                  success: _userChallenge3.UserChallengeSuccess.ONGOING
-                });
-                _context12.prev = 1;
-                _context12.next = 4;
-                return this._client.create(_doctypes.USERCHALLENGE_DOCTYPE, newChallenge);
+                userChallenge.state = _userChallenge3.UserChallengeState.ONGOING;
+                userChallenge.progress.actionProgress = 0;
+                userChallenge.progress.explorationProgress = 0;
+                userChallenge.progress.quizProgress = 0;
+                userChallenge.startDate = _luxon.DateTime.local().setZone('utc', {
+                  keepLocalTime: true
+                }).startOf('day');
+                userChallenge.success = _userChallenge3.UserChallengeSuccess.ONGOING;
+                _context12.prev = 6;
+                _context12.next = 9;
+                return this._client.create(_doctypes.USERCHALLENGE_DOCTYPE, userChallenge);
 
-              case 4:
+              case 9:
                 _yield$this$_client$c = _context12.sent;
                 updatedUserChallengeEntity = _yield$this$_client$c.data;
                 updatedUserChallenge = this.parseUserChallengeEntityToUserChallenge(updatedUserChallengeEntity);
                 return _context12.abrupt("return", updatedUserChallenge);
 
-              case 10:
-                _context12.prev = 10;
-                _context12.t0 = _context12["catch"](1);
+              case 15:
+                _context12.prev = 15;
+                _context12.t0 = _context12["catch"](6);
                 errorMessage = "Challenge service error on startUserChallenge: ".concat(JSON.stringify(_context12.t0));
                 logStack('error', errorMessage);
 
@@ -30343,12 +30357,12 @@ var ChallengeService = /*#__PURE__*/function () {
                 Sentry.captureException(errorMessage);
                 throw _context12.t0;
 
-              case 17:
+              case 22:
               case "end":
                 return _context12.stop();
             }
           }
-        }, _callee11, this, [[1, 10]]);
+        }, _callee11, this, [[6, 15]]);
       }));
 
       function startUserChallenge(_x21) {
@@ -30369,7 +30383,7 @@ var ChallengeService = /*#__PURE__*/function () {
     key: "updateUserChallenge",
     value: function () {
       var _updateUserChallenge = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee12(userChallenge, flag, quizWithUpdatedQuestions, fluidStatus, action) {
-        var updatedUserChallenge, updatedDuel, updatedQuiz, updatedExploration, updatedAction, duelService, quizService, explorationService, actionService, updateQuizProgress, userAction, _yield$this$_client$s, userChallengeEntity, result, errorMessage;
+        var updatedUserChallenge, updatedDuel, updatedQuiz, updatedExploration, updatedAction, duelService, quizService, explorationService, actionService, userAction, _yield$this$_client$s, userChallengeEntity, result, errorMessage;
 
         return _regenerator.default.wrap(function _callee12$(_context13) {
           while (1) {
@@ -30384,12 +30398,12 @@ var ChallengeService = /*#__PURE__*/function () {
                 explorationService = new _exploration.default(this._client);
                 actionService = new _action.default(this._client);
                 _context13.t0 = flag;
-                _context13.next = _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.CHALLENGE ? 11 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_CONSUMPTION ? 11 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_UNLOCK ? 13 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_UPDATE_THRESHOLD ? 18 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_START ? 23 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_WIN ? 28 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_LOSS ? 33 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_START ? 38 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_DONE ? 43 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_UPDATE ? 49 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_RESET ? 51 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_START ? 56 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_UPDATE ? 61 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_NOTIFICATION ? 66 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_DONE ? 71 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_START ? 74 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_NOTIFICATION ? 78 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_DONE ? 81 : 84;
+                _context13.next = _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.CHALLENGE ? 11 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_CONSUMPTION ? 11 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_UNLOCK ? 13 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_UPDATE_THRESHOLD ? 18 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_START ? 23 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_WIN ? 28 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.DUEL_LOSS ? 33 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_START ? 38 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_DONE ? 43 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_UPDATE ? 50 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.QUIZ_RESET ? 52 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_START ? 57 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_UPDATE ? 62 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_NOTIFICATION ? 67 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.EXPLORATION_DONE ? 72 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_START ? 75 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_NOTIFICATION ? 79 : _context13.t0 === _userChallenge3.UserChallengeUpdateFlag.ACTION_DONE ? 82 : 85;
                 break;
 
               case 11:
                 updatedUserChallenge = userChallenge;
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 13:
                 _context13.next = 15;
@@ -30401,7 +30415,7 @@ var ChallengeService = /*#__PURE__*/function () {
                   state: _userChallenge3.UserChallengeState.DUEL,
                   duel: updatedDuel
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 18:
                 _context13.next = 20;
@@ -30413,7 +30427,7 @@ var ChallengeService = /*#__PURE__*/function () {
                   state: _userChallenge3.UserChallengeState.DUEL,
                   duel: updatedDuel
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 23:
                 _context13.next = 25;
@@ -30425,7 +30439,7 @@ var ChallengeService = /*#__PURE__*/function () {
                   state: _userChallenge3.UserChallengeState.DUEL,
                   duel: updatedDuel
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 28:
                 _context13.next = 30;
@@ -30441,7 +30455,7 @@ var ChallengeService = /*#__PURE__*/function () {
                   }).startOf('day'),
                   success: _userChallenge3.UserChallengeSuccess.WIN
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 33:
                 _context13.next = 35;
@@ -30457,7 +30471,7 @@ var ChallengeService = /*#__PURE__*/function () {
                   }).startOf('day'),
                   success: _userChallenge3.UserChallengeSuccess.LOST
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 38:
                 _context13.next = 40;
@@ -30468,74 +30482,78 @@ var ChallengeService = /*#__PURE__*/function () {
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   quiz: updatedQuiz
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
               case 43:
-                updateQuizProgress = Math.min(userChallenge.quiz.result, 5);
-                _context13.next = 46;
+                if (userChallenge.quiz.result > userChallenge.progress.quizProgress) {
+                  userChallenge.progress.quizProgress = userChallenge.quiz.result;
+                }
+
+                if (userChallenge.progress.quizProgress > 5) {
+                  userChallenge.progress.quizProgress = 5;
+                }
+
+                _context13.next = 47;
                 return quizService.endUserQuiz(userChallenge.quiz);
 
-              case 46:
+              case 47:
                 updatedQuiz = _context13.sent;
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
-                  quiz: updatedQuiz,
-                  progress: _objectSpread(_objectSpread({}, userChallenge.progress), {}, {
-                    quizProgress: updateQuizProgress
-                  })
+                  quiz: updatedQuiz
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 49:
+              case 50:
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   quiz: quizWithUpdatedQuestions ? quizWithUpdatedQuestions : userChallenge.quiz
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 51:
-                _context13.next = 53;
+              case 52:
+                _context13.next = 54;
                 return quizService.resetUserQuiz(userChallenge.quiz);
 
-              case 53:
+              case 54:
                 updatedQuiz = _context13.sent;
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   quiz: updatedQuiz
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 56:
-                _context13.next = 58;
+              case 57:
+                _context13.next = 59;
                 return explorationService.startUserExploration(userChallenge.exploration);
 
-              case 58:
+              case 59:
                 updatedExploration = _context13.sent;
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   exploration: updatedExploration
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 61:
-                _context13.next = 63;
+              case 62:
+                _context13.next = 64;
                 return explorationService.updateUserExploration(userChallenge.exploration);
 
-              case 63:
+              case 64:
                 updatedExploration = _context13.sent;
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   exploration: updatedExploration
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 66:
-                _context13.next = 68;
+              case 67:
+                _context13.next = 69;
                 return explorationService.awaitNotificationUserExploration(userChallenge.exploration);
 
-              case 68:
+              case 69:
                 updatedExploration = _context13.sent;
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   exploration: updatedExploration
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 71:
+              case 72:
                 updatedExploration = explorationService.endUserExploration(userChallenge.exploration);
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   exploration: updatedExploration,
@@ -30543,9 +30561,9 @@ var ChallengeService = /*#__PURE__*/function () {
                     explorationProgress: updatedExploration.progress
                   })
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 74:
+              case 75:
                 userAction = userChallenge.action;
 
                 if (action) {
@@ -30555,16 +30573,16 @@ var ChallengeService = /*#__PURE__*/function () {
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   action: userAction
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 78:
+              case 79:
                 updatedAction = actionService.awaitNotificationAction(userChallenge.action);
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   action: updatedAction
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 81:
+              case 82:
                 updatedAction = actionService.endAction(userChallenge.action);
                 updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
                   action: updatedAction,
@@ -30572,26 +30590,26 @@ var ChallengeService = /*#__PURE__*/function () {
                     actionProgress: 5
                   })
                 });
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 84:
+              case 85:
                 updatedUserChallenge = userChallenge;
-                return _context13.abrupt("break", 86);
+                return _context13.abrupt("break", 87);
 
-              case 86:
-                _context13.prev = 86;
-                _context13.next = 89;
+              case 87:
+                _context13.prev = 87;
+                _context13.next = 90;
                 return this._client.save(updatedUserChallenge);
 
-              case 89:
+              case 90:
                 _yield$this$_client$s = _context13.sent;
                 userChallengeEntity = _yield$this$_client$s.data;
                 result = this.parseUserChallengeEntityToUserChallenge(userChallengeEntity);
                 return _context13.abrupt("return", result);
 
-              case 95:
-                _context13.prev = 95;
-                _context13.t1 = _context13["catch"](86);
+              case 96:
+                _context13.prev = 96;
+                _context13.t1 = _context13["catch"](87);
                 errorMessage = "Update user challenge error: ".concat(JSON.stringify(_context13.t1));
                 logStack('error', errorMessage);
 
@@ -30600,12 +30618,12 @@ var ChallengeService = /*#__PURE__*/function () {
                 Sentry.captureException(errorMessage);
                 throw _context13.t1;
 
-              case 102:
+              case 103:
               case "end":
                 return _context13.stop();
             }
           }
-        }, _callee12, this, [[86, 95]]);
+        }, _callee12, this, [[87, 96]]);
       }));
 
       function updateUserChallenge(_x22, _x23, _x24, _x25, _x26) {
@@ -30942,7 +30960,7 @@ var _reactRedux = __webpack_require__("/MKj");
 
 var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("HvHZ");
 
@@ -31194,10 +31212,10 @@ var _picto = __webpack_require__("6DBe");
 
 var _utils = __webpack_require__("c+yx");
 
-var _EfficiencyRating = _interopRequireDefault(__webpack_require__("Zjkz"));
-
 __webpack_require__("PsAx");
 
+var _EfficiencyRating = _interopRequireDefault(__webpack_require__("Zjkz"));
+
 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); }
 
 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; }
@@ -31949,7 +31967,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _global = __webpack_require__("c4IZ");
 
@@ -32174,8 +32192,8 @@ var ProfileTypeView = function ProfileTypeView() {
     return state.ecolyo;
   }),
       profile = _useSelector.profile,
-      profileType = _useSelector.profileType,
-      profileEcogesture = _useSelector.profileEcogesture;
+      curProfileType = _useSelector.profileType,
+      curProfileEcogesture = _useSelector.profileEcogesture;
 
   var _useState = (0, _react.useState)(0),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
@@ -32205,8 +32223,8 @@ var ProfileTypeView = function ProfileTypeView() {
     equipments: []
   }),
       _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      currentProfileType = _useState4[0],
-      setCurrentProfileType = _useState4[1];
+      profileType = _useState4[0],
+      setProfileType = _useState4[1];
 
   var _useState5 = (0, _react.useState)(_profileType2.ProfileTypeStepForm.HOUSING_TYPE),
       _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
@@ -32215,7 +32233,7 @@ var ProfileTypeView = function ProfileTypeView() {
 
   var _useState7 = (0, _react.useState)({
     type: _profileType2.ProfileTypeFormType.SINGLE_CHOICE,
-    attribute: 'housingType',
+    attribute: '',
     choices: []
   }),
       _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
@@ -32234,27 +32252,19 @@ var ProfileTypeView = function ProfileTypeView() {
 
   var defineHeaderHeight = (0, _react.useCallback)(function (height) {
     setHeaderHeight(height);
-  }, []); // if ecogesture profile is completed, update default profileType
-
-  (0, _react.useEffect)(function () {
-    if (profile.isProfileEcogestureCompleted) {
-      setCurrentProfileType(_objectSpread(_objectSpread({}, profileType), {}, {
-        hotWater: profileEcogesture.hotWater,
-        heating: profileEcogesture.heating,
-        warmingFluid: profileEcogesture.warmingFluid,
-        equipments: profileEcogesture.equipments
-      }));
-    }
-  }, [profile.isProfileEcogestureCompleted, profileEcogesture.equipments, profileEcogesture.heating, profileEcogesture.hotWater, profileEcogesture.warmingFluid, profileType]);
+  }, []);
   var setNextStep = (0, _react.useCallback)(function (_profileType) {
     var profileTypeFormService;
 
     if (_profileType) {
-      setCurrentProfileType(_profileType);
+      setProfileType(_profileType);
       profileTypeFormService = new _profileTypeForm.default(_profileType);
+      curProfileEcogesture.heating = _profileType.heating;
+      curProfileEcogesture.hotWater = _profileType.hotWater;
+      curProfileEcogesture.warmingFluid = _profileType.warmingFluid;
     } else {
-      // if equipments are updated, keep currentProfileType as it is
-      profileTypeFormService = new _profileTypeForm.default(_objectSpread({}, currentProfileType));
+      // if equipments are updated, keep profileType as it is
+      profileTypeFormService = new _profileTypeForm.default(_objectSpread({}, profileType));
     }
 
     var nextStep = profileTypeFormService.getNextFormStep(step, !profile.isProfileTypeCompleted);
@@ -32265,94 +32275,86 @@ var ProfileTypeView = function ProfileTypeView() {
     }
 
     setStep(nextStep);
-  }, [profile.isProfileTypeCompleted, currentProfileType, step, viewedStep]);
-  var setPreviousStep = (0, _react.useCallback)(function () {
-    var profileTypeFormService = new _profileTypeForm.default(currentProfileType);
+  }, [curProfileEcogesture, profile.isProfileTypeCompleted, profileType, step, viewedStep]);
+  var setPreviousStep = (0, _react.useCallback)(function (_profileType) {
+    setProfileType(_profileType);
+    var profileTypeFormService = new _profileTypeForm.default(_profileType);
     var previousStep = profileTypeFormService.getPreviousFormStep(step);
     setIsLoading(true);
     setStep(previousStep);
-  }, [currentProfileType, step]);
-  (0, _react.useEffect)(function () {
-    var _answerType = _profileTypeForm.default.getAnswerForStep(step);
-
-    setAnswerType(_answerType);
-    setIsLoading(false);
   }, [step]);
-  /** If profileType OR ecogestureProfile is completed, apply it to local state */
-
-  (0, _react.useEffect)(function () {
-    if (profile.isProfileTypeCompleted) {
-      setCurrentProfileType(_objectSpread({}, profileType));
-      return;
-    }
-
-    if (profile.isProfileEcogestureCompleted) {
-      // Default state + ecogestureProfile
-      setCurrentProfileType(_objectSpread(_objectSpread({}, currentProfileType), {}, {
-        hotWater: profileEcogesture.hotWater,
-        heating: profileEcogesture.heating,
-        warmingFluid: profileEcogesture.warmingFluid,
-        equipments: profileEcogesture.equipments
-      }));
-    } // eslint-disable-next-line react-hooks/exhaustive-deps
-
-  }, [profileType, profile, profile.isProfileEcogestureCompleted]);
 
   var selectForm = function selectForm() {
     if (answerType.type === _profileType2.ProfileTypeFormType.SINGLE_CHOICE) {
       return /*#__PURE__*/_react.default.createElement(_ProfileTypeFormSingleChoice.default, {
         step: step,
         viewedStep: viewedStep,
-        currentProfileType: currentProfileType,
+        profileType: profileType,
         answerType: answerType,
         setNextStep: setNextStep,
+        isProfileTypeComplete: profile.isProfileTypeCompleted,
         setPreviousStep: setPreviousStep
       });
     } else if (answerType.type === _profileType2.ProfileTypeFormType.MULTI_CHOICE) {
       return /*#__PURE__*/_react.default.createElement(_ProfileTypeFormMultiChoice.default, {
         step: step,
         viewedStep: viewedStep,
-        currentProfileType: currentProfileType,
+        profileType: profileType,
         answerType: answerType,
         setNextStep: setNextStep,
-        setPreviousStep: setPreviousStep
+        setPreviousStep: setPreviousStep,
+        isProfileTypeComplete: profile.isProfileTypeCompleted
       });
     } else if (answerType.type === _profileType2.ProfileTypeFormType.NUMBER) {
       return /*#__PURE__*/_react.default.createElement(_ProfileTypeFormNumber.default, {
         step: step,
         viewedStep: viewedStep,
-        currentProfileType: currentProfileType,
+        profileType: profileType,
         answerType: answerType,
         setNextStep: setNextStep,
+        isProfileTypeComplete: profile.isProfileTypeCompleted,
         setPreviousStep: setPreviousStep
       });
     } else if (answerType.type === _profileType2.ProfileTypeFormType.NUMBER_SELECTION) {
       return /*#__PURE__*/_react.default.createElement(_ProfileTypeFormNumberSelection.default, {
         step: step,
         viewedStep: viewedStep,
-        currentProfileType: currentProfileType,
+        profileType: profileType,
         answerType: answerType,
         setNextStep: setNextStep,
+        isProfileTypeComplete: profile.isProfileTypeCompleted,
         setPreviousStep: setPreviousStep
       });
     } else if (answerType.type === _profileType2.ProfileTypeFormType.DATE_SELECTION) {
       return /*#__PURE__*/_react.default.createElement(_ProfileTypeFormDateSelection.default, {
         step: step,
-        profileType: currentProfileType,
+        viewedStep: viewedStep,
+        profileType: profileType,
         answerType: answerType,
         setNextStep: setNextStep,
+        isProfileTypeComplete: profile.isProfileTypeCompleted,
         setPreviousStep: setPreviousStep
       });
     } else if (answerType.type === _profileType2.ProfileTypeFormType.EQUIPMENT_SELECTION) {
       return /*#__PURE__*/_react.default.createElement(_EcogestureFormEquipment.default, {
         step: step,
-        currentProfileType: currentProfileType,
-        setNextStepProfileForm: setNextStep,
+        profileEcogesture: curProfileEcogesture,
+        setNextStep: setNextStep,
         setPreviousStep: setPreviousStep
       });
     }
   };
 
+  (0, _react.useEffect)(function () {
+    if (profile.isProfileTypeCompleted) {
+      setProfileType(curProfileType);
+    }
+
+    var _answerType = _profileTypeForm.default.getAnswerForStep(step);
+
+    setAnswerType(_answerType);
+    setIsLoading(false);
+  }, [step, profile, curProfileType]);
   return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_CozyBar.default, {
     titleKey: 'common.title_profiletype',
     displayBackArrow: true
@@ -32365,7 +32367,7 @@ var ProfileTypeView = function ProfileTypeView() {
   }, /*#__PURE__*/_react.default.createElement("div", {
     className: 'profile-type-container'
   }, isLoading && /*#__PURE__*/_react.default.createElement(_Loader.default, null), !isLoading && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, step !== _profileType2.ProfileTypeStepForm.END && selectForm(), step === _profileType2.ProfileTypeStepForm.END && /*#__PURE__*/_react.default.createElement(_ProfileTypeFinished.default, {
-    profileType: currentProfileType
+    profileType: profileType
   })))));
 };
 
@@ -32616,7 +32618,7 @@ if(false) {}
 
 exports = module.exports = __webpack_require__("JPst")(false);
 // Module
-exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.action-begin {\n  margin: auto;\n}\n\n.action-container {\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  margin: auto;\n  padding: 1.5rem;\n}\n\n.action-begin-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: space-around;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  transition: all 300ms ease;\n  color: #ffffff;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  height: auto;\n  gap: 1.5rem;\n  max-height: 63svh;\n  text-align: center;\n  position: relative;\n  padding: 5rem 1rem 1rem 1rem;\n}\n@media (min-width: 1201px) {\n  .action-begin-container {\n    margin: 6rem 1rem 1rem 1rem;\n  }\n}\n.action-begin-container .icon-container {\n  width: 8.125rem;\n  height: 8.125rem;\n  position: absolute;\n  left: 0;\n  right: 0;\n  margin: 0 auto;\n  top: -70px;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 8px;\n  border: solid 2px #58ffff;\n  display: flex;\n}\n.action-begin-container .action-icon {\n  margin: auto;\n}\n.action-begin-container .action-icon-stars {\n  margin-top: -4rem;\n}\n.action-begin-container .stars .star:not(:last-of-type) {\n  margin-right: 0.4rem;\n}\n.action-begin-container .action-duration {\n  color: #e0e0e0;\n}\n.action-begin-container .action-explanation {\n  margin-bottom: 2rem;\n  line-height: 24px;\n  padding: 1rem;\n}\n@media (min-width: 1201px) {\n  .action-begin-container .action-explanation {\n    padding: 0rem 2rem;\n  }\n}\n.action-begin-container .action-buttons button {\n  padding: 0.7rem;\n  border-color: #e0e0e0;\n  margin-top: 0.5rem;\n}\n.action-begin-container .action-buttons button span {\n  font-weight: 700;\n}", ""]);
+exports.push([module.i, "/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.action-container {\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  margin: auto;\n  padding: 1.5rem;\n}\n\n.action-begin-container {\n  display: flex;\n  flex-direction: column;\n  align-items: center;\n  justify-content: space-around;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  transition: all 300ms ease;\n  color: #ffffff;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  height: 63vh;\n  text-align: center;\n  position: relative;\n  padding: 5rem 1rem 1rem 1rem;\n}\n@media (min-width: 1201px) {\n  .action-begin-container {\n    margin: 6rem 1rem 1rem 1rem;\n  }\n}\n.action-begin-container .icon-container {\n  width: 8.125rem;\n  height: 8.125rem;\n  position: absolute;\n  left: 0;\n  right: 0;\n  margin: 0 auto;\n  top: -70px;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 8px;\n  border: solid 2px #58ffff;\n  display: flex;\n}\n.action-begin-container .action-icon {\n  margin: auto;\n}\n.action-begin-container .action-icon-stars {\n  margin-top: -4rem;\n}\n.action-begin-container .stars .star:not(:last-of-type) {\n  margin-right: 0.4rem;\n}\n.action-begin-container .action-duration {\n  color: #e0e0e0;\n}\n.action-begin-container .action-explanation {\n  margin-bottom: 2rem;\n  line-height: 24px;\n  padding: 1rem;\n}\n@media (min-width: 1201px) {\n  .action-begin-container .action-explanation {\n    padding: 0rem 2rem;\n  }\n}\n.action-begin-container .action-buttons button {\n  padding: 0.7rem;\n  border-color: #e0e0e0;\n  margin-top: 0.5rem;\n}\n.action-begin-container .action-buttons button span {\n  font-weight: 700;\n}", ""]);
 
 
 
@@ -32707,6 +32709,62 @@ exports.openFeedbackModal = openFeedbackModal;
 
 /***/ }),
 
+/***/ "ojwR":
+/***/ (function(module, exports, __webpack_require__) {
+
+"use strict";
+
+
+Object.defineProperty(exports, "__esModule", {
+  value: true
+});
+exports.UPDATE_USER_CHALLENGE_LIST = exports.UNLOCK_NEXT_USER_CHALLENGE = exports.SET_USER_CHALLENGE_LIST = exports.SET_CHALLENGE_CONSUMPTION = void 0;
+exports.setChallengeConsumption = setChallengeConsumption;
+exports.setUserChallengeList = setUserChallengeList;
+exports.unlockNextUserChallenge = unlockNextUserChallenge;
+exports.updateUserChallengeList = updateUserChallengeList;
+var SET_USER_CHALLENGE_LIST = 'SET_USER_CHALLENGE_LIST';
+exports.SET_USER_CHALLENGE_LIST = SET_USER_CHALLENGE_LIST;
+var UPDATE_USER_CHALLENGE_LIST = 'UPDATE_USER_CHALLENGE_LIST';
+exports.UPDATE_USER_CHALLENGE_LIST = UPDATE_USER_CHALLENGE_LIST;
+var UNLOCK_NEXT_USER_CHALLENGE = 'UNLOCK_NEXT_USER_CHALLENGE';
+exports.UNLOCK_NEXT_USER_CHALLENGE = UNLOCK_NEXT_USER_CHALLENGE;
+var SET_CHALLENGE_CONSUMPTION = 'SET_CHALLENGE_CONSUMPTION';
+exports.SET_CHALLENGE_CONSUMPTION = SET_CHALLENGE_CONSUMPTION;
+
+function setUserChallengeList(userChallengeList) {
+  return {
+    type: SET_USER_CHALLENGE_LIST,
+    payload: userChallengeList
+  };
+}
+
+function updateUserChallengeList(userChallenge) {
+  return {
+    type: UPDATE_USER_CHALLENGE_LIST,
+    payload: userChallenge
+  };
+}
+
+function unlockNextUserChallenge(userChallenge) {
+  return {
+    type: UNLOCK_NEXT_USER_CHALLENGE,
+    payload: userChallenge
+  };
+}
+
+function setChallengeConsumption(userChallenge, currentDataload) {
+  return {
+    type: SET_CHALLENGE_CONSUMPTION,
+    payload: {
+      userChallenge: userChallenge,
+      currentDataload: currentDataload
+    }
+  };
+}
+
+/***/ }),
+
 /***/ "ovFf":
 /***/ (function(module, exports, __webpack_require__) {
 
@@ -32747,7 +32805,7 @@ exports.i(__webpack_require__("tgIe"), "");
 exports.push([module.i, "@import url(https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap);", ""]);
 
 // Module
-exports.push([module.i, "/* Cozy UI utilities classes */\n/* Cozy UI React components styles */\n/* App styles */\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nhtml {\n  background: #121212;\n}\n\nbody {\n  background: #121212;\n  overflow: unset !important;\n}\n\n.column {\n  display: flex;\n  flex-direction: column;\n}\n\n.row {\n  display: flex;\n  flex-direction: row;\n}\n\n.cozy-bar {\n  width: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  margin-left: 0;\n}\n\n[role=banner] .coz-bar-container {\n  background-color: #ffffff;\n}\n@media only screen and (max-width : 768px) {\n  [role=banner] .coz-bar-container {\n    padding: 0.6rem 0 0 0;\n    background-color: unset;\n  }\n}\n\n.coz-bar-wrapper {\n  box-shadow: unset !important;\n  background: unset !important;\n}\n\n.coz-label {\n  color: #32363f;\n}\n\n.content-view-loading {\n  height: 80vh;\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  color: #e0e0e0;\n}\n.content-view-loading .content-view-loading-text {\n  padding-top: 1rem;\n  margin: 0 2rem;\n  text-align: center;\n}\n.content-view-loading .content-view-loading-button {\n  max-width: 50vw;\n  margin-top: 1rem;\n}\n\n[role=main] {\n  /* width */\n  /* Track */\n  /* Handle */\n}\n[role=main]::-webkit-scrollbar {\n  width: 10px;\n}\n[role=main]::-webkit-scrollbar-track {\n  background: #3e4045;\n}\n[role=main]::-webkit-scrollbar-thumb {\n  background: #6f7074;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n* {\n  font-family: Lato, sans-serif;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\np {\n  color: #a0a0a0;\n  font-family: Lato, sans-serif;\n}\n\n.home-title {\n  font-size: 1rem;\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  line-height: 120%;\n  text-transform: uppercase;\n}\n\n.app-title {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 21px;\n  line-height: 24px;\n  text-align: center;\n  letter-spacing: 0.15px;\n  color: #e0e0e0;\n  text-shadow: 0px -1px 0px #060609, 0px 1px 0px rgba(255, 255, 255, 0.07);\n}\n\n.text-10, .text-10-italic, .text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase, .text-10-normal, .text-10-normal-150, .text-10-normal-uppercase {\n  font-style: normal;\n  font-size: 0.625rem;\n  line-height: 120%;\n}\n.text-10-normal, .text-10-normal-150, .text-10-normal-uppercase {\n  font-weight: normal;\n}\n.text-10-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-10-normal-150 {\n  line-height: 150%;\n}\n.text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase {\n  font-weight: 700;\n}\n.text-10-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-10-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-10-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-14, .text-14-italic, .text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase, .text-14-normal, .text-14-normal-150, .text-14-normal-uppercase {\n  font-style: normal;\n  font-size: 0.875rem;\n  line-height: 120%;\n}\n.text-14-normal, .text-14-normal-150, .text-14-normal-uppercase {\n  font-weight: normal;\n}\n.text-14-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-14-normal-150 {\n  line-height: 150%;\n}\n.text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase {\n  font-weight: 700;\n}\n.text-14-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-14-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-14-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-15, .text-15-italic, .text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase, .text-15-normal, .text-15-normal-150, .text-15-normal-uppercase {\n  font-style: normal;\n  font-size: 0.938rem;\n  line-height: 120%;\n}\n.text-15-normal, .text-15-normal-150, .text-15-normal-uppercase {\n  font-weight: normal;\n}\n.text-15-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-15-normal-150 {\n  line-height: 150%;\n}\n.text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase {\n  font-weight: 700;\n}\n.text-15-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-15-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-15-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-16, .text-16-italic, .text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase, .text-16-normal, .text-16-normal-150, .text-16-normal-uppercase {\n  font-style: normal;\n  font-size: 1rem;\n  line-height: 120%;\n}\n.text-16-normal, .text-16-normal-150, .text-16-normal-uppercase {\n  font-weight: normal;\n}\n.text-16-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-16-normal-150 {\n  line-height: 150%;\n}\n.text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase {\n  font-weight: 700;\n}\n.text-16-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-16-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-16-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-18, .text-18-italic, .text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase, .text-18-normal, .text-18-normal-150, .text-18-normal-uppercase {\n  font-style: normal;\n  font-size: 1.125rem;\n  line-height: 120%;\n}\n.text-18-normal, .text-18-normal-150, .text-18-normal-uppercase {\n  font-weight: normal;\n}\n.text-18-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-18-normal-150 {\n  line-height: 150%;\n}\n.text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase {\n  font-weight: 700;\n}\n.text-18-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-18-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-18-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-19, .text-19-italic, .text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase, .text-19-normal, .text-19-normal-150, .text-19-normal-uppercase {\n  font-style: normal;\n  font-size: 1.188rem;\n  line-height: 120%;\n}\n.text-19-normal, .text-19-normal-150, .text-19-normal-uppercase {\n  font-weight: normal;\n}\n.text-19-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-19-normal-150 {\n  line-height: 150%;\n}\n.text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase {\n  font-weight: 700;\n}\n.text-19-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-19-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-19-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-20, .text-20-italic, .text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase, .text-20-normal, .text-20-normal-150, .text-20-normal-uppercase {\n  font-style: normal;\n  font-size: 1.25rem;\n  line-height: 120%;\n}\n.text-20-normal, .text-20-normal-150, .text-20-normal-uppercase {\n  font-weight: normal;\n}\n.text-20-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-20-normal-150 {\n  line-height: 150%;\n}\n.text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase {\n  font-weight: 700;\n}\n.text-20-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-20-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-20-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-21, .text-21-italic, .text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase, .text-21-normal, .text-21-normal-150, .text-21-normal-uppercase {\n  font-style: normal;\n  font-size: 1.313rem;\n  line-height: 120%;\n}\n.text-21-normal, .text-21-normal-150, .text-21-normal-uppercase {\n  font-weight: normal;\n}\n.text-21-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-21-normal-150 {\n  line-height: 150%;\n}\n.text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase {\n  font-weight: 700;\n}\n.text-21-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-21-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-21-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-22, .text-22-italic, .text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase, .text-22-normal, .text-22-normal-150, .text-22-normal-uppercase {\n  font-style: normal;\n  font-size: 1.375rem;\n  line-height: 120%;\n}\n.text-22-normal, .text-22-normal-150, .text-22-normal-uppercase {\n  font-weight: normal;\n}\n.text-22-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-22-normal-150 {\n  line-height: 150%;\n}\n.text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase {\n  font-weight: 700;\n}\n.text-22-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-22-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-22-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-24, .text-24-italic, .text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase, .text-24-normal, .text-24-normal-150, .text-24-normal-uppercase {\n  font-style: normal;\n  font-size: 1.5rem;\n  line-height: 120%;\n}\n.text-24-normal, .text-24-normal-150, .text-24-normal-uppercase {\n  font-weight: normal;\n}\n.text-24-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-24-normal-150 {\n  line-height: 150%;\n}\n.text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase {\n  font-weight: 700;\n}\n.text-24-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-24-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-24-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-26, .text-26-italic, .text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase, .text-26-normal, .text-26-normal-150, .text-26-normal-uppercase {\n  font-style: normal;\n  font-size: 1.625rem;\n  line-height: 120%;\n}\n.text-26-normal, .text-26-normal-150, .text-26-normal-uppercase {\n  font-weight: normal;\n}\n.text-26-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-26-normal-150 {\n  line-height: 150%;\n}\n.text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase {\n  font-weight: 700;\n}\n.text-26-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-26-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-26-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-28, .text-28-italic, .text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase, .text-28-normal, .text-28-normal-150, .text-28-normal-uppercase {\n  font-style: normal;\n  font-size: 1.75rem;\n  line-height: 120%;\n}\n.text-28-normal, .text-28-normal-150, .text-28-normal-uppercase {\n  font-weight: normal;\n}\n.text-28-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-28-normal-150 {\n  line-height: 150%;\n}\n.text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase {\n  font-weight: 700;\n}\n.text-28-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-28-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-28-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-36, .text-36-italic, .text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase, .text-36-normal, .text-36-normal-150, .text-36-normal-uppercase {\n  font-style: normal;\n  font-size: 2.25rem;\n  line-height: 120%;\n}\n.text-36-normal, .text-36-normal-150, .text-36-normal-uppercase {\n  font-weight: normal;\n}\n.text-36-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-36-normal-150 {\n  line-height: 150%;\n}\n.text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase {\n  font-weight: 700;\n}\n.text-36-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-36-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-36-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n/* Card */\n.card-title-on {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1.125rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-text-bold {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-indicator {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n/* Chart */\n.chart-ticks-x-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n}\n@media only screen and (max-width : 768px) {\n  .chart-ticks-x-text {\n    font-size: 0.685rem;\n  }\n}\n\n.chart-ticks-y-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 0.9rem;\n  line-height: 120%;\n}\n@media only screen and (max-width : 768px) {\n  .chart-ticks-y-text {\n    font-size: 0.75rem;\n  }\n}\n\n/* Cozy bar */\n.cozybar {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 1.3125rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.axis {\n  color: #7b7b7b;\n}\n.axis .tick-text {\n  fill: #7b7b7b;\n}\n.axis .tick-text.tick-text-selected {\n  fill: #e0e0e0;\n}\n.axis .separator {\n  text-align: center;\n  margin: 0 2px;\n  font-size: 1rem !important;\n}\n\n.value-text {\n  fill: #7b7b7b;\n}\n.value-text.selected {\n  fill: #e0e0e0;\n}\n\n.barContainer.disabled *,\n.barFill.disabled * {\n  cursor: default !important;\n}\n.barContainer:hover,\n.barFill:hover {\n  cursor: pointer;\n}\n\n.background-true {\n  opacity: 0.1;\n}\n.background-true:hover {\n  cursor: pointer;\n}\n\n.background-false {\n  opacity: 0;\n}\n\n.bar-compare-ELECTRICITY:hover,\n.bar-compare-GAS:hover,\n.bar-compare-WATER:hover,\n.bar-compare-MULTIFLUID:hover,\n.bar-MULTIFLUID:hover,\n.bar-WATER:hover,\n.bar-GAS:hover,\n.bar-ELECTRICITY:hover {\n  cursor: pointer;\n}\n.bar-compare-ELECTRICITY:hover.disabled,\n.bar-compare-GAS:hover.disabled,\n.bar-compare-WATER:hover.disabled,\n.bar-compare-MULTIFLUID:hover.disabled,\n.bar-MULTIFLUID:hover.disabled,\n.bar-WATER:hover.disabled,\n.bar-GAS:hover.disabled,\n.bar-ELECTRICITY:hover.disabled {\n  cursor: default;\n}\n\n.bar-ELECTRICITY {\n  fill: #5d3d2a;\n}\n.bar-ELECTRICITY.selected {\n  fill: #d87b39;\n  filter: drop-shadow(0 -0.1rem 0.2rem #d87b39);\n}\n\n.bar-compare-ELECTRICITY {\n  fill: #795c47;\n}\n.bar-compare-ELECTRICITY.selected {\n  fill: #e2bca1;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e2bca1);\n}\n\n.bar-WATER {\n  fill: #20415e;\n}\n.bar-WATER.selected {\n  fill: #3a98ec;\n  filter: drop-shadow(0 -0.1rem 0.2rem #3a98ec);\n}\n\n.bar-compare-WATER {\n  fill: #4d5c6e;\n}\n.bar-compare-WATER.selected {\n  fill: #abd4fa;\n  filter: drop-shadow(0 -0.1rem 0.2rem #abd4fa);\n}\n\n.bar-GAS {\n  fill: #184940;\n}\n.bar-GAS.selected {\n  fill: #45d1b8;\n  filter: drop-shadow(0 -0.1rem 0.2rem #45d1b8);\n}\n\n.bar-compare-GAS {\n  fill: #597773;\n}\n.bar-compare-GAS.selected {\n  fill: #a8f7e9;\n  filter: drop-shadow(0 -0.1rem 0.2rem #a8f7e9);\n}\n\n.bar-MULTIFLUID {\n  fill: #705d1d;\n}\n.bar-MULTIFLUID.selected {\n  fill: #e3b82a;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n.bar-MULTIFLUID.disabled:hover {\n  cursor: default;\n}\n\n.bar-duel {\n  fill: #61f0f2;\n}\n.bar-duel.selected {\n  fill: #61f0f2;\n  filter: drop-shadow(0 -0.1rem 0.2rem #61f0f2);\n}\n.bar-duel.disabled:hover {\n  cursor: default;\n}\n\n.bar-UNCOMING {\n  fill: #242633;\n  opacity: 0.6;\n}\n.bar-UNCOMING.selected {\n  fill: #e3b82a;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n.bar-UNCOMING.disabled:hover {\n  cursor: default;\n}\n\n.bar-compare-MULTIFLUID {\n  fill: #7d6a4e;\n}\n.bar-compare-MULTIFLUID.selected {\n  fill: #ffd597;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n\n.bar-average {\n  stroke-width: 2;\n  stroke: #e3b82a;\n}\n\n.week {\n  fill: #e2bca1;\n}\n.week.selected {\n  fill: #e2bca1;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e2bca1);\n}\n\n.weekend {\n  fill: #ffd597;\n}\n.weekend.selected {\n  fill: #ffd597;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n\n/** Animation **/\n.bounce-1 {\n  animation-name: bounce-1;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n  transform-box: fill-box;\n}\n\n@keyframes bounce-1 {\n  0% {\n    transform: scale(0.1, 0.1);\n  }\n  28% {\n    transform: scale(0.1, 1.1);\n  }\n  45% {\n    transform: scale(0.8, 0.95);\n  }\n  55% {\n    transform: scale(1, 1);\n  }\n  65% {\n    transform: scale(1, 0.98);\n  }\n  75% {\n    transform: scale(1, 1);\n  }\n}\n.bounce-2 {\n  animation-name: bounce-2;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n  transform-box: fill-box;\n}\n\n@keyframes bounce-2 {\n  0% {\n    transform: scale(1, 1);\n  }\n  28% {\n    transform: scale(1, 1.1);\n  }\n  45% {\n    transform: scale(0.8, 0.95);\n  }\n  55% {\n    transform: scale(1, 1);\n  }\n  65% {\n    transform: scale(1, 0.98);\n  }\n  75% {\n    transform: scale(1, 1);\n  }\n}\n.bounce-3 {\n  animation-name: bounce-3;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n}\n\n@keyframes bounce-3 {\n  0% {\n    opacity: 0.6;\n    transform: scaleY(1);\n  }\n  50% {\n    transform: scaleY(1.1);\n    opacity: 0.8;\n  }\n  100% {\n    transform: scaleY(1);\n    opacity: 1;\n  }\n}\n/** Animatio ndelay **/\n.delay {\n  animation-duration: 0.4s;\n}\n\n.delay--0 {\n  animation-duration: 0.6s;\n}\n\n.delay--1 {\n  animation-duration: 0.7s;\n}\n\n.delay--2 {\n  animation-duration: 0.8s;\n}\n\n.delay--3 {\n  animation-duration: 0.9s;\n}\n\n.delay--4 {\n  animation-duration: 1s;\n}\n\n.delay--5 {\n  animation-duration: 1.1s;\n}\n\n.delay--6 {\n  animation-duration: 1.2s;\n}\n\n.delay--7 {\n  animation-duration: 1.3s;\n}\n\n.delay--8 {\n  animation-duration: 1.4s;\n}\n\n.delay--9 {\n  animation-duration: 1.5s;\n}\n\n.delay--10 {\n  animation-duration: 1.6s;\n}\n\n.delay--11 {\n  animation-duration: 1.8s;\n}\n\n.delay--12 {\n  animation-duration: 1.9s;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nbutton.btn-highlight {\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  background-color: #e3b82a;\n  border: none;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-highlight span:first-child {\n  color: #000000;\n}\nbutton.btn-highlight:hover, button.btn-highlight:focus, button.btn-highlight.active, button.btn-highlight:disabled {\n  background-color: #b89318;\n}\nbutton.btn-highlight:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-primary-positive {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #121212;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-primary-positive span:first-child {\n  color: #e3b82a;\n}\nbutton.btn-primary-positive:hover, button.btn-primary-positive:focus, button.btn-primary-positive.active, button.btn-primary-positive:disabled {\n  background-color: rgba(18, 18, 18, 0.2);\n}\nbutton.btn-primary-positive:hover span:first-child, button.btn-primary-positive:focus span:first-child, button.btn-primary-positive.active span:first-child, button.btn-primary-positive:disabled span:first-child {\n  color: rgba(227, 184, 42, 0.7);\n}\nbutton.btn-primary-positive:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-primary-negative {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-primary-negative span:first-child {\n  color: #e3b82a;\n}\nbutton.btn-primary-negative:hover, button.btn-primary-negative:focus, button.btn-primary-negative.active, button.btn-primary-negative:disabled {\n  background-color: rgba(123, 123, 123, 0.2);\n}\nbutton.btn-primary-negative:hover span:first-child, button.btn-primary-negative:focus span:first-child, button.btn-primary-negative.active span:first-child, button.btn-primary-negative:disabled span:first-child {\n  color: rgba(227, 184, 42, 0.7);\n}\nbutton.btn-primary-negative:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary span:first-child {\n  color: #f1c017;\n}\nbutton.btn-secondary:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary-positive {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #121212;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary-positive span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-secondary-positive:hover, button.btn-secondary-positive:focus, button.btn-secondary-positive.active, button.btn-secondary-positive:disabled {\n  background-color: rgba(18, 18, 18, 0.2);\n}\nbutton.btn-secondary-positive:hover span:first-child, button.btn-secondary-positive:focus span:first-child, button.btn-secondary-positive.active span:first-child, button.btn-secondary-positive:disabled span:first-child {\n  color: rgba(224, 224, 224, 0.7);\n}\nbutton.btn-secondary-positive:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary-negative {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary-negative span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-secondary-negative:hover, button.btn-secondary-negative:focus, button.btn-secondary-negative.active, button.btn-secondary-negative:disabled {\n  background-color: rgba(123, 123, 123, 0.2);\n}\nbutton.btn-secondary-negative:hover span:first-child, button.btn-secondary-negative:focus span:first-child, button.btn-secondary-negative.active span:first-child, button.btn-secondary-negative:disabled span:first-child {\n  color: rgba(224, 224, 224, 0.7);\n}\nbutton.btn-secondary-negative:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-off {\n  background: #121212;\n  background-color: #121212;\n  border: 1px solid rgba(97, 240, 242, 0.5);\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-off span:first-child {\n  color: #ffffff;\n}\nbutton.btn-duel-off:hover, button.btn-duel-off:focus, button.btn-duel-off.active, button.btn-duel-off:disabled {\n  background-color: black;\n}\nbutton.btn-duel-off:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-active {\n  border-radius: 4px !important;\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  background-color: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  border: none;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-active span:first-child {\n  color: #121212;\n}\nbutton.btn-duel-active:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-on {\n  background: radial-gradient(60.65% 30.62% at 50% 3.13%, #2a2b30 0%, #1b1c22 100%);\n  background-color: #121212;\n  border: 1px solid #58ffff;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-on span:first-child {\n  color: #ffffff;\n}\nbutton.btn-duel-on:hover, button.btn-duel-on:focus, button.btn-duel-on.active, button.btn-duel-on:disabled {\n  background-color: black;\n}\nbutton.btn-duel-on:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-profile-next {\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  background-color: #e3b82a;\n  border: 1px solid #e3b82a;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-profile-next span:first-child {\n  color: #000000;\n}\nbutton.btn-profile-next:hover, button.btn-profile-next:focus, button.btn-profile-next.active, button.btn-profile-next:disabled {\n  background-color: #b89318;\n}\nbutton.btn-profile-next:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-profile-back {\n  background: none;\n  background-color: none;\n  border: 1px solid #e0e0e0;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-profile-back span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-profile-back:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.card {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-sizing: border-box;\n  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.75);\n  border-radius: 4px;\n  padding: 16px;\n}\n.card:hover {\n  background: linear-gradient(180deg, rgba(70, 71, 77, 0.7) 0%, rgba(57, 58, 63, 0.7) 100%);\n}\n.card.rich-card {\n  padding: 24px 16px;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.modal-root .MuiBackdrop-root {\n  background-color: hsla(231deg, 11%, 12%, 0.85);\n}\n\ndiv.modal-paper {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  width: 36rem;\n  max-width: 100%;\n  max-height: 90vh;\n  padding: 2rem;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  margin: 0 0 0 13.75rem;\n  align-items: center;\n  color: #ffffff;\n}\n@media only screen and (max-width : 1023px) {\n  div.modal-paper {\n    width: 35rem;\n    margin: 0;\n  }\n}\n@media only screen and (max-width : 768px) {\n  div.modal-paper {\n    padding: 1rem 1rem 1.5rem;\n    width: 85%;\n    max-width: 35rem;\n    margin: 0;\n  }\n}\ndiv.modal-paper.no-padding {\n  padding: 0;\n}\ndiv.modal-paper.blue-border {\n  border: 1px solid rgba(88, 255, 255, 0.2509803922);\n}\ndiv.modal-paper.blue-light-border {\n  border: 1px solid #61f0f2;\n}\ndiv.modal-paper.yellow-border {\n  border: 1px solid rgba(227, 184, 42, 0.4);\n}\ndiv.modal-paper .modal-paper-close-button {\n  position: absolute;\n  top: 0.5rem;\n  right: 0.5rem;\n  padding: 5px 5px;\n  z-index: 10;\n}\n\ndiv.modal-paper-full-screen {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  max-height: 100%;\n  padding: 0;\n  margin: 0;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  color: #ffffff;\n  display: flex;\n  align-items: center;\n}\ndiv.modal-paper-full-screen.dark-background {\n  background: #121212;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.expansion-panel-root {\n  margin: 1.2rem 0;\n  color: #e0e0e0;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  border-radius: 4px;\n  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.75);\n  transition: background-color 0.6s ease;\n  box-sizing: border-box;\n}\ndiv.expansion-panel-root.Mui-expanded:first-child {\n  margin: 1.2rem 0;\n}\ndiv.expansion-panel-root.Mui-expanded:last-child {\n  margin: 1.2rem 0;\n}\ndiv.expansion-panel-root.red-border {\n  border: 1px solid #d25959;\n}\n\ndiv.expansion-panel-summary {\n  padding: 0.25rem 1.2rem;\n  min-height: 4rem;\n}\ndiv.expansion-panel-summary.Mui-focused {\n  border-radius: 4px;\n  background-color: unset;\n  box-shadow: 0 0 0 1px #e0e0e0;\n}\ndiv.expansion-panel-summary.Mui-expanded {\n  min-height: 4rem;\n}\ndiv.expansion-panel-summary.Mui-expanded.small {\n  min-height: 3rem;\n}\ndiv.expansion-panel-summary.small {\n  padding: 0 1.2rem;\n  min-height: 3rem;\n}\ndiv.expansion-panel-summary.bold-text {\n  font-weight: bold;\n}\n\ndiv.expansion-panel-content {\n  display: flex;\n  align-items: center;\n}\ndiv.expansion-panel-content.Mui-expanded {\n  margin: 0.75rem 0;\n}\n\ndiv.expansion-panel-details {\n  padding: 0 1.2rem 1.2rem;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\na {\n  color: #deaf0e;\n}\na:visited {\n  color: #deaf0e;\n}\n\na:focus {\n  outline: none;\n  box-shadow: inset 0 0 0 1px #e0e0e0;\n}\na:focus > div:first-child {\n  box-shadow: 0 0 0 1px #e0e0e0;\n}\n\na.MuiLink-underlineHover:hover {\n  text-decoration: none;\n}\n\na.MuiTypography-colorPrimary {\n  color: #e0e0e0;\n}\n\n:root {\n  white-space: pre-line;\n  --blue: #58ffff;\n  --blue40: rgba(88, 255, 255, 0.2509803922);\n  --blueBackground: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  --blueRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  --blueRadialGradientTrans: radial-gradient(circle, #58ffff 0%, rgba(255, 255, 255, 0) 100%);\n  --elecColor: #d87b39;\n  --elecColor40: rgba(216, 123, 57, 0.4);\n  --elecCompareColor: #e2bca1;\n  --gasColor: #45d1b8;\n  --gasColor40: rgba(69, 209, 184, 0.4);\n  --gasCompareColor: #a8f7e9;\n  --waterColor: #3a98ec;\n  --waterColor40: rgba(58, 152, 236, 0.4);\n  --waterCompareColor: #abd4fa;\n  --multiColor: #e3b82a;\n  --multiCompareColor: #ffd597;\n  --redPrimary: #d25959;\n  --greyBright: #e0e0e0;\n  --greyDark: #7b7b7b;\n  --textWhite: #ffffff;\n  --softGrey: #a0a0a0;\n  --darkLight: #25262b;\n  --darkLight2: #121212;\n  --textFont: Lato, sans-serif;\n  --greyLinearGradientBackground: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  --multiColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%);\n  --elecColorRadialGradientTrans: radial-gradient(circle, #d87b39 0%, rgba(255, 255, 255, 0) 100%);\n  --waterColorRadialGradientTrans: radial-gradient(circle, #3a98ec 0%, rgba(255, 255, 255, 0) 100%);\n  --gasColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%);\n  --multiColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  --elecColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(158, 67, 2, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #d87b39;\n  --gasColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(4, 106, 88, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #45d1b8;\n  --waterColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(2, 93, 174, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #3a98ec;\n}\n\n.application {\n  overflow-x: hidden;\n  background-color: #121212;\n}\n\n.accordion-icon {\n  color: #ffffff;\n}\n\n.loaderContainer {\n  height: 80vh;\n  justify-content: center;\n  display: flex;\n}", ""]);
+exports.push([module.i, "/* Cozy UI utilities classes */\n/* Cozy UI React components styles */\n/* App styles */\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nhtml {\n  background: #121212;\n}\n\nbody {\n  background: #121212;\n  overflow: unset !important;\n}\n\n.column {\n  display: flex;\n  flex-direction: column;\n}\n\n.row {\n  display: flex;\n  flex-direction: row;\n}\n\n.cozy-bar {\n  width: 100%;\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  margin-left: 0;\n}\n\n[role=banner] .coz-bar-container {\n  background-color: #ffffff;\n}\n@media only screen and (max-width : 768px) {\n  [role=banner] .coz-bar-container {\n    padding: 0.6rem 0 0 0;\n    background-color: unset;\n  }\n}\n\n.coz-bar-wrapper {\n  box-shadow: unset !important;\n  background: unset !important;\n}\n\n.coz-label {\n  color: #32363f;\n}\n\n.content-view-loading {\n  height: 80vh;\n  width: 100%;\n  display: flex;\n  flex-direction: column;\n  justify-content: center;\n  align-items: center;\n  color: #e0e0e0;\n}\n.content-view-loading .content-view-loading-text {\n  padding-top: 1rem;\n  margin: 0 2rem;\n  text-align: center;\n}\n.content-view-loading .content-view-loading-button {\n  max-width: 50vw;\n  margin-top: 1rem;\n}\n\n[role=main] {\n  /* width */\n  /* Track */\n  /* Handle */\n}\n[role=main]::-webkit-scrollbar {\n  width: 10px;\n}\n[role=main]::-webkit-scrollbar-track {\n  background: #3e4045;\n}\n[role=main]::-webkit-scrollbar-thumb {\n  background: #6f7074;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n* {\n  font-family: Lato, sans-serif;\n}\n\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\np {\n  color: #a0a0a0;\n  font-family: Lato, sans-serif;\n}\n\n.home-title {\n  font-size: 1rem;\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  line-height: 120%;\n  text-transform: uppercase;\n}\n\n.app-title {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 21px;\n  line-height: 24px;\n  text-align: center;\n  letter-spacing: 0.15px;\n  color: #e0e0e0;\n  text-shadow: 0px -1px 0px #060609, 0px 1px 0px rgba(255, 255, 255, 0.07);\n}\n\n.text-10, .text-10-italic, .text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase, .text-10-normal, .text-10-normal-150, .text-10-normal-uppercase {\n  font-style: normal;\n  font-size: 0.625rem;\n  line-height: 120%;\n}\n.text-10-normal, .text-10-normal-150, .text-10-normal-uppercase {\n  font-weight: normal;\n}\n.text-10-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-10-normal-150 {\n  line-height: 150%;\n}\n.text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase {\n  font-weight: 700;\n}\n.text-10-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-10-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-10-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-14, .text-14-italic, .text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase, .text-14-normal, .text-14-normal-150, .text-14-normal-uppercase {\n  font-style: normal;\n  font-size: 0.875rem;\n  line-height: 120%;\n}\n.text-14-normal, .text-14-normal-150, .text-14-normal-uppercase {\n  font-weight: normal;\n}\n.text-14-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-14-normal-150 {\n  line-height: 150%;\n}\n.text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase {\n  font-weight: 700;\n}\n.text-14-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-14-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-14-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-15, .text-15-italic, .text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase, .text-15-normal, .text-15-normal-150, .text-15-normal-uppercase {\n  font-style: normal;\n  font-size: 0.938rem;\n  line-height: 120%;\n}\n.text-15-normal, .text-15-normal-150, .text-15-normal-uppercase {\n  font-weight: normal;\n}\n.text-15-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-15-normal-150 {\n  line-height: 150%;\n}\n.text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase {\n  font-weight: 700;\n}\n.text-15-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-15-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-15-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-16, .text-16-italic, .text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase, .text-16-normal, .text-16-normal-150, .text-16-normal-uppercase {\n  font-style: normal;\n  font-size: 1rem;\n  line-height: 120%;\n}\n.text-16-normal, .text-16-normal-150, .text-16-normal-uppercase {\n  font-weight: normal;\n}\n.text-16-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-16-normal-150 {\n  line-height: 150%;\n}\n.text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase {\n  font-weight: 700;\n}\n.text-16-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-16-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-16-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-18, .text-18-italic, .text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase, .text-18-normal, .text-18-normal-150, .text-18-normal-uppercase {\n  font-style: normal;\n  font-size: 1.125rem;\n  line-height: 120%;\n}\n.text-18-normal, .text-18-normal-150, .text-18-normal-uppercase {\n  font-weight: normal;\n}\n.text-18-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-18-normal-150 {\n  line-height: 150%;\n}\n.text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase {\n  font-weight: 700;\n}\n.text-18-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-18-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-18-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-19, .text-19-italic, .text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase, .text-19-normal, .text-19-normal-150, .text-19-normal-uppercase {\n  font-style: normal;\n  font-size: 1.188rem;\n  line-height: 120%;\n}\n.text-19-normal, .text-19-normal-150, .text-19-normal-uppercase {\n  font-weight: normal;\n}\n.text-19-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-19-normal-150 {\n  line-height: 150%;\n}\n.text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase {\n  font-weight: 700;\n}\n.text-19-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-19-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-19-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-20, .text-20-italic, .text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase, .text-20-normal, .text-20-normal-150, .text-20-normal-uppercase {\n  font-style: normal;\n  font-size: 1.25rem;\n  line-height: 120%;\n}\n.text-20-normal, .text-20-normal-150, .text-20-normal-uppercase {\n  font-weight: normal;\n}\n.text-20-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-20-normal-150 {\n  line-height: 150%;\n}\n.text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase {\n  font-weight: 700;\n}\n.text-20-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-20-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-20-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-21, .text-21-italic, .text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase, .text-21-normal, .text-21-normal-150, .text-21-normal-uppercase {\n  font-style: normal;\n  font-size: 1.313rem;\n  line-height: 120%;\n}\n.text-21-normal, .text-21-normal-150, .text-21-normal-uppercase {\n  font-weight: normal;\n}\n.text-21-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-21-normal-150 {\n  line-height: 150%;\n}\n.text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase {\n  font-weight: 700;\n}\n.text-21-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-21-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-21-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-22, .text-22-italic, .text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase, .text-22-normal, .text-22-normal-150, .text-22-normal-uppercase {\n  font-style: normal;\n  font-size: 1.375rem;\n  line-height: 120%;\n}\n.text-22-normal, .text-22-normal-150, .text-22-normal-uppercase {\n  font-weight: normal;\n}\n.text-22-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-22-normal-150 {\n  line-height: 150%;\n}\n.text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase {\n  font-weight: 700;\n}\n.text-22-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-22-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-22-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-24, .text-24-italic, .text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase, .text-24-normal, .text-24-normal-150, .text-24-normal-uppercase {\n  font-style: normal;\n  font-size: 1.5rem;\n  line-height: 120%;\n}\n.text-24-normal, .text-24-normal-150, .text-24-normal-uppercase {\n  font-weight: normal;\n}\n.text-24-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-24-normal-150 {\n  line-height: 150%;\n}\n.text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase {\n  font-weight: 700;\n}\n.text-24-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-24-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-24-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-26, .text-26-italic, .text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase, .text-26-normal, .text-26-normal-150, .text-26-normal-uppercase {\n  font-style: normal;\n  font-size: 1.625rem;\n  line-height: 120%;\n}\n.text-26-normal, .text-26-normal-150, .text-26-normal-uppercase {\n  font-weight: normal;\n}\n.text-26-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-26-normal-150 {\n  line-height: 150%;\n}\n.text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase {\n  font-weight: 700;\n}\n.text-26-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-26-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-26-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-28, .text-28-italic, .text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase, .text-28-normal, .text-28-normal-150, .text-28-normal-uppercase {\n  font-style: normal;\n  font-size: 1.75rem;\n  line-height: 120%;\n}\n.text-28-normal, .text-28-normal-150, .text-28-normal-uppercase {\n  font-weight: normal;\n}\n.text-28-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-28-normal-150 {\n  line-height: 150%;\n}\n.text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase {\n  font-weight: 700;\n}\n.text-28-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-28-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-28-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n.text-36, .text-36-italic, .text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase, .text-36-normal, .text-36-normal-150, .text-36-normal-uppercase {\n  font-style: normal;\n  font-size: 2.25rem;\n  line-height: 120%;\n}\n.text-36-normal, .text-36-normal-150, .text-36-normal-uppercase {\n  font-weight: normal;\n}\n.text-36-normal-uppercase {\n  text-transform: uppercase;\n}\n.text-36-normal-150 {\n  line-height: 150%;\n}\n.text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase {\n  font-weight: 700;\n}\n.text-36-bold-uppercase {\n  text-transform: uppercase;\n}\n.text-36-bold-capitalize {\n  text-transform: capitalize;\n}\n.text-36-italic {\n  font-style: italic;\n  font-weight: normal;\n}\n\n/* Card */\n.card-title-on {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1.125rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-text-bold {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-indicator {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n.card-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n/* Chart */\n.chart-ticks-x-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 1rem;\n  line-height: 120%;\n}\n@media only screen and (max-width : 768px) {\n  .chart-ticks-x-text {\n    font-size: 0.685rem;\n  }\n}\n\n.chart-ticks-y-text {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  font-size: 0.9rem;\n  line-height: 120%;\n}\n@media only screen and (max-width : 768px) {\n  .chart-ticks-y-text {\n    font-size: 0.75rem;\n  }\n}\n\n/* Cozy bar */\n.cozybar {\n  font-family: Lato, sans-serif;\n  font-style: normal;\n  font-weight: bold;\n  font-size: 1.3125rem;\n  line-height: 120%;\n  color: #e0e0e0;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.axis {\n  color: #7b7b7b;\n}\n.axis .tick-text {\n  fill: #7b7b7b;\n}\n.axis .tick-text.tick-text-selected {\n  fill: #e0e0e0;\n}\n.axis .separator {\n  text-align: center;\n  margin: 0 2px;\n  font-size: 1rem !important;\n}\n\n.value-text {\n  fill: #7b7b7b;\n}\n.value-text.selected {\n  fill: #e0e0e0;\n}\n\n.barContainer:hover,\n.barFill:hover {\n  cursor: pointer;\n}\n\n.background-true {\n  opacity: 0.1;\n}\n.background-true:hover {\n  cursor: pointer;\n}\n\n.background-false {\n  opacity: 0;\n}\n\n.bar-compare-ELECTRICITY:hover,\n.bar-compare-GAS:hover,\n.bar-compare-WATER:hover,\n.bar-compare-MULTIFLUID:hover,\n.bar-MULTIFLUID:hover,\n.bar-WATER:hover,\n.bar-GAS:hover,\n.bar-ELECTRICITY:hover {\n  cursor: pointer;\n}\n\n.bar-ELECTRICITY {\n  fill: #5d3d2a;\n}\n.bar-ELECTRICITY.selected {\n  fill: #d87b39;\n  filter: drop-shadow(0 -0.1rem 0.2rem #d87b39);\n}\n\n.bar-compare-ELECTRICITY {\n  fill: #795c47;\n}\n.bar-compare-ELECTRICITY.selected {\n  fill: #e2bca1;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e2bca1);\n}\n\n.bar-WATER {\n  fill: #20415e;\n}\n.bar-WATER.selected {\n  fill: #3a98ec;\n  filter: drop-shadow(0 -0.1rem 0.2rem #3a98ec);\n}\n\n.bar-compare-WATER {\n  fill: #4d5c6e;\n}\n.bar-compare-WATER.selected {\n  fill: #abd4fa;\n  filter: drop-shadow(0 -0.1rem 0.2rem #abd4fa);\n}\n\n.bar-GAS {\n  fill: #184940;\n}\n.bar-GAS.selected {\n  fill: #45d1b8;\n  filter: drop-shadow(0 -0.1rem 0.2rem #45d1b8);\n}\n\n.bar-compare-GAS {\n  fill: #597773;\n}\n.bar-compare-GAS.selected {\n  fill: #a8f7e9;\n  filter: drop-shadow(0 -0.1rem 0.2rem #a8f7e9);\n}\n\n.bar-MULTIFLUID {\n  fill: #705d1d;\n}\n.bar-MULTIFLUID.selected {\n  fill: #e3b82a;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n.bar-MULTIFLUID.disabled:hover {\n  cursor: default;\n}\n\n.bar-duel {\n  fill: #61f0f2;\n}\n.bar-duel.selected {\n  fill: #61f0f2;\n  filter: drop-shadow(0 -0.1rem 0.2rem #61f0f2);\n}\n.bar-duel.disabled:hover {\n  cursor: default;\n}\n\n.bar-UNCOMING {\n  fill: #242633;\n  opacity: 0.6;\n}\n.bar-UNCOMING.selected {\n  fill: #e3b82a;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n.bar-UNCOMING.disabled:hover {\n  cursor: default;\n}\n\n.bar-compare-MULTIFLUID {\n  fill: #7d6a4e;\n}\n.bar-compare-MULTIFLUID.selected {\n  fill: #ffd597;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n\n.bar-average {\n  stroke-width: 2;\n  stroke: #e3b82a;\n}\n\n.week {\n  fill: #e2bca1;\n}\n.week.selected {\n  fill: #e2bca1;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e2bca1);\n}\n\n.weekend {\n  fill: #ffd597;\n}\n.weekend.selected {\n  fill: #ffd597;\n  filter: drop-shadow(0 -0.1rem 0.2rem #e3b82a);\n}\n\n/** Animation **/\n.bounce-1 {\n  animation-name: bounce-1;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n  transform-box: fill-box;\n}\n\n@keyframes bounce-1 {\n  0% {\n    transform: scale(0.1, 0.1);\n  }\n  28% {\n    transform: scale(0.1, 1.1);\n  }\n  45% {\n    transform: scale(0.8, 0.95);\n  }\n  55% {\n    transform: scale(1, 1);\n  }\n  65% {\n    transform: scale(1, 0.98);\n  }\n  75% {\n    transform: scale(1, 1);\n  }\n}\n.bounce-2 {\n  animation-name: bounce-2;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n  transform-box: fill-box;\n}\n\n@keyframes bounce-2 {\n  0% {\n    transform: scale(1, 1);\n  }\n  28% {\n    transform: scale(1, 1.1);\n  }\n  45% {\n    transform: scale(0.8, 0.95);\n  }\n  55% {\n    transform: scale(1, 1);\n  }\n  65% {\n    transform: scale(1, 0.98);\n  }\n  75% {\n    transform: scale(1, 1);\n  }\n}\n.bounce-3 {\n  animation-name: bounce-3;\n  animation-timing-function: cubic-bezier(1, 1, 0.42, 1);\n  animation-iteration-count: 1;\n  transform-origin: bottom center;\n}\n\n@keyframes bounce-3 {\n  0% {\n    opacity: 0.6;\n    transform: scaleY(1);\n  }\n  50% {\n    transform: scaleY(1.1);\n    opacity: 0.8;\n  }\n  100% {\n    transform: scaleY(1);\n    opacity: 1;\n  }\n}\n/** Animatio ndelay **/\n.delay {\n  animation-duration: 0.4s;\n}\n\n.delay--0 {\n  animation-duration: 0.6s;\n}\n\n.delay--1 {\n  animation-duration: 0.7s;\n}\n\n.delay--2 {\n  animation-duration: 0.8s;\n}\n\n.delay--3 {\n  animation-duration: 0.9s;\n}\n\n.delay--4 {\n  animation-duration: 1s;\n}\n\n.delay--5 {\n  animation-duration: 1.1s;\n}\n\n.delay--6 {\n  animation-duration: 1.2s;\n}\n\n.delay--7 {\n  animation-duration: 1.3s;\n}\n\n.delay--8 {\n  animation-duration: 1.4s;\n}\n\n.delay--9 {\n  animation-duration: 1.5s;\n}\n\n.delay--10 {\n  animation-duration: 1.6s;\n}\n\n.delay--11 {\n  animation-duration: 1.8s;\n}\n\n.delay--12 {\n  animation-duration: 1.9s;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\nbutton.btn-highlight {\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  background-color: #e3b82a;\n  border: none;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-highlight span:first-child {\n  color: #000000;\n}\nbutton.btn-highlight:hover, button.btn-highlight:focus, button.btn-highlight.active, button.btn-highlight:disabled {\n  background-color: #b89318;\n}\nbutton.btn-highlight:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-primary-positive {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #121212;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-primary-positive span:first-child {\n  color: #e3b82a;\n}\nbutton.btn-primary-positive:hover, button.btn-primary-positive:focus, button.btn-primary-positive.active, button.btn-primary-positive:disabled {\n  background-color: rgba(18, 18, 18, 0.2);\n}\nbutton.btn-primary-positive:hover span:first-child, button.btn-primary-positive:focus span:first-child, button.btn-primary-positive.active span:first-child, button.btn-primary-positive:disabled span:first-child {\n  color: rgba(227, 184, 42, 0.7);\n}\nbutton.btn-primary-positive:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-primary-negative {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-primary-negative span:first-child {\n  color: #e3b82a;\n}\nbutton.btn-primary-negative:hover, button.btn-primary-negative:focus, button.btn-primary-negative.active, button.btn-primary-negative:disabled {\n  background-color: rgba(123, 123, 123, 0.2);\n}\nbutton.btn-primary-negative:hover span:first-child, button.btn-primary-negative:focus span:first-child, button.btn-primary-negative.active span:first-child, button.btn-primary-negative:disabled span:first-child {\n  color: rgba(227, 184, 42, 0.7);\n}\nbutton.btn-primary-negative:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary span:first-child {\n  color: #f1c017;\n}\nbutton.btn-secondary:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary-positive {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #121212;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary-positive span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-secondary-positive:hover, button.btn-secondary-positive:focus, button.btn-secondary-positive.active, button.btn-secondary-positive:disabled {\n  background-color: rgba(18, 18, 18, 0.2);\n}\nbutton.btn-secondary-positive:hover span:first-child, button.btn-secondary-positive:focus span:first-child, button.btn-secondary-positive.active span:first-child, button.btn-secondary-positive:disabled span:first-child {\n  color: rgba(224, 224, 224, 0.7);\n}\nbutton.btn-secondary-positive:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-secondary-negative {\n  background: transparent;\n  background-color: transparent;\n  border: 1px solid #7b7b7b;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-secondary-negative span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-secondary-negative:hover, button.btn-secondary-negative:focus, button.btn-secondary-negative.active, button.btn-secondary-negative:disabled {\n  background-color: rgba(123, 123, 123, 0.2);\n}\nbutton.btn-secondary-negative:hover span:first-child, button.btn-secondary-negative:focus span:first-child, button.btn-secondary-negative.active span:first-child, button.btn-secondary-negative:disabled span:first-child {\n  color: rgba(224, 224, 224, 0.7);\n}\nbutton.btn-secondary-negative:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-off {\n  background: #121212;\n  background-color: #121212;\n  border: 1px solid rgba(97, 240, 242, 0.5);\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-off span:first-child {\n  color: #ffffff;\n}\nbutton.btn-duel-off:hover, button.btn-duel-off:focus, button.btn-duel-off.active, button.btn-duel-off:disabled {\n  background-color: black;\n}\nbutton.btn-duel-off:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-active {\n  border-radius: 4px !important;\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  background-color: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  border: none;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-active span:first-child {\n  color: #121212;\n}\nbutton.btn-duel-active:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-duel-on {\n  background: radial-gradient(60.65% 30.62% at 50% 3.13%, #2a2b30 0%, #1b1c22 100%);\n  background-color: #121212;\n  border: 1px solid #58ffff;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-duel-on span:first-child {\n  color: #ffffff;\n}\nbutton.btn-duel-on:hover, button.btn-duel-on:focus, button.btn-duel-on.active, button.btn-duel-on:disabled {\n  background-color: black;\n}\nbutton.btn-duel-on:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-profile-next {\n  background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  background-color: #e3b82a;\n  border: 1px solid #e3b82a;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-profile-next span:first-child {\n  color: #000000;\n}\nbutton.btn-profile-next:hover, button.btn-profile-next:focus, button.btn-profile-next.active, button.btn-profile-next:disabled {\n  background-color: #b89318;\n}\nbutton.btn-profile-next:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\nbutton.btn-profile-back {\n  background: none;\n  background-color: none;\n  border: 1px solid #e0e0e0;\n  border-radius: 2px;\n  margin: 1.5rem 0 0;\n  width: 100%;\n  text-transform: initial;\n  cursor: pointer;\n}\nbutton.btn-profile-back span:first-child {\n  color: #e0e0e0;\n}\nbutton.btn-profile-back:disabled {\n  cursor: not-allowed;\n  opacity: 0.5;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\n.card {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  box-sizing: border-box;\n  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.75);\n  border-radius: 4px;\n  padding: 16px;\n}\n.card:hover {\n  background: linear-gradient(180deg, rgba(70, 71, 77, 0.7) 0%, rgba(57, 58, 63, 0.7) 100%);\n}\n.card.rich-card {\n  padding: 24px 16px;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.modal-root .MuiBackdrop-root {\n  background-color: hsla(231deg, 11%, 12%, 0.85);\n}\n\ndiv.modal-paper {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  width: 36rem;\n  max-width: 100%;\n  max-height: 90vh;\n  padding: 2rem;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  margin: 0 0 0 13.75rem;\n  align-items: center;\n  color: #ffffff;\n}\n@media only screen and (max-width : 1023px) {\n  div.modal-paper {\n    width: 35rem;\n    margin: 0;\n  }\n}\n@media only screen and (max-width : 768px) {\n  div.modal-paper {\n    padding: 1rem 1rem 1.5rem;\n    width: 85%;\n    max-width: 35rem;\n    margin: 0;\n  }\n}\ndiv.modal-paper.no-padding {\n  padding: 0;\n}\ndiv.modal-paper.blue-border {\n  border: 1px solid rgba(88, 255, 255, 0.2509803922);\n}\ndiv.modal-paper.blue-light-border {\n  border: 1px solid #61f0f2;\n}\ndiv.modal-paper.yellow-border {\n  border: 1px solid rgba(227, 184, 42, 0.4);\n}\ndiv.modal-paper .modal-paper-close-button {\n  position: absolute;\n  top: 0.5rem;\n  right: 0.5rem;\n  padding: 5px 5px;\n  z-index: 10;\n}\n\ndiv.modal-paper-full-screen {\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  width: 100%;\n  max-width: 100%;\n  height: 100%;\n  max-height: 100%;\n  padding: 0;\n  margin: 0;\n  box-sizing: border-box;\n  box-shadow: 0px 4px 16px rgba(0, 0, 0, 0.55);\n  border-radius: 4px;\n  color: #ffffff;\n  display: flex;\n  align-items: center;\n}\ndiv.modal-paper-full-screen.dark-background {\n  background: #121212;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\ndiv.expansion-panel-root {\n  margin: 1.2rem 0;\n  color: #e0e0e0;\n  background: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  border-radius: 4px;\n  box-shadow: 0px 4px 8px rgba(0, 0, 0, 0.75);\n  transition: background-color 0.6s ease;\n  box-sizing: border-box;\n}\ndiv.expansion-panel-root.Mui-expanded:first-child {\n  margin: 1.2rem 0;\n}\ndiv.expansion-panel-root.Mui-expanded:last-child {\n  margin: 1.2rem 0;\n}\ndiv.expansion-panel-root.red-border {\n  border: 1px solid #d25959;\n}\n\ndiv.expansion-panel-summary {\n  padding: 0.25rem 1.2rem;\n  min-height: 4rem;\n}\ndiv.expansion-panel-summary.Mui-focused {\n  border-radius: 4px;\n  background-color: unset;\n  box-shadow: 0 0 0 1px #e0e0e0;\n}\ndiv.expansion-panel-summary.Mui-expanded {\n  min-height: 4rem;\n}\ndiv.expansion-panel-summary.Mui-expanded.small {\n  min-height: 3rem;\n}\ndiv.expansion-panel-summary.small {\n  padding: 0 1.2rem;\n  min-height: 3rem;\n}\ndiv.expansion-panel-summary.bold-text {\n  font-weight: bold;\n}\n\ndiv.expansion-panel-content {\n  display: flex;\n  align-items: center;\n}\ndiv.expansion-panel-content.Mui-expanded {\n  margin: 0.75rem 0;\n}\n\ndiv.expansion-panel-details {\n  padding: 0 1.2rem 1.2rem;\n}\n\n/** BLACK **/\n/** RED **/\n/** YELLOW **/\n/** ORANGE **/\n/** BLUE **/\n/** GREEN **/\n/** WHITE **/\n/** GREY **/\n/** App colors **/\n/** TABS GRADIENT **/\n/** SCROLLBAR **/\na {\n  color: #deaf0e;\n}\na:visited {\n  color: #deaf0e;\n}\n\na:focus {\n  outline: none;\n  box-shadow: inset 0 0 0 1px #e0e0e0;\n}\na:focus > div:first-child {\n  box-shadow: 0 0 0 1px #e0e0e0;\n}\n\na.MuiLink-underlineHover:hover {\n  text-decoration: none;\n}\n\na.MuiTypography-colorPrimary {\n  color: #e0e0e0;\n}\n\n:root {\n  white-space: pre-line;\n  --blue: #58ffff;\n  --blue40: rgba(88, 255, 255, 0.2509803922);\n  --blueBackground: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  --blueRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff;\n  --blueRadialGradientTrans: radial-gradient(circle, #58ffff 0%, rgba(255, 255, 255, 0) 100%);\n  --elecColor: #d87b39;\n  --elecColor40: rgba(216, 123, 57, 0.4);\n  --elecCompareColor: #e2bca1;\n  --gasColor: #45d1b8;\n  --gasColor40: rgba(69, 209, 184, 0.4);\n  --gasCompareColor: #a8f7e9;\n  --waterColor: #3a98ec;\n  --waterColor40: rgba(58, 152, 236, 0.4);\n  --waterCompareColor: #abd4fa;\n  --multiColor: #e3b82a;\n  --multiCompareColor: #ffd597;\n  --redPrimary: #d25959;\n  --greyBright: #e0e0e0;\n  --greyDark: #7b7b7b;\n  --textWhite: #ffffff;\n  --softGrey: #a0a0a0;\n  --darkLight: #25262b;\n  --darkLight2: #121212;\n  --textFont: Lato, sans-serif;\n  --greyLinearGradientBackground: linear-gradient(180deg, #323339 0%, #25262b 100%);\n  --multiColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%);\n  --elecColorRadialGradientTrans: radial-gradient(circle, #d87b39 0%, rgba(255, 255, 255, 0) 100%);\n  --waterColorRadialGradientTrans: radial-gradient(circle, #3a98ec 0%, rgba(255, 255, 255, 0) 100%);\n  --gasColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%);\n  --multiColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017;\n  --elecColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(158, 67, 2, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #d87b39;\n  --gasColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(4, 106, 88, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #45d1b8;\n  --waterColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(2, 93, 174, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #3a98ec;\n}\n\n.application {\n  overflow-x: hidden;\n  background-color: #121212;\n}\n\n.accordion-icon {\n  color: #ffffff;\n}\n\n.loaderContainer {\n  height: 80vh;\n  justify-content: center;\n  display: flex;\n}", ""]);
 
 
 
@@ -32756,7 +32814,7 @@ exports.push([module.i, "/* Cozy UI utilities classes */\n/* Cozy UI React compo
 /***/ "pZg0":
 /***/ (function(module, exports) {
 
-module.exports = {"name":"Ecolyo","slug":"ecolyo","icon":"icon.svg","categories":["energy"],"version":"2.5.1","licence":"AGPL-3.0","editor":"Métropole de Lyon","default_locale":"fr","locales":{"fr":{"short_description":"Ecolyo est le service proposé par la Métropole de Lyon pour suivre et comprendre les consommations d’énergie et d’eau de votre foyer.","long_description":"Ecolyo est le service proposé par la Métropole de Lyon pour suivre et comprendre les consommations d’énergie et d’eau de votre foyer afin de vous accompagner dans la gestion quotidienne de ces consommations et ce, de façon ludique en vous lançant des défis personnalisés.","permissions":{"ecolyo":{"description":"Requises pour le fonctionnement des différentes parties de l’application (Analyse, liste d’astuces personnalisée, …)."},"enedis":{"description":"Requises pour l’affichage et l’analyse de vos consommations électriques dans Ecolyo. Issues du connecteur Enedis."},"grdf":{"description":"Requises pour l’affichage et l’analyse de vos consommations de gaz dans Ecolyo. Issues du connecteur GRDF."},"egl":{"description":"Requises pour l’affichage et l’analyse de vos consommations d’eau dans Ecolyo. Issues du connecteur Eau du Grand Lyon."},"konnectors":{"description":"Requis pour vérifier la présence des connecteurs Enedis, GRDF et Eau du Grand Lyon ainsi que pour pouvoir les configurer à partir de l’application Ecolyo."},"accounts":{"description":"Requis pour stocker des informations propres aux comptes énergie et eau (Enedis, GRDF, Eau du Grand Lyon). Sont stockés votre numéro de PDL pour Enedis, votre numéro de PCE pour GRDF, vos logins et mots de passe pour Eau du Grand Lyon."},"triggers":{"description":"Requis pour le bon fonctionnement des connecteurs énergie et eau."},"jobs":{"description":"Requis pour le bon fonctionnement des connecteurs énergie et eau."},"terms":{"description":"Nécessaire pour la gestion des consentements de l'application"},"apps":{"description":"Requis par Cozy pour afficher les icônes des applications installées dans la barre Cozy."},"settings":{"description":"Requis pour afficher les paramètres Cozy dans la barre Cozy."},"ecolyo-dju":{"description":"Requis pour la récupération des DJU (Degrés Jours Unifiés), informations météorologiques permettant d’ajuster le modèle de comparaison des consommations énergétiques."},"dacc-dev":{"description":"Requis pour la récupération et l’envoi de statistiques d’utilisation anonymisées dans un environnement de test."},"dacc":{"description":"Requis pour envoyer des statistiques d'utilisation anonymisées."},"backoffice-prod":{"description":"Requis pour la récupération des données de la newsletter."},"backoffice-rec":{"description":"Requis pour la récupération des données de la newsletter dans un environment de test."},"backoffice-custom-popup":{"description":"Requis pour la récupération des alertes personnalisées."},"backoffice-custom-popup-rec":{"description":"Requis pour la récupération des alertes personnalisées dans un environment de test."},"backoffice-partners-info":{"description":"Requis pour la récupération du status des services partenaires"},"backoffice-partners-info-rec":{"description":"Requis pour la récupération du status des services partenaires dans un environment de test."},"backoffice-prices":{"description":"Requis pour la récupération du prix des fluides."},"backoffice-prices-rec":{"description":"Requis pour la récupération du prix des fluides dans un environnement de test."}}},"en":{"short_description":"Ecolyo a free service developed by Métropole de Lyon to help you to monitor and understand the energy and water consumption of your home.","long_description":"Ecolyo a free service developed by the Métropole de Lyon to help you to monitor and understand the energy and water consumption of your home. To help you in reducing your daily consumption it gives you best energy consumption practices, consumption analysis and challenges to take up. At least one Smartmeter is needed among Linky (for electricity), Gazpar (for gas) or Téléo (for water).","permissions":{"ecolyo":{"description":"Required for the operation of the different parts of the application (Analysis, customized eco-gesture lists, etc...)."},"enedis":{"description":"Required for the display and analysis of your electricity consumption in Ecolyo. Retrieved by the Enedis connector."},"grdf":{"description":"Required for the display and analysis of your gas consumption in Ecolyo. Retrieved by the GRDF connector."},"egl":{"description":"Required for the display and analysis of your water consumption in Ecolyo. Retrieved by the Eau du Grand Lyon connector."},"konnectors":{"description":"Required to verify the presence of the Enedis, GRDF and Eau du Grand Lyon connectors as well as to be able to configure them from the Ecolyo application."},"accounts":{"description":"Required to store information specific to energy and water accounts (Enedis, GRDF, Eau du Grand Lyon). Your PDL number for Enedis, your PCE number for GRDF, your logins and passwords for Eau du Grand Lyon are stored."},"triggers":{"description":"Required for the correct functioning of the energy and water connectors."},"jobs":{"description":"Required for the correct functioning of the energy and water connectors."},"terms":{"description":"Required for the correct managment of CGU."},"apps":{"description":"Required to display the icons of installed applications in the Cozy bar."},"settings":{"description":"Required for the application's consents managment"},"ecolyo-dju":{"description":"Required to gather udd data (Unified Degree Days), a meteorological data allowing the app to adjust our energical consumption model. "},"dacc-dev":{"description":"Required for gathering and sending anonymous usage statistics for test environment."},"dacc":{"description":"Required for sending cozy anonymized stats."},"agent":{"description":"Required for retrieving informations from our partners."},"backoffice-prod":{"description":"Required for retrieving newsletter informations from backoffice prod."},"backoffice-rec":{"description":"Required for retrieving newsletter informations from backoffice rec."},"backoffice-custom-popup":{"description":"Required for retrieving custom alerts."},"backoffice-custom-popup-rec":{"description":"Required for retrieving custom alerts in test environment."},"backoffice-partners-info":{"description":"Required for getting the status of partners' services"},"backoffice-partners-info-rec":{"description":"Required for getting the status of partners' services in test environment."},"backoffice-prices":{"description":"Required for getting fluid prices form backoffice prod"},"backoffice-prices-rec":{"description":"Required for getting fluid prices form backoffice rec."}}}},"langs":["fr"],"developer":{"name":"Métropole de Lyon","url":"https://www.grandlyon.com/"},"routes":{"/":{"folder":"/","index":"index.html","public":false}},"services":{"enedisHalfHourMonthlyAnalysis":{"type":"node","file":"services/enedisHalfHourMonthlyAnalysis/ecolyo.js","trigger":"@cron 0 0 8 3 * *"},"monthlyReportNotification":{"type":"node","file":"services/monthlyReportNotification/ecolyo.js","trigger":"@cron 0 0 10 3 * *"},"consumptionAlert":{"type":"node","file":"services/consumptionAlert/ecolyo.js","trigger":"@daily after 11am"},"aggregatorUsageEvents":{"type":"node","file":"services/aggregatorUsageEvents/ecolyo.js","trigger":"@daily before 7am"},"fluidsPrices":{"type":"node","file":"services/fluidsPrices/ecolyo.js","trigger":"@daily before 7am"}},"permissions":{"ecolyo":{"type":"com.grandlyon.ecolyo.*"},"enedis":{"type":"com.grandlyon.enedis.*"},"grdf":{"type":"com.grandlyon.grdf.*"},"egl":{"type":"com.grandlyon.egl.*"},"agent":{"type":"org.ecolyo.agent.*"},"konnectors":{"type":"io.cozy.konnectors"},"accounts":{"type":"io.cozy.accounts"},"triggers":{"type":"io.cozy.triggers"},"jobs":{"type":"io.cozy.jobs"},"terms":{"type":"io.cozy.terms"},"apps":{"type":"io.cozy.apps","verbs":["GET"]},"settings":{"type":"io.cozy.settings","verbs":["GET"]},"ecolyo-dju":{"type":"org.ecolyo.dju_v2","verbs":["GET"]},"dacc":{"type":"cc.cozycloud.dacc_v2","verbs":["ALL"]},"dacc-dev":{"type":"cc.cozycloud.dacc.dev_v2","verbs":["ALL"]},"backoffice-prod":{"type":"org.ecolyo.agent","verbs":["ALL"]},"backoffice-rec":{"type":"org.ecolyo.agent.rec","verbs":["ALL"]},"backoffice-custom-popup":{"type":"org.ecolyo.agent.custom.popup","verbs":["ALL"]},"backoffice-custom-popup-rec":{"type":"org.ecolyo.agent.custom.popup.rec","verbs":["ALL"]},"backoffice-partners-info":{"type":"org.ecolyo.agent.partners.info","verbs":["ALL"]},"backoffice-partners-info-rec":{"type":"org.ecolyo.agent.partners.info.rec","verbs":["ALL"]},"backoffice-prices":{"type":"org.ecolyo.agent.prices","verbs":["ALL"]},"backoffice-prices-rec":{"type":"org.ecolyo.agent.prices.rec","verbs":["ALL"]}}}
+module.exports = {"name":"Ecolyo","slug":"ecolyo","icon":"icon.svg","categories":["energy"],"version":"2.4.0","licence":"AGPL-3.0","editor":"Métropole de Lyon","default_locale":"fr","locales":{"fr":{"short_description":"Ecolyo est le service proposé par la Métropole de Lyon pour suivre et comprendre les consommations d’énergie et d’eau de votre foyer.","long_description":"Ecolyo est le service proposé par la Métropole de Lyon pour suivre et comprendre les consommations d’énergie et d’eau de votre foyer afin de vous accompagner dans la gestion quotidienne de ces consommations et ce, de façon ludique en vous lançant des défis personnalisés.","permissions":{"ecolyo":{"description":"Requises pour le fonctionnement des différentes parties de l’application (Analyse, liste d’astuces personnalisée, …)."},"enedis":{"description":"Requises pour l’affichage et l’analyse de vos consommations électriques dans Ecolyo. Issues du connecteur Enedis."},"grdf":{"description":"Requises pour l’affichage et l’analyse de vos consommations de gaz dans Ecolyo. Issues du connecteur GRDF."},"egl":{"description":"Requises pour l’affichage et l’analyse de vos consommations d’eau dans Ecolyo. Issues du connecteur Eau du Grand Lyon."},"konnectors":{"description":"Requis pour vérifier la présence des connecteurs Enedis, GRDF et Eau du Grand Lyon ainsi que pour pouvoir les configurer à partir de l’application Ecolyo."},"accounts":{"description":"Requis pour stocker des informations propres aux comptes énergie et eau (Enedis, GRDF, Eau du Grand Lyon). Sont stockés votre numéro de PDL pour Enedis, votre numéro de PCE pour GRDF, vos logins et mots de passe pour Eau du Grand Lyon."},"triggers":{"description":"Requis pour le bon fonctionnement des connecteurs énergie et eau."},"jobs":{"description":"Requis pour le bon fonctionnement des connecteurs énergie et eau."},"terms":{"description":"Nécessaire pour la gestion des consentements de l'application"},"apps":{"description":"Requis par Cozy pour afficher les icônes des applications installées dans la barre Cozy."},"settings":{"description":"Requis pour afficher les paramètres Cozy dans la barre Cozy."},"ecolyo-dju":{"description":"Requis pour la récupération des DJU (Degrés Jours Unifiés), informations météorologiques permettant d’ajuster le modèle de comparaison des consommations énergétiques."},"dacc-dev":{"description":"Requis pour la récupération et l’envoi de statistiques d’utilisation anonymisées dans un environnement de test."},"dacc":{"description":"Requis pour envoyer des statistiques d'utilisation anonymisées."},"backoffice-prod":{"description":"Requis pour la récupération des données de la newsletter."},"backoffice-rec":{"description":"Requis pour la récupération des données de la newsletter dans un environment de test."},"backoffice-custom-popup":{"description":"Requis pour la récupération des alertes personnalisées."},"backoffice-custom-popup-rec":{"description":"Requis pour la récupération des alertes personnalisées dans un environment de test."},"backoffice-partners-info":{"description":"Requis pour la récupération du status des services partenaires"},"backoffice-partners-info-rec":{"description":"Requis pour la récupération du status des services partenaires dans un environment de test."},"backoffice-prices":{"description":"Requis pour la récupération du prix des fluides."},"backoffice-prices-rec":{"description":"Requis pour la récupération du prix des fluides dans un environnement de test."}}},"en":{"short_description":"Ecolyo a free service developed by Métropole de Lyon to help you to monitor and understand the energy and water consumption of your home.","long_description":"Ecolyo a free service developed by the Métropole de Lyon to help you to monitor and understand the energy and water consumption of your home. To help you in reducing your daily consumption it gives you best energy consumption practices, consumption analysis and challenges to take up. At least one Smartmeter is needed among Linky (for electricity), Gazpar (for gas) or Téléo (for water).","permissions":{"ecolyo":{"description":"Required for the operation of the different parts of the application (Analysis, customized eco-gesture lists, etc...)."},"enedis":{"description":"Required for the display and analysis of your electricity consumption in Ecolyo. Retrieved by the Enedis connector."},"grdf":{"description":"Required for the display and analysis of your gas consumption in Ecolyo. Retrieved by the GRDF connector."},"egl":{"description":"Required for the display and analysis of your water consumption in Ecolyo. Retrieved by the Eau du Grand Lyon connector."},"konnectors":{"description":"Required to verify the presence of the Enedis, GRDF and Eau du Grand Lyon connectors as well as to be able to configure them from the Ecolyo application."},"accounts":{"description":"Required to store information specific to energy and water accounts (Enedis, GRDF, Eau du Grand Lyon). Your PDL number for Enedis, your PCE number for GRDF, your logins and passwords for Eau du Grand Lyon are stored."},"triggers":{"description":"Required for the correct functioning of the energy and water connectors."},"jobs":{"description":"Required for the correct functioning of the energy and water connectors."},"terms":{"description":"Required for the correct managment of CGU."},"apps":{"description":"Required to display the icons of installed applications in the Cozy bar."},"settings":{"description":"Required for the application's consents managment"},"ecolyo-dju":{"description":"Required to gather udd data (Unified Degree Days), a meteorological data allowing the app to adjust our energical consumption model. "},"dacc-dev":{"description":"Required for gathering and sending anonymous usage statistics for test environment."},"dacc":{"description":"Required for sending cozy anonymized stats."},"agent":{"description":"Required for retrieving informations from our partners."},"backoffice-prod":{"description":"Required for retrieving newsletter informations from backoffice prod."},"backoffice-rec":{"description":"Required for retrieving newsletter informations from backoffice rec."},"backoffice-custom-popup":{"description":"Required for retrieving custom alerts."},"backoffice-custom-popup-rec":{"description":"Required for retrieving custom alerts in test environment."},"backoffice-partners-info":{"description":"Required for getting the status of partners' services"},"backoffice-partners-info-rec":{"description":"Required for getting the status of partners' services in test environment."},"backoffice-prices":{"description":"Required for getting fluid prices form backoffice prod"},"backoffice-prices-rec":{"description":"Required for getting fluid prices form backoffice rec."}}}},"langs":["fr"],"developer":{"name":"Métropole de Lyon","url":"https://www.grandlyon.com/"},"routes":{"/":{"folder":"/","index":"index.html","public":false}},"services":{"enedisHalfHourMonthlyAnalysis":{"type":"node","file":"services/enedisHalfHourMonthlyAnalysis/ecolyo.js","trigger":"@cron 0 0 8 3 * *"},"monthlyReportNotification":{"type":"node","file":"services/monthlyReportNotification/ecolyo.js","trigger":"@cron 0 0 10 3 * *"},"consumptionAlert":{"type":"node","file":"services/consumptionAlert/ecolyo.js","trigger":"@daily after 11am"},"aggregatorUsageEvents":{"type":"node","file":"services/aggregatorUsageEvents/ecolyo.js","trigger":"@daily before 7am"},"fluidsPrices":{"type":"node","file":"services/fluidsPrices/ecolyo.js","trigger":"@daily before 7am"}},"permissions":{"ecolyo":{"type":"com.grandlyon.ecolyo.*"},"enedis":{"type":"com.grandlyon.enedis.*"},"grdf":{"type":"com.grandlyon.grdf.*"},"egl":{"type":"com.grandlyon.egl.*"},"agent":{"type":"org.ecolyo.agent.*"},"konnectors":{"type":"io.cozy.konnectors"},"accounts":{"type":"io.cozy.accounts"},"triggers":{"type":"io.cozy.triggers"},"jobs":{"type":"io.cozy.jobs"},"terms":{"type":"io.cozy.terms"},"apps":{"type":"io.cozy.apps","verbs":["GET"]},"settings":{"type":"io.cozy.settings","verbs":["GET"]},"ecolyo-dju":{"type":"org.ecolyo.dju","verbs":["GET"]},"dacc":{"type":"cc.cozycloud.dacc_v2","verbs":["ALL"]},"dacc-dev":{"type":"cc.cozycloud.dacc.dev_v2","verbs":["ALL"]},"backoffice-prod":{"type":"org.ecolyo.agent","verbs":["ALL"]},"backoffice-rec":{"type":"org.ecolyo.agent.rec","verbs":["ALL"]},"backoffice-custom-popup":{"type":"org.ecolyo.agent.custom.popup","verbs":["ALL"]},"backoffice-custom-popup-rec":{"type":"org.ecolyo.agent.custom.popup.rec","verbs":["ALL"]},"backoffice-partners-info":{"type":"org.ecolyo.agent.partners.info","verbs":["ALL"]},"backoffice-partners-info-rec":{"type":"org.ecolyo.agent.partners.info.rec","verbs":["ALL"]},"backoffice-prices":{"type":"org.ecolyo.agent.prices","verbs":["ALL"]},"backoffice-prices-rec":{"type":"org.ecolyo.agent.prices.rec","verbs":["ALL"]}}}
 
 /***/ }),
 
@@ -32909,6 +32967,7 @@ var UncomingBar = function UncomingBar(_ref) {
       yScale = _ref.yScale,
       height = _ref.height,
       average = _ref.average;
+  dataload.value = average;
 
   var _useState = (0, _react.useState)(false),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
@@ -32941,10 +33000,10 @@ var UncomingBar = function UncomingBar(_ref) {
     height: height + 40,
     className: "background-false",
     fill: "#E0E0E0"
-  })), height > 0 && average >= 0 && /*#__PURE__*/_react.default.createElement("g", {
-    transform: "translate(".concat(xScale(dataload.date.toLocaleString(_luxon.DateTime.DATETIME_SHORT)), ", ").concat(yScale(average), ")")
+  })), height > 0 && dataload.value >= 0 && /*#__PURE__*/_react.default.createElement("g", {
+    transform: "translate(".concat(xScale(dataload.date.toLocaleString(_luxon.DateTime.DATETIME_SHORT)), ", ").concat(yScale(dataload.value), ")")
   }, /*#__PURE__*/_react.default.createElement("path", {
-    d: topRoundedRectDashedLine(0, 0, getBandWidth(), height - yScale(average)),
+    d: topRoundedRectDashedLine(0, 0, getBandWidth(), height - yScale(dataload.value)),
     fill: "url(#gradient)",
     strokeDasharray: "5",
     stroke: '#61f0f2',
@@ -33060,9 +33119,7 @@ var Bar = function Bar(_ref) {
       isSwitching = _ref.isSwitching,
       isDuel = _ref.isDuel,
       isMultiMissingFluid = _ref.isMultiMissingFluid,
-      weekdays = _ref.weekdays,
-      _ref$clickable = _ref.clickable,
-      clickable = _ref$clickable === void 0 ? true : _ref$clickable;
+      weekdays = _ref.weekdays;
   var dispatch = (0, _reactRedux.useDispatch)();
 
   var _useSelector = (0, _reactRedux.useSelector)(function (state) {
@@ -33089,7 +33146,7 @@ var Bar = function Bar(_ref) {
   var fluidStyle = fluidType === _fluid.FluidType.MULTIFLUID ? 'MULTIFLUID' : _fluid.FluidType[fluidType];
 
   var handleClick = function handleClick() {
-    if (!isSwitching && !isDuel && clickable) {
+    if (!isSwitching && !isDuel) {
       setClicked(true);
       dispatch((0, _chart.setSelectedDate)(dataload.date));
     }
@@ -33116,7 +33173,6 @@ var Bar = function Bar(_ref) {
   var edgeBrowser = browser && browser.name !== 'edge';
   var selected = isSelectedDate ? ' selected' : '';
   var bounce = edgeBrowser ? '1' : '3';
-  var disabled = "".concat(clickable ? '' : 'disabled');
 
   var getBarClass = function getBarClass() {
     var bounceDelay = " bounce-".concat(bounce, " delay--").concat(delayIndex);
@@ -33125,10 +33181,10 @@ var Bar = function Bar(_ref) {
     if (clicked) {
       return "".concat(fluidWeekdays).concat(selected, " bounce-2 delay");
     } else if (animationEnded) {
-      return "".concat(fluidWeekdays).concat(selected, " ").concat(disabled);
+      return "".concat(fluidWeekdays).concat(selected);
     }
 
-    return "".concat(fluidWeekdays).concat(bounceDelay).concat(selected, " ").concat(disabled);
+    return "".concat(fluidWeekdays).concat(bounceDelay).concat(selected);
   };
 
   var getCompareBarClass = function getCompareBarClass() {
@@ -33168,7 +33224,7 @@ var Bar = function Bar(_ref) {
   }, [dispatch, isSelectedDate, isDuel, index]);
   return /*#__PURE__*/_react.default.createElement("g", null, height > 0 && /*#__PURE__*/_react.default.createElement("g", {
     transform: "translate(".concat(xScaleValue, ", -40)"),
-    className: "barContainer ".concat(disabled)
+    className: "barContainer"
   }, /*#__PURE__*/_react.default.createElement("rect", {
     onClick: !weekdays ? handleClick : function () {
       return undefined;
@@ -33606,7 +33662,7 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("1RIw");
 
@@ -33811,19 +33867,19 @@ var EcogestureView = /*#__PURE__*/(0, _react.lazy)(function () {
   return __webpack_require__.e(/* import() */ 6).then(__webpack_require__.t.bind(null, "1MlH", 7));
 });
 var SingleEcogesture = /*#__PURE__*/(0, _react.lazy)(function () {
-  return __webpack_require__.e(/* import() */ 9).then(__webpack_require__.t.bind(null, "GwQd", 7));
+  return __webpack_require__.e(/* import() */ 8).then(__webpack_require__.t.bind(null, "GwQd", 7));
 });
 var OptionsView = /*#__PURE__*/(0, _react.lazy)(function () {
-  return Promise.all(/* import() */[__webpack_require__.e(0), __webpack_require__.e(8), __webpack_require__.e(4)]).then(__webpack_require__.t.bind(null, "e+zH", 7));
+  return Promise.all(/* import() */[__webpack_require__.e(0), __webpack_require__.e(4)]).then(__webpack_require__.t.bind(null, "e+zH", 7));
 });
 var LegalNoticeView = /*#__PURE__*/(0, _react.lazy)(function () {
-  return __webpack_require__.e(/* import() */ 10).then(__webpack_require__.t.bind(null, "ckxh", 7));
+  return __webpack_require__.e(/* import() */ 9).then(__webpack_require__.t.bind(null, "ckxh", 7));
 });
 var GCUView = /*#__PURE__*/(0, _react.lazy)(function () {
   return __webpack_require__.e(/* import() */ 1).then(__webpack_require__.t.bind(null, "+Tny", 7));
 });
 var AnalysisView = /*#__PURE__*/(0, _react.lazy)(function () {
-  return Promise.all(/* import() */[__webpack_require__.e(0), __webpack_require__.e(7), __webpack_require__.e(8), __webpack_require__.e(3)]).then(__webpack_require__.t.bind(null, "DTIR", 7));
+  return Promise.all(/* import() */[__webpack_require__.e(0), __webpack_require__.e(7), __webpack_require__.e(3)]).then(__webpack_require__.t.bind(null, "DTIR", 7));
 });
 var ProfileTypeView = /*#__PURE__*/(0, _react.lazy)(function () {
   return Promise.resolve(/* import() */).then(__webpack_require__.t.bind(null, "nKTC", 7));
@@ -33998,7 +34054,7 @@ var _reactRedux = __webpack_require__("/MKj");
 
 var _exploration = _interopRequireDefault(__webpack_require__("z8s1"));
 
-var _challenge = __webpack_require__("F6Xr");
+var _challenge = __webpack_require__("ojwR");
 
 var _global = __webpack_require__("c4IZ");
 
@@ -34374,35 +34430,33 @@ var _slicedToArray2 = _interopRequireDefault(__webpack_require__("J4zp"));
 
 var _react = __webpack_require__("q1tI");
 
-/**
- * Update the width and height of the chart when the window is resized or the chart is loaded
- */
-var useChartResize = function useChartResize(ref, loading) {
-  var maxHeight = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 300;
-  var maxWidth = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 940;
+var useChartResize = function useChartResize(ref) {
+  var maxHeight = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 300;
+  var maxWidth = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 940;
+  var loading = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
 
-  var _useState = (0, _react.useState)(maxHeight),
+  var _useState = (0, _react.useState)(0),
       _useState2 = (0, _slicedToArray2.default)(_useState, 2),
-      height = _useState2[0],
-      setHeight = _useState2[1];
+      width = _useState2[0],
+      setWidth = _useState2[1];
 
-  var _useState3 = (0, _react.useState)(maxWidth),
+  var _useState3 = (0, _react.useState)(0),
       _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
-      width = _useState4[0],
-      setWidth = _useState4[1];
+      height = _useState4[0],
+      setHeight = _useState4[1];
 
   (0, _react.useEffect)(function () {
     function handleResize() {
       if (!loading) {
-        var _ref$current, _ref$current2;
+        var _ref$current$offsetWi, _ref$current, _ref$current$offsetHe, _ref$current2;
 
-        var chartContainerHeight = ((_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.offsetHeight) || maxHeight;
-        var chartContainerWidth = ((_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.offsetWidth) || maxWidth;
-
-        var _height = Math.min(chartContainerHeight, maxHeight);
+        var chartContainerWidth = (_ref$current$offsetWi = ref === null || ref === void 0 ? void 0 : (_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.offsetWidth) !== null && _ref$current$offsetWi !== void 0 ? _ref$current$offsetWi : 400;
+        var chartContainerHeight = (_ref$current$offsetHe = ref === null || ref === void 0 ? void 0 : (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.offsetHeight) !== null && _ref$current$offsetHe !== void 0 ? _ref$current$offsetHe : 200;
 
         var _width = Math.min(chartContainerWidth, maxWidth);
 
+        var _height = Math.min(chartContainerHeight, maxHeight);
+
         setWidth(_width);
         setHeight(_height);
       }
@@ -34413,7 +34467,7 @@ var useChartResize = function useChartResize(ref, loading) {
     return function () {
       return window.removeEventListener('resize', handleResize);
     };
-  }, [loading, maxHeight, maxWidth, ref]);
+  }, [loading]);
   return {
     width: width,
     height: height
@@ -35470,7 +35524,7 @@ var MatomoTracker = /*#__PURE__*/function () {
         return;
       }
 
-      var currentPath = loc.pathname;
+      var currentPath = loc.hash.substring(1);
       MatomoTracker.push(['setCustomUrl', 'https://ecolyo.com' + currentPath]);
       MatomoTracker.push(['setDocumentTitle', currentPath.substring(1)]);
       MatomoTracker.push(['trackPageView']);
@@ -35916,15 +35970,15 @@ var EcogestureService = /*#__PURE__*/function () {
                     season: {
                       $ne: seasonFilter
                     }
-                  }).indexFields(['season']).sortBy([{
+                  }).sortBy([{
                     season: 'desc'
                   }]);
                 } else if (orderByID) {
-                  query = query.where({}).indexFields(['_id']).sortBy([{
+                  query = query.where({}).sortBy([{
                     _id: 'asc'
                   }]);
                 } else {
-                  query = query.where({}).indexFields(['season']).sortBy([{
+                  query = query.where({}).sortBy([{
                     season: 'desc'
                   }]);
                 }
@@ -35946,7 +36000,7 @@ var EcogestureService = /*#__PURE__*/function () {
                   season: {
                     $eq: seasonFilter
                   }
-                }).indexFields(['season']).sortBy([{
+                }).sortBy([{
                   season: 'asc'
                 }]));
 
@@ -36445,7 +36499,7 @@ var TermsService = /*#__PURE__*/function () {
           while (1) {
             switch (_context.prev = _context.next) {
               case 0:
-                query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).indexFields(['acceptedAt']).sortBy([{
+                query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).sortBy([{
                   acceptedAt: 'desc'
                 }]).limitBy(1);
                 _context.next = 3;
@@ -36486,7 +36540,7 @@ var TermsService = /*#__PURE__*/function () {
           while (1) {
             switch (_context2.prev = _context2.next) {
               case 0:
-                query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).indexFields(['acceptedAt']).sortBy([{
+                query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).sortBy([{
                   acceptedAt: 'desc'
                 }]).limitBy(1);
                 _context2.next = 3;
@@ -37008,14 +37062,14 @@ var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
 var _usageEvent2 = _interopRequireDefault(__webpack_require__("dECN"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 var _utils = __webpack_require__("c+yx");
 
-var _ChallengeNoFluidModal = _interopRequireDefault(__webpack_require__("rDu6"));
-
 __webpack_require__("Layg");
 
+var _ChallengeNoFluidModal = _interopRequireDefault(__webpack_require__("rDu6"));
+
 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); }
 
 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; }
@@ -37246,7 +37300,7 @@ var _reactRedux = __webpack_require__("/MKj");
 
 var _challenge = _interopRequireDefault(__webpack_require__("kdea"));
 
-var _challenge2 = __webpack_require__("F6Xr");
+var _challenge2 = __webpack_require__("ojwR");
 
 __webpack_require__("8Eoq");
 
diff --git a/index.html b/index.html
index 5e6e46ec983891a586abe8fae4d5af6915d19dfb..3453036b6ee47da01b5fe2dd69df3d7449d13926 100644
--- a/index.html
+++ b/index.html
@@ -1 +1 @@
-<!DOCTYPE html><html lang="{{.Locale}}"><head><meta charset="utf-8"><title>Ecolyo</title><link rel="icon" type="image/png" href="/favicon-32x32.png" sizes="32x32"><link rel="icon" type="image/png" href="/favicon-16x16.png" sizes="16x16"><!-- PWA Manifest --><link rel="manifest" href="/manifest.json" crossorigin="use-credentials"><link rel="mask-icon" href="/safari-pinned-tab.svg" color="#297EF2"><meta name="viewport" content="width=device-width,height=device-height,initial-scale=1,viewport-fit=cover"><!-- PWA Chrome --><link rel="icon" sizes="192x192" href="/android-chrome-192x192.png"><link rel="icon" sizes="512x512" href="/android-chrome-512x512.png"><!-- PWA iOS --><link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png"><link rel="apple-touch-startup-image" href="/apple-touch-icon.png"><meta name="apple-mobile-web-app-title" content="Ecolyo"><meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-status-bar-style" content="black"><!-- PWA Colors --><meta name="theme-color" content="#343641"><meta name="background-color" content="#121212">{{.ThemeCSS}} {{.CozyBar}}<script src="//{{.Domain}}/assets/js/piwik.js"></script></head><body><div role="application" class="application" data-cozy="{{.CozyData}}"><script src="vendors/ecolyo.4fa33e16654f2d5e9a3e.js"></script><script src="app/ecolyo.9c6f20e5996a8ab34cd7.js"></script></div></body></html>
\ No newline at end of file
+<!DOCTYPE html><html lang="{{.Locale}}"><head><meta charset="utf-8"><title>Ecolyo</title><link rel="icon" type="image/png" href="/favicon-32x32.png" sizes="32x32"><link rel="icon" type="image/png" href="/favicon-16x16.png" sizes="16x16"><!-- PWA Manifest --><link rel="manifest" href="/manifest.json" crossorigin="use-credentials"><link rel="mask-icon" href="/safari-pinned-tab.svg" color="#297EF2"><meta name="viewport" content="width=device-width,height=device-height,initial-scale=1,viewport-fit=cover"><!-- PWA Chrome --><link rel="icon" sizes="192x192" href="/android-chrome-192x192.png"><link rel="icon" sizes="512x512" href="/android-chrome-512x512.png"><!-- PWA iOS --><link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png"><link rel="apple-touch-startup-image" href="/apple-touch-icon.png"><meta name="apple-mobile-web-app-title" content="Ecolyo"><meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-status-bar-style" content="black"><!-- PWA Colors --><meta name="theme-color" content="#343641"><meta name="background-color" content="#121212">{{.ThemeCSS}} {{.CozyBar}}<script src="//{{.Domain}}/assets/js/piwik.js"></script></head><body><div role="application" class="application" data-cozy="{{.CozyData}}"><script src="vendors/ecolyo.4fa33e16654f2d5e9a3e.js"></script><script src="app/ecolyo.a3308bcbd50a4d741c60.js"></script></div></body></html>
\ No newline at end of file
diff --git a/manifest.webapp b/manifest.webapp
index 693282ca4cc56d1e2350d6223fdea83682f329bc..ea2e6ac63e87876075f72b5c6d2c24ef94f6f3bd 100644
--- a/manifest.webapp
+++ b/manifest.webapp
@@ -5,7 +5,7 @@
   "categories": [
     "energy"
   ],
-  "version": "2.5.1",
+  "version": "2.4.0",
   "licence": "AGPL-3.0",
   "editor": "Métropole de Lyon",
   "default_locale": "fr",
@@ -243,7 +243,7 @@
       ]
     },
     "ecolyo-dju": {
-      "type": "org.ecolyo.dju_v2",
+      "type": "org.ecolyo.dju",
       "verbs": [
         "GET"
       ]
diff --git a/services/aggregatorUsageEvents/ecolyo.js b/services/aggregatorUsageEvents/ecolyo.js
index 0208c1ccea52ce4a099763b4610e9ddcace06d23..b0e784033acafd17341acfad2d302a37169c6191 100644
--- a/services/aggregatorUsageEvents/ecolyo.js
+++ b/services/aggregatorUsageEvents/ecolyo.js
@@ -44421,23 +44421,19 @@ class ChallengeService {
 
 
   async startUserChallenge(userChallenge) {
-    const newChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
-      state: _userChallenge2.UserChallengeState.ONGOING,
-      progress: {
-        actionProgress: 0,
-        explorationProgress: 0,
-        quizProgress: 0
-      },
-      startDate: _luxon.DateTime.local().setZone('utc', {
-        keepLocalTime: true
-      }).startOf('day'),
-      success: _userChallenge2.UserChallengeSuccess.ONGOING
-    });
+    userChallenge.state = _userChallenge2.UserChallengeState.ONGOING;
+    userChallenge.progress.actionProgress = 0;
+    userChallenge.progress.explorationProgress = 0;
+    userChallenge.progress.quizProgress = 0;
+    userChallenge.startDate = _luxon.DateTime.local().setZone('utc', {
+      keepLocalTime: true
+    }).startOf('day');
+    userChallenge.success = _userChallenge2.UserChallengeSuccess.ONGOING;
 
     try {
       const {
         data: updatedUserChallengeEntity
-      } = await this._client.create(_doctypes.USERCHALLENGE_DOCTYPE, newChallenge);
+      } = await this._client.create(_doctypes.USERCHALLENGE_DOCTYPE, userChallenge);
       const updatedUserChallenge = this.parseUserChallengeEntityToUserChallenge(updatedUserChallengeEntity);
       return updatedUserChallenge;
     } catch (error) {
@@ -44532,18 +44528,20 @@ class ChallengeService {
         break;
 
       case _userChallenge2.UserChallengeUpdateFlag.QUIZ_DONE:
-        {
-          const updateQuizProgress = Math.min(userChallenge.quiz.result, 5);
-          updatedQuiz = await quizService.endUserQuiz(userChallenge.quiz);
-          updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
-            quiz: updatedQuiz,
-            progress: _objectSpread(_objectSpread({}, userChallenge.progress), {}, {
-              quizProgress: updateQuizProgress
-            })
-          });
-          break;
+        if (userChallenge.quiz.result > userChallenge.progress.quizProgress) {
+          userChallenge.progress.quizProgress = userChallenge.quiz.result;
         }
 
+        if (userChallenge.progress.quizProgress > 5) {
+          userChallenge.progress.quizProgress = 5;
+        }
+
+        updatedQuiz = await quizService.endUserQuiz(userChallenge.quiz);
+        updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
+          quiz: updatedQuiz
+        });
+        break;
+
       case _userChallenge2.UserChallengeUpdateFlag.QUIZ_UPDATE:
         updatedUserChallenge = _objectSpread(_objectSpread({}, userChallenge), {}, {
           quiz: quizWithUpdatedQuestions ? quizWithUpdatedQuestions : userChallenge.quiz
@@ -96919,7 +96917,7 @@ class ConsumptionDataManager {
 
 
   async getFirsDataDateFromDoctype(doctype) {
-    const query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
       year: 'asc'
     }, {
       month: 'asc'
@@ -96930,11 +96928,8 @@ class ConsumptionDataManager {
 
   async getFirstDataDateFromDoctypeWithPrice(doctype) {
     const query = (0, _cozyClient.Q)(doctype).where({
-      year: {
-        $gt: null
-      },
-      month: {
-        $gt: null
+      price: {
+        $exists: false
       }
     }).partialIndex({
       price: {
@@ -97494,7 +97489,7 @@ class DateChartService {
    */
 
 
-  incrementDate(timeStep, selectedDate, increment) {
+  incrementeDate(timeStep, selectedDate, increment) {
     switch (timeStep) {
       case _timeStep.TimeStep.YEAR:
         return selectedDate.plus({
@@ -97648,7 +97643,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__(120);
 
@@ -97784,6 +97779,20 @@ const convertDateToShortDateString = (actualData, timeStep) => {
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+const convertDateToMonthString = date => {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 const convertDateToMonthYearString = date => {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -97827,11 +97836,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -97883,14 +97891,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -97941,6 +97941,7 @@ function formatNumberValues(value, fluidStyle, toBeCompared = false) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -97951,6 +97952,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -97961,6 +97963,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -97972,6 +97975,7 @@ function getRelationships(doc, relNameList) {
   }))[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -97989,23 +97993,14 @@ const importIconById = async (id, pathType) => {
     return importedChallengeIcon.default;
   }
 };
-
-exports.importIconById = importIconById;
-
-const getMonthFullName = month => {
-  const monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 const getMonthName = date => {
   const monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -99559,14 +99554,14 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
         load: 'desc'
-      }]).limitBy(1);
+      }]);
     }
 
-    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
       load: 'desc'
-    }]).limitBy(limit);
+    }]);
   }
 
   buildFirstDateQuery(fluidType, limit, timeStep) {
@@ -99924,7 +99919,7 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     try {
-      const query = (0, _cozyClient.Q)(doctype).limitBy(1);
+      const query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
       const result = await this._client.query(query);
       return result;
     } catch (error) {
@@ -100583,16 +100578,21 @@ class QuizService {
 
 
   async startUserQuiz(userQuiz) {
-    const questions = userQuiz.questions.map(question => _objectSpread(_objectSpread({}, question), {}, {
-      answers: (0, _lodash.shuffle)(question.answers)
-    }));
-    return _objectSpread(_objectSpread({}, userQuiz), {}, {
-      questions: (0, _lodash.shuffle)(questions),
+    const {
+      questions
+    } = userQuiz;
+    questions.forEach(question => question.answers = (0, _lodash.shuffle)(question.answers));
+    const randomizedQuestions = (0, _lodash.shuffle)(questions);
+
+    const updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
+      questions: randomizedQuestions,
       state: _userQuiz.UserQuizState.ONGOING,
       startDate: _luxon.DateTime.local().setZone('utc', {
         keepLocalTime: true
       })
     });
+
+    return updatedUserQuiz;
   }
   /**
    * Return quiz with updated state to UserQuizState.UNLOCKED and updated questions with false result
@@ -100602,20 +100602,23 @@ class QuizService {
 
 
   async resetUserQuiz(userQuiz) {
-    const updatedQuestions = userQuiz.questions.map(question => _objectSpread(_objectSpread({}, question), {}, {
-      result: _userQuiz.UserQuestionState.UNLOCKED
-    }));
+    const updatedQuestions = userQuiz.questions;
+    updatedQuestions.forEach(question => {
+      question.result = _userQuiz.UserQuestionState.UNLOCKED;
+    });
 
     const updatedCustomQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
       result: _userQuiz.UserQuestionState.UNLOCKED
     });
 
-    return _objectSpread(_objectSpread({}, userQuiz), {}, {
+    const updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
       customQuestion: updatedCustomQuestion,
       questions: updatedQuestions,
       result: 0,
       state: _userQuiz.UserQuizState.UNLOCKED
     });
+
+    return updatedUserQuiz;
   }
   /**
    * Return quiz with updated state to UserQuizState.DONE
@@ -100641,26 +100644,28 @@ class QuizService {
 
 
   async updateUserQuiz(userQuiz, questionResult, questionIndex) {
-    const result = questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT;
-    const updatedQuestions = userQuiz.questions.map((question, index) => {
-      if (index === questionIndex) {
-        return _objectSpread(_objectSpread({}, question), {}, {
-          result: result
-        });
-      }
+    if (questionIndex !== undefined) {
+      const updatedQuestion = _objectSpread(_objectSpread({}, userQuiz.questions[questionIndex]), {}, {
+        result: questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT
+      });
 
-      return question;
-    });
+      userQuiz.questions[questionIndex] = updatedQuestion;
+    } else {
+      const updatedQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
+        result: questionResult ? _userQuiz.UserQuestionState.CORRECT : _userQuiz.UserQuestionState.UNCORRECT
+      });
 
-    const updatedCustomQuestion = _objectSpread(_objectSpread({}, userQuiz.customQuestion), {}, {
-      result: result
-    });
+      userQuiz.customQuestion = updatedQuestion;
+    }
 
-    return _objectSpread(_objectSpread({}, userQuiz), {}, {
-      questions: updatedQuestions,
-      customQuestion: questionIndex === undefined ? updatedCustomQuestion : userQuiz.customQuestion,
-      result: questionResult ? Math.min(userQuiz.result + 1, 5) : userQuiz.result
+    let quizScoreLimit = userQuiz.result;
+    quizScoreLimit = quizScoreLimit + 1 > 5 ? 5 : quizScoreLimit + 1;
+
+    const updatedUserQuiz = _objectSpread(_objectSpread({}, userQuiz), {}, {
+      result: questionResult ? quizScoreLimit : userQuiz.result
     });
+
+    return updatedUserQuiz;
   }
   /**
    * Build a custom question with the customQuestionEntity
@@ -101474,15 +101479,15 @@ class EcogestureService {
         season: {
           $ne: seasonFilter
         }
-      }).indexFields(['season']).sortBy([{
+      }).sortBy([{
         season: 'desc'
       }]);
     } else if (orderByID) {
-      query = query.where({}).indexFields(['_id']).sortBy([{
+      query = query.where({}).sortBy([{
         _id: 'asc'
       }]);
     } else {
-      query = query.where({}).indexFields(['season']).sortBy([{
+      query = query.where({}).sortBy([{
         season: 'desc'
       }]);
     }
@@ -101498,7 +101503,7 @@ class EcogestureService {
         season: {
           $eq: seasonFilter
         }
-      }).indexFields(['season']).sortBy([{
+      }).sortBy([{
         season: 'asc'
       }]));
       return [...ecogesturesWithSeason, ...ecogestures];
@@ -118862,7 +118867,7 @@ class ProfileTypeEntityService {
         updateDate: {
           $lte: date.toString()
         }
-      }).indexFields(['updateDate']).sortBy([{
+      }).sortBy([{
         updateDate: 'desc'
       }]).limitBy(1));
       const result = profileType ? profileType : null;
@@ -118897,7 +118902,11 @@ class ProfileTypeEntityService {
     } else {
       const {
         data: [profileType]
-      } = await this._client.query(query.where({}).indexFields(['updateDate']).sortBy([{
+      } = await this._client.query(query.where({
+        _id: {
+          $gt: null
+        }
+      }).sortBy([{
         updateDate: 'desc'
       }]).limitBy(1));
       const result = profileType ? profileType : null;
@@ -118926,7 +118935,7 @@ class ProfileTypeEntityService {
         updateDate: {
           $gte: timePeriod.startDate.toString()
         }
-      }).indexFields(['updateDate']).sortBy([{
+      }).sortBy([{
         updateDate: 'asc'
       }]).limitBy(100));
 
@@ -118965,7 +118974,7 @@ class ProfileTypeEntityService {
    */
 
 
-  async saveProfileType(attributes) {
+  async updateProfileType(attributes) {
     const query = (0, _cozyClient.Q)(_doctypes.PROFILETYPE_DOCTYPE);
     const {
       data: [doc]
@@ -119078,7 +119087,7 @@ class TermsService {
 
 
   async getLastTerm() {
-    const query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).indexFields(['acceptedAt']).sortBy([{
+    const query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).sortBy([{
       acceptedAt: 'desc'
     }]).limitBy(1);
     const {
@@ -119093,7 +119102,7 @@ class TermsService {
 
 
   async isLastTermValidated() {
-    const query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).indexFields(['acceptedAt']).sortBy([{
+    const query = (0, _cozyClient.Q)(_doctypes.TERMS_DOCTYPE).where({}).sortBy([{
       acceptedAt: 'desc'
     }]).limitBy(1);
     const {
@@ -119250,11 +119259,10 @@ class UsageEventService {
     try {
       // Get last Connection attempt Event
       const query = (0, _cozyClient.Q)(_doctypes.USAGEEVENT_DOCTYPE).where({
-        target: konnectorSlug
-      }).partialIndex({
         type: _usageEvent.UsageEventType.KONNECTOR_ATTEMPT_EVENT,
+        target: konnectorSlug,
         result: 'error'
-      }).indexFields(['eventDate', 'type']).sortBy([{
+      }).sortBy([{
         eventDate: 'desc'
       }]).limitBy(1);
       const {
diff --git a/services/consumptionAlert/ecolyo.js b/services/consumptionAlert/ecolyo.js
index ae4f62b3feb4f96920a91657b3f364039cd2e009..615006c181e66c7eede93efbefed6d0d21e53e7c 100644
--- a/services/consumptionAlert/ecolyo.js
+++ b/services/consumptionAlert/ecolyo.js
@@ -94610,7 +94610,7 @@ class ConsumptionDataManager {
 
 
   async getFirsDataDateFromDoctype(doctype) {
-    const query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
       year: 'asc'
     }, {
       month: 'asc'
@@ -94621,11 +94621,8 @@ class ConsumptionDataManager {
 
   async getFirstDataDateFromDoctypeWithPrice(doctype) {
     const query = (0, _cozyClient.Q)(doctype).where({
-      year: {
-        $gt: null
-      },
-      month: {
-        $gt: null
+      price: {
+        $exists: false
       }
     }).partialIndex({
       price: {
@@ -95185,7 +95182,7 @@ class DateChartService {
    */
 
 
-  incrementDate(timeStep, selectedDate, increment) {
+  incrementeDate(timeStep, selectedDate, increment) {
     switch (timeStep) {
       case _timeStep.TimeStep.YEAR:
         return selectedDate.plus({
@@ -95339,7 +95336,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__(120);
 
@@ -95475,6 +95472,20 @@ const convertDateToShortDateString = (actualData, timeStep) => {
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+const convertDateToMonthString = date => {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 const convertDateToMonthYearString = date => {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -95518,11 +95529,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -95574,14 +95584,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -95632,6 +95634,7 @@ function formatNumberValues(value, fluidStyle, toBeCompared = false) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95642,6 +95645,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95652,6 +95656,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -95663,6 +95668,7 @@ function getRelationships(doc, relNameList) {
   }))[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -95680,23 +95686,14 @@ const importIconById = async (id, pathType) => {
     return importedChallengeIcon.default;
   }
 };
-
-exports.importIconById = importIconById;
-
-const getMonthFullName = month => {
-  const monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 const getMonthName = date => {
   const monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -97250,14 +97247,14 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
         load: 'desc'
-      }]).limitBy(1);
+      }]);
     }
 
-    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
       load: 'desc'
-    }]).limitBy(limit);
+    }]);
   }
 
   buildFirstDateQuery(fluidType, limit, timeStep) {
@@ -97615,7 +97612,7 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     try {
-      const query = (0, _cozyClient.Q)(doctype).limitBy(1);
+      const query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
       const result = await this._client.query(query);
       return result;
     } catch (error) {
diff --git a/services/enedisHalfHourMonthlyAnalysis/ecolyo.js b/services/enedisHalfHourMonthlyAnalysis/ecolyo.js
index d3629c5f63d24ba971241cb0ae227a01e6b26976..cd5b3cf5ceba37a43abb84c0ff8b837276fb17f9 100644
--- a/services/enedisHalfHourMonthlyAnalysis/ecolyo.js
+++ b/services/enedisHalfHourMonthlyAnalysis/ecolyo.js
@@ -94610,7 +94610,7 @@ class ConsumptionDataManager {
 
 
   async getFirsDataDateFromDoctype(doctype) {
-    const query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
       year: 'asc'
     }, {
       month: 'asc'
@@ -94621,11 +94621,8 @@ class ConsumptionDataManager {
 
   async getFirstDataDateFromDoctypeWithPrice(doctype) {
     const query = (0, _cozyClient.Q)(doctype).where({
-      year: {
-        $gt: null
-      },
-      month: {
-        $gt: null
+      price: {
+        $exists: false
       }
     }).partialIndex({
       price: {
@@ -95185,7 +95182,7 @@ class DateChartService {
    */
 
 
-  incrementDate(timeStep, selectedDate, increment) {
+  incrementeDate(timeStep, selectedDate, increment) {
     switch (timeStep) {
       case _timeStep.TimeStep.YEAR:
         return selectedDate.plus({
@@ -95339,7 +95336,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__(120);
 
@@ -95475,6 +95472,20 @@ const convertDateToShortDateString = (actualData, timeStep) => {
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+const convertDateToMonthString = date => {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 const convertDateToMonthYearString = date => {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -95518,11 +95529,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -95574,14 +95584,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -95632,6 +95634,7 @@ function formatNumberValues(value, fluidStyle, toBeCompared = false) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95642,6 +95645,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95652,6 +95656,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -95663,6 +95668,7 @@ function getRelationships(doc, relNameList) {
   }))[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -95680,23 +95686,14 @@ const importIconById = async (id, pathType) => {
     return importedChallengeIcon.default;
   }
 };
-
-exports.importIconById = importIconById;
-
-const getMonthFullName = month => {
-  const monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 const getMonthName = date => {
   const monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -97250,14 +97247,14 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
         load: 'desc'
-      }]).limitBy(1);
+      }]);
     }
 
-    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
       load: 'desc'
-    }]).limitBy(limit);
+    }]);
   }
 
   buildFirstDateQuery(fluidType, limit, timeStep) {
@@ -97615,7 +97612,7 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     try {
-      const query = (0, _cozyClient.Q)(doctype).limitBy(1);
+      const query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
       const result = await this._client.query(query);
       return result;
     } catch (error) {
@@ -98768,7 +98765,7 @@ class EnedisMonthlyAnalysisDataService {
 
 
   async getLastEnedisMonthlyAnalysis() {
-    const query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({}).sortBy([{
       year: 'desc'
     }, {
       month: 'desc'
@@ -98793,7 +98790,7 @@ class EnedisMonthlyAnalysisDataService {
     const query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MONTHLY_ANALYSIS_DATA_DOCTYPE).where({
       year: year,
       month: month
-    }).indexFields(['year', 'month']).sortBy([{
+    }).sortBy([{
       year: 'desc'
     }, {
       month: 'desc'
@@ -98836,7 +98833,7 @@ class EnedisMonthlyAnalysisDataService {
     const query = (0, _cozyClient.Q)(_doctypes.ENEDIS_MAXPOWER_DOCTYPE).where({
       year: year,
       month: month
-    }).indexFields(['year', 'month']).sortBy([{
+    }).sortBy([{
       year: 'desc'
     }, {
       month: 'desc'
diff --git a/services/fluidsPrices/ecolyo.js b/services/fluidsPrices/ecolyo.js
index a80b12264a3699e7e926c6300c0b46b59186d1a6..14da2a61650f51f9fb06bf8838da7e3a1eb64186 100644
--- a/services/fluidsPrices/ecolyo.js
+++ b/services/fluidsPrices/ecolyo.js
@@ -94610,7 +94610,7 @@ class ConsumptionDataManager {
 
 
   async getFirsDataDateFromDoctype(doctype) {
-    const query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
       year: 'asc'
     }, {
       month: 'asc'
@@ -94621,11 +94621,8 @@ class ConsumptionDataManager {
 
   async getFirstDataDateFromDoctypeWithPrice(doctype) {
     const query = (0, _cozyClient.Q)(doctype).where({
-      year: {
-        $gt: null
-      },
-      month: {
-        $gt: null
+      price: {
+        $exists: false
       }
     }).partialIndex({
       price: {
@@ -95185,7 +95182,7 @@ class DateChartService {
    */
 
 
-  incrementDate(timeStep, selectedDate, increment) {
+  incrementeDate(timeStep, selectedDate, increment) {
     switch (timeStep) {
       case _timeStep.TimeStep.YEAR:
         return selectedDate.plus({
@@ -95339,7 +95336,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__(120);
 
@@ -95475,6 +95472,20 @@ const convertDateToShortDateString = (actualData, timeStep) => {
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+const convertDateToMonthString = date => {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 const convertDateToMonthYearString = date => {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -95518,11 +95529,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -95574,14 +95584,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -95632,6 +95634,7 @@ function formatNumberValues(value, fluidStyle, toBeCompared = false) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95642,6 +95645,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95652,6 +95656,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -95663,6 +95668,7 @@ function getRelationships(doc, relNameList) {
   }))[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -95680,23 +95686,14 @@ const importIconById = async (id, pathType) => {
     return importedChallengeIcon.default;
   }
 };
-
-exports.importIconById = importIconById;
-
-const getMonthFullName = month => {
-  const monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 const getMonthName = date => {
   const monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -97250,14 +97247,14 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
         load: 'desc'
-      }]).limitBy(1);
+      }]);
     }
 
-    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
       load: 'desc'
-    }]).limitBy(limit);
+    }]);
   }
 
   buildFirstDateQuery(fluidType, limit, timeStep) {
@@ -97615,7 +97612,7 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     try {
-      const query = (0, _cozyClient.Q)(doctype).limitBy(1);
+      const query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
       const result = await this._client.query(query);
       return result;
     } catch (error) {
@@ -98884,14 +98881,14 @@ class FluidPricesService {
 
 
   async getPrices(fluidType, date) {
-    const query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).where({
+    const query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).indexFields(['startDate']).where({
       startDate: {
         $lte: date.toISO({
           suppressMilliseconds: true
         }).toString()
       },
       fluidType
-    }).indexFields(['startDate']).sortBy([{
+    }).sortBy([{
       startDate: 'desc'
     }]).limitBy(1);
     const {
@@ -98906,11 +98903,11 @@ class FluidPricesService {
 
 
   async getAllLastPrices() {
-    const query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).where({
+    const query = (0, _cozyClient.Q)(_doctypes.FLUIDSPRICES_DOCTYPE).indexFields(['fluidType']).where({
       endDate: {
         $eq: ''
       }
-    }).indexFields(['fluidType']).sortBy([{
+    }).sortBy([{
       fluidType: 'asc'
     }]).limitBy(3);
     const {
diff --git a/services/monthlyReportNotification/ecolyo.js b/services/monthlyReportNotification/ecolyo.js
index fdf331d5738a15963b54c2148900a98fc8e26aba..b5c9295c031ee12a20deeeef97d9873980c360eb 100644
--- a/services/monthlyReportNotification/ecolyo.js
+++ b/services/monthlyReportNotification/ecolyo.js
@@ -94610,7 +94610,7 @@ class ConsumptionDataManager {
 
 
   async getFirsDataDateFromDoctype(doctype) {
-    const query = (0, _cozyClient.Q)(doctype).where({}).indexFields(['year', 'month']).sortBy([{
+    const query = (0, _cozyClient.Q)(doctype).where({}).sortBy([{
       year: 'asc'
     }, {
       month: 'asc'
@@ -94621,11 +94621,8 @@ class ConsumptionDataManager {
 
   async getFirstDataDateFromDoctypeWithPrice(doctype) {
     const query = (0, _cozyClient.Q)(doctype).where({
-      year: {
-        $gt: null
-      },
-      month: {
-        $gt: null
+      price: {
+        $exists: false
       }
     }).partialIndex({
       price: {
@@ -95185,7 +95182,7 @@ class DateChartService {
    */
 
 
-  incrementDate(timeStep, selectedDate, increment) {
+  incrementeDate(timeStep, selectedDate, increment) {
     switch (timeStep) {
       case _timeStep.TimeStep.YEAR:
         return selectedDate.plus({
@@ -95339,7 +95336,7 @@ Object.defineProperty(exports, "__esModule", {
   value: true
 });
 exports.compareDates = compareDates;
-exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = void 0;
+exports.isLastPeriodReached = exports.isLastDateReached = exports.getLagDays = exports.getActualAnalysisDate = exports.convertDateToShortDateString = exports.convertDateToMonthYearString = exports.convertDateToMonthString = void 0;
 
 var _fluid = __webpack_require__(120);
 
@@ -95475,6 +95472,20 @@ const convertDateToShortDateString = (actualData, timeStep) => {
 
 exports.convertDateToShortDateString = convertDateToShortDateString;
 
+const convertDateToMonthString = date => {
+  if (date.month !== 4 && date.month != 8 && date.month != 10) {
+    return ' de ' + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  } else {
+    return " d'" + date.setLocale('fr-FR').toLocaleString({
+      month: 'long'
+    });
+  }
+};
+
+exports.convertDateToMonthString = convertDateToMonthString;
+
 const convertDateToMonthYearString = date => {
   return date.setLocale('fr-FR').toLocaleString({
     month: 'long',
@@ -95518,11 +95529,10 @@ Object.defineProperty(exports, "__esModule", {
 });
 exports.formatNumberValues = formatNumberValues;
 exports.getChallengeTitleWithLineReturn = void 0;
-exports.getFluidName = getFluidName;
 exports.getFluidType = getFluidType;
 exports.getKonnectorSlug = getKonnectorSlug;
 exports.getKonnectorUpdateError = getKonnectorUpdateError;
-exports.getMonthNameWithPrep = exports.getMonthName = exports.getMonthFullName = void 0;
+exports.getMonthNameWithPrep = exports.getMonthName = void 0;
 exports.getRelationship = getRelationship;
 exports.getRelationshipHasMany = getRelationshipHasMany;
 exports.getRelationships = getRelationships;
@@ -95574,14 +95584,6 @@ function getKonnectorSlug(fluidType) {
       throw new Error('unknown fluidtype');
   }
 }
-/** Return lowercase fluidtype
- * @example FluidType.ELECTRICITY => 'electricity'
- */
-
-
-function getFluidName(fluidType) {
-  return _fluid.FluidType[fluidType].toLowerCase();
-}
 
 function getKonnectorUpdateError(type) {
   switch (type.toUpperCase()) {
@@ -95632,6 +95634,7 @@ function formatNumberValues(value, fluidStyle, toBeCompared = false) {
 }
 /**
  * Get one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95642,6 +95645,7 @@ function getRelationship(doc, relName) {
 }
 /**
  * Get array of items in one relation in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {string} relName - Name of the relation
  */
@@ -95652,6 +95656,7 @@ function getRelationshipHasMany(doc, relName) {
 }
 /**
  * Get many relations in doc
+ *
  * @param {object} doc - DocumentEntity
  * @param {Array<[relName: string]: Array<Relation>>} relNameList - Array of name of the relations
  */
@@ -95663,6 +95668,7 @@ function getRelationships(doc, relNameList) {
   }))[0];
 }
 /**
+ *
  * @param id
  * @param pathType
  */
@@ -95680,23 +95686,14 @@ const importIconById = async (id, pathType) => {
     return importedChallengeIcon.default;
   }
 };
-
-exports.importIconById = importIconById;
-
-const getMonthFullName = month => {
-  const monthNames = ['Janvier', 'Février', 'Mars', 'Avril', 'Mai', 'Juin', 'Juillet', 'Août', 'Septembre', 'Octobre', 'Novembre', 'Décembre'];
-  if (month < 1 || month > 12) throw new Error('Invalid month');
-  return monthNames[month - 1];
-};
 /**
  * Return month string according to month index
- * @Note Equivalent to date.monthLong
  * @param date - DateTime
  * @returns month in french
  */
 
 
-exports.getMonthFullName = getMonthFullName;
+exports.importIconById = importIconById;
 
 const getMonthName = date => {
   const monthNames = ['janvier', 'février', 'mars', 'avril', 'mai', 'juin', 'juillet', 'août', 'septembre', 'octobre', 'novembre', 'décembre'];
@@ -97250,14 +97247,14 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     if (timeStep === _timeStep.TimeStep.HALF_AN_HOUR) {
-      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).sortBy([{
+      return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, _timeStep.TimeStep.HALF_AN_HOUR)).indexFields(['load']).limitBy(1).sortBy([{
         load: 'desc'
-      }]).limitBy(1);
+      }]);
     }
 
-    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).sortBy([{
+    return (0, _cozyClient.Q)(doctype).where(this.getPredicate(maxTimePeriod, timeStep)).indexFields(['load']).limitBy(limit).sortBy([{
       load: 'desc'
-    }]).limitBy(limit);
+    }]);
   }
 
   buildFirstDateQuery(fluidType, limit, timeStep) {
@@ -97615,7 +97612,7 @@ class QueryRunner {
     const doctype = this.getRelevantDoctype(fluidType, timeStep);
 
     try {
-      const query = (0, _cozyClient.Q)(doctype).limitBy(1);
+      const query = (0, _cozyClient.Q)(doctype).where({}).limitBy(1);
       const result = await this._client.query(query);
       return result;
     } catch (error) {