diff --git a/web/src/components/MyEMS/Space/SpaceEnergyCategory.js b/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
index c2dea910..dc2c1b73 100644
--- a/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
+++ b/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
@@ -86,7 +86,7 @@ const SpaceEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
last7Days: t('last7Days')
};
const dateRangePickerStyle = { display: 'block', zIndex: 10};
-
+
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(true);
const [spinnerHidden, setSpinnerHidden] = useState(true);
@@ -109,10 +109,10 @@ const SpaceEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
const [parameterLineChartLabels, setParameterLineChartLabels] = useState([]);
const [parameterLineChartData, setParameterLineChartData] = useState({});
const [parameterLineChartOptions, setParameterLineChartOptions] = useState([]);
-
+
const [detailedDataTableData, setDetailedDataTableData] = useState([]);
const [detailedDataTableColumns, setDetailedDataTableColumns] = useState([{dataField: 'startdatetime', text: t('Datetime'), sort: true}]);
-
+
const [childSpacesTableData, setChildSpacesTableData] = useState([]);
const [childSpacesTableColumns, setChildSpacesTableColumns] = useState([{dataField: 'name', text: t('Child Spaces'), sort: true }]);
const [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
diff --git a/web/src/components/MyEMS/Store/StoreBatch.js b/web/src/components/MyEMS/Store/StoreBatch.js
index e40754c1..2ab6c389 100644
--- a/web/src/components/MyEMS/Store/StoreBatch.js
+++ b/web/src/components/MyEMS/Store/StoreBatch.js
@@ -12,9 +12,8 @@ import {
FormGroup,
Input,
Label,
- Spinner,
+ Spinner
} from 'reactstrap';
-import Datetime from 'react-datetime';
import moment from 'moment';
import loadable from '@loadable/component';
import Cascader from 'rc-cascader';
@@ -25,6 +24,8 @@ import { toast } from 'react-toastify';
import ButtonIcon from '../../common/ButtonIcon';
import { APIBaseURL } from '../../../config';
+import { DateRangePicker } from 'rsuite';
+import { endOfDay} from 'date-fns';
const DetailedDataTable = loadable(() => import('../common/DetailedDataTable'));
@@ -49,14 +50,33 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
const [selectedSpaceID, setSelectedSpaceID] = useState(undefined);
const [storeList, setStoreList] = useState([]);
- const [reportingPeriodBeginsDatetime, setReportingPeriodBeginsDatetime] = useState(current_moment.clone().startOf('month'));
- const [reportingPeriodEndsDatetime, setReportingPeriodEndsDatetime] = useState(current_moment);
const [cascaderOptions, setCascaderOptions] = useState(undefined);
+ const [reportingPeriodDateRange, setReportingPeriodDateRange] = useState([current_moment.clone().startOf('month').toDate(), current_moment.toDate()]);
+ const dateRangePickerLocale = {
+ sunday: t('sunday'),
+ monday: t('monday'),
+ tuesday: t('tuesday'),
+ wednesday: t('wednesday'),
+ thursday: t('thursday'),
+ friday: t('friday'),
+ saturday: t('saturday'),
+ ok: t('ok'),
+ today: t('today'),
+ yesterday: t('yesterday'),
+ hours: t('hours'),
+ minutes: t('minutes'),
+ seconds: t('seconds'),
+ last7Days: t('last7Days')
+ };
+ const dateRangePickerStyle = { display: 'block', zIndex: 10};
+
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(false);
@@ -67,7 +87,7 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
const [detailedDataTableColumns, setDetailedDataTableColumns] = useState(
[{dataField: 'name', text: t('Name'), sort: true}, {dataField: 'space', text: t('Space'), sort: true}]);
const [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
-
+
useEffect(() => {
let isResponseOK = false;
fetch(APIBaseURL + '/spaces/tree', {
@@ -115,29 +135,32 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
setExportButtonHidden(true);
setSubmitButtonDisabled(false);
}
- let onReportingPeriodBeginsDatetimeChange = (newDateTime) => {
- setReportingPeriodBeginsDatetime(newDateTime);
- }
+ // Callback fired when value changed
+ let onReportingPeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setReportingPeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setReportingPeriodDateRange([DateRange[0], DateRange[1]]);
+ }
+ };
- let onReportingPeriodEndsDatetimeChange = (newDateTime) => {
- setReportingPeriodEndsDatetime(newDateTime);
- }
+ // Callback fired when value clean
+ let onReportingPeriodClean = event => {
+ setReportingPeriodDateRange([null, null]);
+ };
- var getValidReportingPeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(reportingPeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(reportingPeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
// Handler
const handleSubmit = e => {
e.preventDefault();
console.log('handleSubmit');
console.log(selectedSpaceID);
- console.log(reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
- console.log(reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
+ console.log(moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss'))
+ console.log(moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'));
// disable submit button
setSubmitButtonDisabled(true);
@@ -152,8 +175,8 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
let isResponseOK = false;
fetch(APIBaseURL + '/reports/storebatch?' +
'spaceid=' + selectedSpaceID +
- '&reportingperiodstartdatetime=' + reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') +
- '&reportingperiodenddatetime=' + reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'), {
+ '&reportingperiodstartdatetime=' + moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') +
+ '&reportingperiodenddatetime=' + moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'), {
method: 'GET',
headers: {
"Content-type": "application/json",
@@ -279,26 +302,19 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
@@ -563,52 +574,36 @@ const StoreEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
@@ -665,6 +660,7 @@ const StoreEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
data={storeLineChartData}
options={storeLineChartOptions}>
+
{
+
);
};
diff --git a/web/src/components/MyEMS/Store/StoreLoad.js b/web/src/components/MyEMS/Store/StoreLoad.js
index 549d69e6..e7c0c638 100644
--- a/web/src/components/MyEMS/Store/StoreLoad.js
+++ b/web/src/components/MyEMS/Store/StoreLoad.js
@@ -13,10 +13,9 @@ import {
Input,
Label,
CustomInput,
- Spinner,
+ Spinner
} from 'reactstrap';
import CountUp from 'react-countup';
-import Datetime from 'react-datetime';
import moment from 'moment';
import loadable from '@loadable/component';
import Cascader from 'rc-cascader';
@@ -30,7 +29,8 @@ import ButtonIcon from '../../common/ButtonIcon';
import { APIBaseURL } from '../../../config';
import { periodTypeOptions } from '../common/PeriodTypeOptions';
import { comparisonTypeOptions } from '../common/ComparisonTypeOptions';
-
+import { DateRangePicker } from 'rsuite';
+import { endOfDay} from 'date-fns';
const DetailedDataTable = loadable(() => import('../common/DetailedDataTable'));
@@ -55,6 +55,8 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -63,20 +65,33 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedStore, setSelectedStore] = useState(undefined);
const [comparisonType, setComparisonType] = useState('month-on-month');
const [periodType, setPeriodType] = useState('daily');
- const [basePeriodBeginsDatetime, setBasePeriodBeginsDatetime] = useState(current_moment.clone().subtract(1, 'months').startOf('month'));
- const [basePeriodEndsDatetime, setBasePeriodEndsDatetime] = useState(current_moment.clone().subtract(1, 'months'));
- const [basePeriodBeginsDatetimeDisabled, setBasePeriodBeginsDatetimeDisabled] = useState(true);
- const [basePeriodEndsDatetimeDisabled, setBasePeriodEndsDatetimeDisabled] = useState(true);
- const [reportingPeriodBeginsDatetime, setReportingPeriodBeginsDatetime] = useState(current_moment.clone().startOf('month'));
- const [reportingPeriodEndsDatetime, setReportingPeriodEndsDatetime] = useState(current_moment);
const [cascaderOptions, setCascaderOptions] = useState(undefined);
-
+ const [basePeriodDateRange, setBasePeriodDateRange] = useState([current_moment.clone().subtract(1, 'months').startOf('month').toDate(), current_moment.clone().subtract(1, 'months').toDate()]);
+ const [basePeriodDateRangePickerDisabled, setBasePeriodDateRangePickerDisabled] = useState(true);
+ const [reportingPeriodDateRange, setReportingPeriodDateRange] = useState([current_moment.clone().startOf('month').toDate(), current_moment.toDate()]);
+ const dateRangePickerLocale = {
+ sunday: t('sunday'),
+ monday: t('monday'),
+ tuesday: t('tuesday'),
+ wednesday: t('wednesday'),
+ thursday: t('thursday'),
+ friday: t('friday'),
+ saturday: t('saturday'),
+ ok: t('ok'),
+ today: t('today'),
+ yesterday: t('yesterday'),
+ hours: t('hours'),
+ minutes: t('minutes'),
+ seconds: t('seconds'),
+ last7Days: t('last7Days')
+ };
+ const dateRangePickerStyle = { display: 'block', zIndex: 10};
+
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(true);
const [spinnerHidden, setSpinnerHidden] = useState(true);
const [exportButtonHidden, setExportButtonHidden] = useState(true);
-
//Results
const [cardSummaryList, setCardSummaryList] = useState([]);
const [storeLineChartLabels, setStoreLineChartLabels] = useState([]);
@@ -90,7 +105,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
const [detailedDataTableData, setDetailedDataTableData] = useState([]);
const [detailedDataTableColumns, setDetailedDataTableColumns] = useState([{dataField: 'startdatetime', text: t('Datetime'), sort: true}]);
const [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
-
+
useEffect(() => {
let isResponseOK = false;
fetch(APIBaseURL + '/spaces/tree', {
@@ -210,67 +225,61 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
console.log(target.value);
setComparisonType(target.value);
if (target.value === 'year-over-year') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'years'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'years'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'years').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'years').toDate()]);
} else if (target.value === 'month-on-month') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'months'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'months'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'months').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'months').toDate()]);
} else if (target.value === 'free-comparison') {
- setBasePeriodBeginsDatetimeDisabled(false);
- setBasePeriodEndsDatetimeDisabled(false);
+ setBasePeriodDateRangePickerDisabled(false);
} else if (target.value === 'none-comparison') {
- setBasePeriodBeginsDatetime(undefined);
- setBasePeriodEndsDatetime(undefined);
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
+ setBasePeriodDateRange([null, null]);
+ setBasePeriodDateRangePickerDisabled(true);
}
- }
+ };
- let onBasePeriodBeginsDatetimeChange = (newDateTime) => {
- setBasePeriodBeginsDatetime(newDateTime);
- }
-
- let onBasePeriodEndsDatetimeChange = (newDateTime) => {
- setBasePeriodEndsDatetime(newDateTime);
- }
-
- let onReportingPeriodBeginsDatetimeChange = (newDateTime) => {
- setReportingPeriodBeginsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onBasePeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setBasePeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setBasePeriodDateRange([DateRange[0], DateRange[1]]);
}
- }
+ };
- let onReportingPeriodEndsDatetimeChange = (newDateTime) => {
- setReportingPeriodEndsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onReportingPeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setReportingPeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setReportingPeriodDateRange([DateRange[0], DateRange[1]]);
+ if (comparisonType === 'year-over-year') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'years').toDate(), moment(DateRange[1]).clone().subtract(1, 'years').toDate()]);
+ } else if (comparisonType === 'month-on-month') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'months').toDate(), moment(DateRange[1]).clone().subtract(1, 'months').toDate()]);
+ }
}
- }
+ };
- var getValidBasePeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(basePeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onBasePeriodClean = event => {
+ setBasePeriodDateRange([null, null]);
+ };
- var getValidBasePeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(basePeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(reportingPeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(reportingPeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onReportingPeriodClean = event => {
+ setReportingPeriodDateRange([null, null]);
+ };
// Handler
const handleSubmit = e => {
@@ -278,11 +287,12 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
console.log('handleSubmit');
console.log(selectedSpaceID);
console.log(selectedStore);
+ console.log(comparisonType);
console.log(periodType);
- console.log(basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
- console.log(reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
+ console.log(basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss'))
+ console.log(moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'));
// disable submit button
setSubmitButtonDisabled(true);
@@ -290,7 +300,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -298,10 +308,10 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/storeload?' +
'storeid=' + selectedStore +
'&periodtype=' + periodType +
- '&baseperiodstartdatetime=' + (basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&baseperiodenddatetime=' + (basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&reportingperiodstartdatetime=' + reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') +
- '&reportingperiodenddatetime=' + reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'), {
+ '&baseperiodstartdatetime=' + (basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&baseperiodenddatetime=' + (basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&reportingperiodstartdatetime=' + moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') +
+ '&reportingperiodenddatetime=' + moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'), {
method: 'GET',
headers: {
"Content-type": "application/json",
@@ -318,7 +328,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
}).then(json => {
if (isResponseOK) {
console.log(json)
-
+
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
let cardSummaryItem = {}
@@ -341,7 +351,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
timestamps['a' + index] = currentValue;
});
setStoreLineChartLabels(timestamps);
-
+
let values = {}
json['reporting_period']['sub_maximums'].forEach((currentValue, index) => {
values['a' + index] = currentValue;
@@ -354,7 +364,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + '/H)'});
});
setStoreLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -376,7 +386,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue });
});
setParameterLineChartOptions(names);
-
+
let detailed_value_list = [];
if (json['reporting_period']['timestamps'].length > 0) {
json['reporting_period']['timestamps'][0].forEach((currentTimestamp, timestampIndex) => {
@@ -407,7 +417,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
dataField: 'startdatetime',
text: t('Datetime'),
sort: true
- })
+ });
json['reporting_period']['names'].forEach((currentValue, index) => {
let unit = json['reporting_period']['units'][index];
detailed_column_list.push({
@@ -445,7 +455,7 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false)
-
+
} else {
toast.error(json.description)
}
@@ -547,52 +557,36 @@ const StoreLoad = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Store/StoreSaving.js b/web/src/components/MyEMS/Store/StoreSaving.js
index d1b85cec..db93cc15 100644
--- a/web/src/components/MyEMS/Store/StoreSaving.js
+++ b/web/src/components/MyEMS/Store/StoreSaving.js
@@ -13,10 +13,9 @@ import {
Input,
Label,
CustomInput,
- Spinner,
+ Spinner
} from 'reactstrap';
import CountUp from 'react-countup';
-import Datetime from 'react-datetime';
import moment from 'moment';
import loadable from '@loadable/component';
import Cascader from 'rc-cascader';
@@ -31,7 +30,8 @@ import ButtonIcon from '../../common/ButtonIcon';
import { APIBaseURL } from '../../../config';
import { periodTypeOptions } from '../common/PeriodTypeOptions';
import { comparisonTypeOptions } from '../common/ComparisonTypeOptions';
-
+import { DateRangePicker } from 'rsuite';
+import { endOfDay} from 'date-fns';
const DetailedDataTable = loadable(() => import('../common/DetailedDataTable'));
@@ -55,6 +55,8 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -63,19 +65,33 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedStore, setSelectedStore] = useState(undefined);
const [comparisonType, setComparisonType] = useState('month-on-month');
const [periodType, setPeriodType] = useState('daily');
- const [basePeriodBeginsDatetime, setBasePeriodBeginsDatetime] = useState(current_moment.clone().subtract(1, 'months').startOf('month'));
- const [basePeriodEndsDatetime, setBasePeriodEndsDatetime] = useState(current_moment.clone().subtract(1, 'months'));
- const [basePeriodBeginsDatetimeDisabled, setBasePeriodBeginsDatetimeDisabled] = useState(true);
- const [basePeriodEndsDatetimeDisabled, setBasePeriodEndsDatetimeDisabled] = useState(true);
- const [reportingPeriodBeginsDatetime, setReportingPeriodBeginsDatetime] = useState(current_moment.clone().startOf('month'));
- const [reportingPeriodEndsDatetime, setReportingPeriodEndsDatetime] = useState(current_moment);
const [cascaderOptions, setCascaderOptions] = useState(undefined);
+ const [basePeriodDateRange, setBasePeriodDateRange] = useState([current_moment.clone().subtract(1, 'months').startOf('month').toDate(), current_moment.clone().subtract(1, 'months').toDate()]);
+ const [basePeriodDateRangePickerDisabled, setBasePeriodDateRangePickerDisabled] = useState(true);
+ const [reportingPeriodDateRange, setReportingPeriodDateRange] = useState([current_moment.clone().startOf('month').toDate(), current_moment.toDate()]);
+ const dateRangePickerLocale = {
+ sunday: t('sunday'),
+ monday: t('monday'),
+ tuesday: t('tuesday'),
+ wednesday: t('wednesday'),
+ thursday: t('thursday'),
+ friday: t('friday'),
+ saturday: t('saturday'),
+ ok: t('ok'),
+ today: t('today'),
+ yesterday: t('yesterday'),
+ hours: t('hours'),
+ minutes: t('minutes'),
+ seconds: t('seconds'),
+ last7Days: t('last7Days')
+ };
+ const dateRangePickerStyle = { display: 'block', zIndex: 10};
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(true);
const [spinnerHidden, setSpinnerHidden] = useState(true);
const [exportButtonHidden, setExportButtonHidden] = useState(true);
-
+
//Results
const [TCEShareData, setTCEShareData] = useState([]);
const [TCO2EShareData, setTCO2EShareData] = useState([]);
@@ -94,7 +110,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
const [detailedDataTableData, setDetailedDataTableData] = useState([]);
const [detailedDataTableColumns, setDetailedDataTableColumns] = useState([{dataField: 'startdatetime', text: t('Datetime'), sort: true}]);
const [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
-
+
useEffect(() => {
let isResponseOK = false;
fetch(APIBaseURL + '/spaces/tree', {
@@ -214,67 +230,61 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
console.log(target.value);
setComparisonType(target.value);
if (target.value === 'year-over-year') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'years'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'years'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'years').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'years').toDate()]);
} else if (target.value === 'month-on-month') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'months'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'months'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'months').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'months').toDate()]);
} else if (target.value === 'free-comparison') {
- setBasePeriodBeginsDatetimeDisabled(false);
- setBasePeriodEndsDatetimeDisabled(false);
+ setBasePeriodDateRangePickerDisabled(false);
} else if (target.value === 'none-comparison') {
- setBasePeriodBeginsDatetime(undefined);
- setBasePeriodEndsDatetime(undefined);
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
+ setBasePeriodDateRange([null, null]);
+ setBasePeriodDateRangePickerDisabled(true);
}
- }
+ };
- let onBasePeriodBeginsDatetimeChange = (newDateTime) => {
- setBasePeriodBeginsDatetime(newDateTime);
- }
-
- let onBasePeriodEndsDatetimeChange = (newDateTime) => {
- setBasePeriodEndsDatetime(newDateTime);
- }
-
- let onReportingPeriodBeginsDatetimeChange = (newDateTime) => {
- setReportingPeriodBeginsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onBasePeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setBasePeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setBasePeriodDateRange([DateRange[0], DateRange[1]]);
}
- }
+ };
- let onReportingPeriodEndsDatetimeChange = (newDateTime) => {
- setReportingPeriodEndsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onReportingPeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setReportingPeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setReportingPeriodDateRange([DateRange[0], DateRange[1]]);
+ if (comparisonType === 'year-over-year') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'years').toDate(), moment(DateRange[1]).clone().subtract(1, 'years').toDate()]);
+ } else if (comparisonType === 'month-on-month') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'months').toDate(), moment(DateRange[1]).clone().subtract(1, 'months').toDate()]);
+ }
}
- }
+ };
- var getValidBasePeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(basePeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onBasePeriodClean = event => {
+ setBasePeriodDateRange([null, null]);
+ };
- var getValidBasePeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(basePeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(reportingPeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(reportingPeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onReportingPeriodClean = event => {
+ setReportingPeriodDateRange([null, null]);
+ };
// Handler
const handleSubmit = e => {
@@ -282,11 +292,12 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
console.log('handleSubmit');
console.log(selectedSpaceID);
console.log(selectedStore);
+ console.log(comparisonType);
console.log(periodType);
- console.log(basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
- console.log(reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
+ console.log(basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss'))
+ console.log(moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'));
// disable submit button
setSubmitButtonDisabled(true);
@@ -294,7 +305,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -302,10 +313,10 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/storesaving?' +
'storeid=' + selectedStore +
'&periodtype=' + periodType +
- '&baseperiodstartdatetime=' + (basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&baseperiodenddatetime=' + (basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&reportingperiodstartdatetime=' + reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') +
- '&reportingperiodenddatetime=' + reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'), {
+ '&baseperiodstartdatetime=' + (basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&baseperiodenddatetime=' + (basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&reportingperiodstartdatetime=' + moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') +
+ '&reportingperiodenddatetime=' + moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'), {
method: 'GET',
headers: {
"Content-type": "application/json",
@@ -322,7 +333,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
}).then(json => {
if (isResponseOK) {
console.log(json)
-
+
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
let cardSummaryItem = {}
@@ -374,7 +385,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
timestamps['a' + index] = currentValue;
});
setStoreLineChartLabels(timestamps);
-
+
let values = {}
json['reporting_period']['values_saving'].forEach((currentValue, index) => {
values['a' + index] = currentValue;
@@ -387,7 +398,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + ')'});
});
setStoreLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -409,7 +420,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue });
});
setParameterLineChartOptions(names);
-
+
let detailed_value_list = [];
if (json['reporting_period']['timestamps'].length > 0) {
json['reporting_period']['timestamps'][0].forEach((currentTimestamp, timestampIndex) => {
@@ -437,7 +448,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
dataField: 'startdatetime',
text: t('Datetime'),
sort: true
- })
+ });
json['reporting_period']['names'].forEach((currentValue, index) => {
let unit = json['reporting_period']['units'][index];
detailed_column_list.push({
@@ -451,7 +462,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
@@ -463,7 +474,7 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false)
-
+
} else {
toast.error(json.description)
}
@@ -565,52 +576,36 @@ const StoreSaving = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Store/StoreStatistics.js b/web/src/components/MyEMS/Store/StoreStatistics.js
index a42a0b0d..6d9ef873 100644
--- a/web/src/components/MyEMS/Store/StoreStatistics.js
+++ b/web/src/components/MyEMS/Store/StoreStatistics.js
@@ -13,10 +13,9 @@ import {
Input,
Label,
CustomInput,
- Spinner,
+ Spinner
} from 'reactstrap';
import CountUp from 'react-countup';
-import Datetime from 'react-datetime';
import moment from 'moment';
import loadable from '@loadable/component';
import Cascader from 'rc-cascader';
@@ -30,7 +29,8 @@ import ButtonIcon from '../../common/ButtonIcon';
import { APIBaseURL } from '../../../config';
import { periodTypeOptions } from '../common/PeriodTypeOptions';
import { comparisonTypeOptions } from '../common/ComparisonTypeOptions';
-
+import { DateRangePicker } from 'rsuite';
+import { endOfDay} from 'date-fns';
const DetailedDataTable = loadable(() => import('../common/DetailedDataTable'));
@@ -54,6 +54,8 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -62,19 +64,33 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedStore, setSelectedStore] = useState(undefined);
const [comparisonType, setComparisonType] = useState('month-on-month');
const [periodType, setPeriodType] = useState('daily');
- const [basePeriodBeginsDatetime, setBasePeriodBeginsDatetime] = useState(current_moment.clone().subtract(1, 'months').startOf('month'));
- const [basePeriodEndsDatetime, setBasePeriodEndsDatetime] = useState(current_moment.clone().subtract(1, 'months'));
- const [basePeriodBeginsDatetimeDisabled, setBasePeriodBeginsDatetimeDisabled] = useState(true);
- const [basePeriodEndsDatetimeDisabled, setBasePeriodEndsDatetimeDisabled] = useState(true);
- const [reportingPeriodBeginsDatetime, setReportingPeriodBeginsDatetime] = useState(current_moment.clone().startOf('month'));
- const [reportingPeriodEndsDatetime, setReportingPeriodEndsDatetime] = useState(current_moment);
const [cascaderOptions, setCascaderOptions] = useState(undefined);
+ const [basePeriodDateRange, setBasePeriodDateRange] = useState([current_moment.clone().subtract(1, 'months').startOf('month').toDate(), current_moment.clone().subtract(1, 'months').toDate()]);
+ const [basePeriodDateRangePickerDisabled, setBasePeriodDateRangePickerDisabled] = useState(true);
+ const [reportingPeriodDateRange, setReportingPeriodDateRange] = useState([current_moment.clone().startOf('month').toDate(), current_moment.toDate()]);
+ const dateRangePickerLocale = {
+ sunday: t('sunday'),
+ monday: t('monday'),
+ tuesday: t('tuesday'),
+ wednesday: t('wednesday'),
+ thursday: t('thursday'),
+ friday: t('friday'),
+ saturday: t('saturday'),
+ ok: t('ok'),
+ today: t('today'),
+ yesterday: t('yesterday'),
+ hours: t('hours'),
+ minutes: t('minutes'),
+ seconds: t('seconds'),
+ last7Days: t('last7Days')
+ };
+ const dateRangePickerStyle = { display: 'block', zIndex: 10};
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(true);
const [spinnerHidden, setSpinnerHidden] = useState(true);
const [exportButtonHidden, setExportButtonHidden] = useState(true);
-
+
//Results
const [cardSummaryList, setCardSummaryList] = useState([]);
const [storeLineChartLabels, setStoreLineChartLabels] = useState([]);
@@ -88,7 +104,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
const [detailedDataTableData, setDetailedDataTableData] = useState([]);
const [detailedDataTableColumns, setDetailedDataTableColumns] = useState([{dataField: 'startdatetime', text: t('Datetime'), sort: true}]);
const [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
-
+
useEffect(() => {
let isResponseOK = false;
fetch(APIBaseURL + '/spaces/tree', {
@@ -208,67 +224,61 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
console.log(target.value);
setComparisonType(target.value);
if (target.value === 'year-over-year') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'years'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'years'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'years').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'years').toDate()]);
} else if (target.value === 'month-on-month') {
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
- setBasePeriodBeginsDatetime(moment(reportingPeriodBeginsDatetime).subtract(1, 'months'));
- setBasePeriodEndsDatetime(moment(reportingPeriodEndsDatetime).subtract(1, 'months'));
+ setBasePeriodDateRangePickerDisabled(true);
+ setBasePeriodDateRange([moment(reportingPeriodDateRange[0]).subtract(1, 'months').toDate(),
+ moment(reportingPeriodDateRange[1]).subtract(1, 'months').toDate()]);
} else if (target.value === 'free-comparison') {
- setBasePeriodBeginsDatetimeDisabled(false);
- setBasePeriodEndsDatetimeDisabled(false);
+ setBasePeriodDateRangePickerDisabled(false);
} else if (target.value === 'none-comparison') {
- setBasePeriodBeginsDatetime(undefined);
- setBasePeriodEndsDatetime(undefined);
- setBasePeriodBeginsDatetimeDisabled(true);
- setBasePeriodEndsDatetimeDisabled(true);
+ setBasePeriodDateRange([null, null]);
+ setBasePeriodDateRangePickerDisabled(true);
}
- }
+ };
- let onBasePeriodBeginsDatetimeChange = (newDateTime) => {
- setBasePeriodBeginsDatetime(newDateTime);
- }
-
- let onBasePeriodEndsDatetimeChange = (newDateTime) => {
- setBasePeriodEndsDatetime(newDateTime);
- }
-
- let onReportingPeriodBeginsDatetimeChange = (newDateTime) => {
- setReportingPeriodBeginsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodBeginsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onBasePeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setBasePeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setBasePeriodDateRange([DateRange[0], DateRange[1]]);
}
- }
+ };
- let onReportingPeriodEndsDatetimeChange = (newDateTime) => {
- setReportingPeriodEndsDatetime(newDateTime);
- if (comparisonType === 'year-over-year') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'years'));
- } else if (comparisonType === 'month-on-month') {
- setBasePeriodEndsDatetime(newDateTime.clone().subtract(1, 'months'));
+ // Callback fired when value changed
+ let onReportingPeriodChange = (DateRange) => {
+ if(DateRange == null) {
+ setReportingPeriodDateRange([null, null]);
+ } else {
+ if (moment(DateRange[1]).format('HH:mm:ss') == '00:00:00') {
+ // if the user did not change time value, set the default time to the end of day
+ DateRange[1] = endOfDay(DateRange[1]);
+ }
+ setReportingPeriodDateRange([DateRange[0], DateRange[1]]);
+ if (comparisonType === 'year-over-year') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'years').toDate(), moment(DateRange[1]).clone().subtract(1, 'years').toDate()]);
+ } else if (comparisonType === 'month-on-month') {
+ setBasePeriodDateRange([moment(DateRange[0]).clone().subtract(1, 'months').toDate(), moment(DateRange[1]).clone().subtract(1, 'months').toDate()]);
+ }
}
- }
+ };
- var getValidBasePeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(basePeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onBasePeriodClean = event => {
+ setBasePeriodDateRange([null, null]);
+ };
- var getValidBasePeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(basePeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodBeginsDatetimes = function (currentDate) {
- return currentDate.isBefore(moment(reportingPeriodEndsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
-
- var getValidReportingPeriodEndsDatetimes = function (currentDate) {
- return currentDate.isAfter(moment(reportingPeriodBeginsDatetime, 'MM/DD/YYYY, hh:mm:ss a'));
- }
+ // Callback fired when value clean
+ let onReportingPeriodClean = event => {
+ setReportingPeriodDateRange([null, null]);
+ };
// Handler
const handleSubmit = e => {
@@ -276,11 +286,12 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
console.log('handleSubmit');
console.log(selectedSpaceID);
console.log(selectedStore);
+ console.log(comparisonType);
console.log(periodType);
- console.log(basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : undefined);
- console.log(reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
- console.log(reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'));
+ console.log(basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : null)
+ console.log(moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss'))
+ console.log(moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'));
// disable submit button
setSubmitButtonDisabled(true);
@@ -296,10 +307,10 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/storestatistics?' +
'storeid=' + selectedStore +
'&periodtype=' + periodType +
- '&baseperiodstartdatetime=' + (basePeriodBeginsDatetime != null ? basePeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&baseperiodenddatetime=' + (basePeriodEndsDatetime != null ? basePeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss') : '') +
- '&reportingperiodstartdatetime=' + reportingPeriodBeginsDatetime.format('YYYY-MM-DDTHH:mm:ss') +
- '&reportingperiodenddatetime=' + reportingPeriodEndsDatetime.format('YYYY-MM-DDTHH:mm:ss'), {
+ '&baseperiodstartdatetime=' + (basePeriodDateRange[0] != null ? moment(basePeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&baseperiodenddatetime=' + (basePeriodDateRange[1] != null ? moment(basePeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss') : '') +
+ '&reportingperiodstartdatetime=' + moment(reportingPeriodDateRange[0]).format('YYYY-MM-DDTHH:mm:ss') +
+ '&reportingperiodenddatetime=' + moment(reportingPeriodDateRange[1]).format('YYYY-MM-DDTHH:mm:ss'), {
method: 'GET',
headers: {
"Content-type": "application/json",
@@ -316,7 +327,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
}).then(json => {
if (isResponseOK) {
console.log(json)
-
+
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
let cardSummaryItem = {}
@@ -349,7 +360,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
timestamps['a' + index] = currentValue;
});
setStoreLineChartLabels(timestamps);
-
+
let values = {}
json['reporting_period']['values'].forEach((currentValue, index) => {
values['a' + index] = currentValue;
@@ -362,7 +373,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + ')'});
});
setStoreLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -384,7 +395,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue });
});
setParameterLineChartOptions(names);
-
+
let detailed_value_list = [];
if (json['reporting_period']['timestamps'].length > 0) {
json['reporting_period']['timestamps'][0].forEach((currentTimestamp, timestampIndex) => {
@@ -412,7 +423,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
dataField: 'startdatetime',
text: t('Datetime'),
sort: true
- })
+ });
json['reporting_period']['names'].forEach((currentValue, index) => {
let unit = json['reporting_period']['units'][index];
detailed_column_list.push({
@@ -426,7 +437,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
@@ -438,7 +449,7 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false)
-
+
} else {
toast.error(json.description)
}
@@ -540,52 +551,36 @@ const StoreStatistics = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+