diff --git a/web/src/components/MyEMS/Space/SpaceEnergyCategory.js b/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
index dc2c1b73..b8f5f56f 100644
--- a/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
+++ b/web/src/components/MyEMS/Space/SpaceEnergyCategory.js
@@ -499,7 +499,7 @@ const SpaceEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
setChildSpacesTableColumns(child_space_column_list);
setExcelBytesBase64(json['excel_bytes_base64']);
-
+
// enable submit button
setSubmitButtonDisabled(false);
// hide spinner
diff --git a/web/src/components/MyEMS/Tenant/TenantBatch.js b/web/src/components/MyEMS/Tenant/TenantBatch.js
index 15baf7b9..b8c8c726 100644
--- a/web/src/components/MyEMS/Tenant/TenantBatch.js
+++ b/web/src/components/MyEMS/Tenant/TenantBatch.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'));
@@ -54,10 +55,26 @@ const TenantBatch = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
const [selectedSpaceID, setSelectedSpaceID] = useState(undefined);
const [tenantList, setTenantList] = 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);
const [spinnerHidden, setSpinnerHidden] = useState(true);
@@ -115,29 +132,31 @@ const TenantBatch = ({ 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);
- }
-
- 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 => {
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 +171,8 @@ const TenantBatch = ({ setRedirect, setRedirectUrl, t }) => {
let isResponseOK = false;
fetch(APIBaseURL + '/reports/tenantbatch?' +
'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",
@@ -169,7 +188,7 @@ const TenantBatch = ({ setRedirect, setRedirectUrl, t }) => {
return response.json();
}).then(json => {
if (isResponseOK) {
- console.log(json)
+ console.log(json);
let tenants = [];
if (json['tenants'].length > 0) {
json['tenants'].forEach((currentTenant, index) => {
@@ -293,26 +312,19 @@ const TenantBatch = ({ setRedirect, setRedirectUrl, t }) => {
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Tenant/TenantBill.js b/web/src/components/MyEMS/Tenant/TenantBill.js
index 6abcdb63..fe0018b3 100644
--- a/web/src/components/MyEMS/Tenant/TenantBill.js
+++ b/web/src/components/MyEMS/Tenant/TenantBill.js
@@ -3,22 +3,21 @@ import PropTypes from 'prop-types';
import {
Breadcrumb,
BreadcrumbItem,
- Button,
- ButtonGroup,
Row,
Col,
Card,
CardBody,
+ Button,
+ ButtonGroup,
Form,
FormGroup,
Input,
Label,
CustomInput,
Table,
- Spinner,
+ Spinner
} from 'reactstrap';
import createMarkup from '../../../helpers/createMarkup';
-import Datetime from 'react-datetime';
import moment from 'moment';
import Cascader from 'rc-cascader';
import { isIterableArray } from '../../../helpers/utils';
@@ -29,6 +28,8 @@ import { withTranslation } from 'react-i18next';
import { toast } from 'react-toastify';
import ButtonIcon from '../../common/ButtonIcon';
import { APIBaseURL } from '../../../config';
+import { DateRangePicker } from 'rsuite';
+import { endOfDay} from 'date-fns';
const formatCurrency = (number, currency) =>
@@ -109,9 +110,25 @@ const Invoice = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedSpaceID, setSelectedSpaceID] = useState(undefined);
const [tenantList, setTenantList] = useState([]);
const [selectedTenant, setSelectedTenant] = useState(undefined);
- const [reportingPeriodBeginsDatetime, setReportingPeriodBeginsDatetime] = useState(current_moment.clone().subtract(1, 'months').startOf('month'));
- const [reportingPeriodEndsDatetime, setReportingPeriodEndsDatetime] = useState(current_moment.clone().subtract(1, 'months').endOf('month'));
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(true);
@@ -241,30 +258,31 @@ const Invoice = ({ setRedirect, setRedirectUrl, t }) => {
}
- let onReportingPeriodBeginsDatetimeChange = (newDateTime) => {
- setReportingPeriodBeginsDatetime(newDateTime);
- }
-
- let onReportingPeriodEndsDatetimeChange = (newDateTime) => {
- setReportingPeriodEndsDatetime(newDateTime);
- }
-
- 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 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]]);
+ }
+ };
+ // Callback fired when value clean
+ let onReportingPeriodClean = event => {
+ setReportingPeriodDateRange([null, null]);
+ };
// Handler
const handleSubmit = e => {
e.preventDefault();
console.log('handleSubmit');
console.log(selectedSpaceID);
console.log(selectedTenant);
- 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);
@@ -276,8 +294,8 @@ const Invoice = ({ setRedirect, setRedirectUrl, t }) => {
let isResponseOK = false;
fetch(APIBaseURL + '/reports/tenantbill?' +
'tenantid=' + selectedTenant +
- '&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",
@@ -300,8 +318,8 @@ const Invoice = ({ setRedirect, setRedirectUrl, t }) => {
let productItem = {}
productItem['name'] = json['reporting_period']['names'][index];
productItem['unit'] = json['reporting_period']['units'][index];
- productItem['startdate'] = reportingPeriodBeginsDatetime.format('YYYY-MM-DD');
- productItem['enddate'] = reportingPeriodEndsDatetime.format('YYYY-MM-DD');
+ productItem['startdate'] = moment(reportingPeriodDateRange[0]).format('YYYY-MM-DD');
+ productItem['enddate'] = moment(reportingPeriodDateRange[1]).format('YYYY-MM-DD');
productItem['subtotalinput'] = json['reporting_period']['subtotals_input'][index];
productItem['subtotalcost'] = json['reporting_period']['subtotals_cost'][index];
productArray.push(productItem);
@@ -412,26 +430,19 @@ const Invoice = ({ setRedirect, setRedirectUrl, t }) => {
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Tenant/TenantCost.js b/web/src/components/MyEMS/Tenant/TenantCost.js
index 4ad52373..301007ae 100644
--- a/web/src/components/MyEMS/Tenant/TenantCost.js
+++ b/web/src/components/MyEMS/Tenant/TenantCost.js
@@ -13,16 +13,15 @@ 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';
import CardSummary from '../common/CardSummary';
import LineChart from '../common/LineChart';
import SharePie from '../common/SharePie';
-import loadable from '@loadable/component';
import { getCookieValue, createCookie } from '../../../helpers/utils';
import withRedirect from '../../../hoc/withRedirect';
import { withTranslation } from 'react-i18next';
@@ -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'));
@@ -63,14 +63,28 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -88,7 +102,7 @@ const TenantCost = ({ 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 [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
@@ -111,7 +125,7 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
}
return response.json();
}).then(json => {
- console.log(json)
+ console.log(json);
if (isResponseOK) {
// rename keys
json = JSON.parse(JSON.stringify([json]).split('"id":').join('"value":').split('"name":').join('"label":'));
@@ -207,72 +221,65 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
});
}
-
let onComparisonTypeChange = ({ target }) => {
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,18 +289,18 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
// show spinner
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -301,10 +308,10 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantcost?' +
'tenantid=' + selectedTenant +
'&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",
@@ -600,52 +607,36 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
@@ -708,7 +699,6 @@ const TenantCost = ({ setRedirect, setRedirectUrl, t }) => {
data={parameterLineChartData}
options={parameterLineChartOptions}>
-
diff --git a/web/src/components/MyEMS/Tenant/TenantEnergyCategory.js b/web/src/components/MyEMS/Tenant/TenantEnergyCategory.js
index 71f82414..11e05893 100644
--- a/web/src/components/MyEMS/Tenant/TenantEnergyCategory.js
+++ b/web/src/components/MyEMS/Tenant/TenantEnergyCategory.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 TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -63,14 +65,28 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -91,7 +107,7 @@ const TenantEnergyCategory = ({ 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 [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
@@ -214,67 +230,61 @@ const TenantEnergyCategory = ({ 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 => {
@@ -284,10 +294,10 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
@@ -295,7 +305,7 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -303,10 +313,10 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantenergycategory?' +
'tenantid=' + selectedTenant +
'&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,11 +328,11 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
}).then(response => {
if (response.ok) {
isResponseOK = true;
- }
+ };
return response.json();
}).then(json => {
if (isResponseOK) {
- console.log(json)
+ console.log(json);
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
@@ -424,7 +434,7 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + ')'});
});
setTenantLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -446,7 +456,7 @@ const TenantEnergyCategory = ({ 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) => {
@@ -488,7 +498,7 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
@@ -499,15 +509,14 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
// hide spinner
setSpinnerHidden(true);
// show export button
- setExportButtonHidden(false)
-
+ setExportButtonHidden(false);
+
} else {
toast.error(json.description)
}
}).catch(err => {
console.log(err);
});
-
};
const handleExport = e => {
@@ -526,8 +535,6 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
document.body.removeChild(link);
});
};
-
-
return (
@@ -603,52 +610,36 @@ const TenantEnergyCategory = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Tenant/TenantEnergyItem.js b/web/src/components/MyEMS/Tenant/TenantEnergyItem.js
index b9dd7fad..0c71f6a3 100644
--- a/web/src/components/MyEMS/Tenant/TenantEnergyItem.js
+++ b/web/src/components/MyEMS/Tenant/TenantEnergyItem.js
@@ -13,16 +13,15 @@ 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';
import CardSummary from '../common/CardSummary';
-import SharePie from '../common/SharePie';
import LineChart from '../common/LineChart';
-import loadable from '@loadable/component';
+import SharePie from '../common/SharePie';
import { getCookieValue, createCookie } from '../../../helpers/utils';
import withRedirect from '../../../hoc/withRedirect';
import { withTranslation } from 'react-i18next';
@@ -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 TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -63,14 +65,28 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -86,7 +102,7 @@ const TenantEnergyItem = ({ 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 [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
@@ -205,72 +221,65 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
});
}
-
let onComparisonTypeChange = ({ target }) => {
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 => {
@@ -280,18 +289,18 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
// show spinner
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -299,10 +308,10 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantenergyitem?' +
'tenantid=' + selectedTenant +
'&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",
@@ -408,7 +417,7 @@ const TenantEnergyItem = ({ 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) => {
@@ -462,7 +471,7 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false)
-
+
} else {
toast.error(json.description)
}
@@ -563,52 +572,36 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
@@ -665,6 +658,7 @@ const TenantEnergyItem = ({ setRedirect, setRedirectUrl, t }) => {
data={tenantLineChartData}
options={tenantLineChartOptions}>
+
{
+
);
};
diff --git a/web/src/components/MyEMS/Tenant/TenantLoad.js b/web/src/components/MyEMS/Tenant/TenantLoad.js
index a793bccc..47549246 100644
--- a/web/src/components/MyEMS/Tenant/TenantLoad.js
+++ b/web/src/components/MyEMS/Tenant/TenantLoad.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 TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -62,14 +64,28 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -203,72 +219,65 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
});
}
-
let onComparisonTypeChange = ({ target }) => {
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,18 +287,18 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
// show spinner
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -297,10 +306,10 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantload?' +
'tenantid=' + selectedTenant +
'&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",
@@ -317,7 +326,7 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
}).then(json => {
if (isResponseOK) {
console.log(json)
-
+
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
let cardSummaryItem = {}
@@ -353,7 +362,7 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + '/H)'});
});
setTenantLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -375,7 +384,7 @@ const TenantLoad = ({ 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) => {
@@ -444,7 +453,7 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false);
-
+
} else {
toast.error(json.description)
}
@@ -469,8 +478,6 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
document.body.removeChild(link);
});
};
-
-
return (
@@ -546,52 +553,36 @@ const TenantLoad = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Tenant/TenantSaving.js b/web/src/components/MyEMS/Tenant/TenantSaving.js
index e867008f..276229b1 100644
--- a/web/src/components/MyEMS/Tenant/TenantSaving.js
+++ b/web/src/components/MyEMS/Tenant/TenantSaving.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'));
@@ -56,6 +56,8 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -64,14 +66,28 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -91,7 +107,7 @@ const TenantSaving = ({ 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 [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
@@ -210,72 +226,65 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
});
}
-
let onComparisonTypeChange = ({ target }) => {
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 => {
@@ -285,11 +294,11 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
// show spinner
@@ -304,10 +313,10 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantsaving?' +
'tenantid=' + selectedTenant +
'&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",
@@ -411,7 +420,7 @@ const TenantSaving = ({ 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) => {
@@ -453,19 +462,19 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
setExcelBytesBase64(json['excel_bytes_base64']);
-
+
// enable submit button
setSubmitButtonDisabled(false);
// hide spinner
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false);
-
+
} else {
toast.error(json.description)
}
@@ -490,8 +499,6 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
document.body.removeChild(link);
});
};
-
-
return (
@@ -567,52 +574,36 @@ const TenantSaving = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Tenant/TenantStatistics.js b/web/src/components/MyEMS/Tenant/TenantStatistics.js
index 08301247..d4881da3 100644
--- a/web/src/components/MyEMS/Tenant/TenantStatistics.js
+++ b/web/src/components/MyEMS/Tenant/TenantStatistics.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,11 +29,11 @@ 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'));
-
const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
let current_moment = moment();
useEffect(() => {
@@ -55,6 +54,8 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -63,14 +64,28 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedTenant, setSelectedTenant] = 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);
@@ -85,7 +100,7 @@ const TenantStatistics = ({ 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 [excelBytesBase64, setExcelBytesBase64] = useState(undefined);
@@ -204,72 +219,65 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
});
}
-
let onComparisonTypeChange = ({ target }) => {
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 => {
@@ -279,18 +287,18 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
console.log(selectedTenant);
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);
// show spinner
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -298,10 +306,10 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/tenantstatistics?' +
'tenantid=' + selectedTenant +
'&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",
@@ -317,8 +325,8 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
return response.json();
}).then(json => {
if (isResponseOK) {
- console.log(json)
-
+ console.log(json);
+
let cardSummaryArray = []
json['reporting_period']['names'].forEach((currentValue, index) => {
let cardSummaryItem = {}
@@ -364,7 +372,7 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + ')'});
});
setTenantLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -386,7 +394,7 @@ const TenantStatistics = ({ 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) => {
@@ -428,7 +436,7 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
@@ -440,7 +448,7 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false);
-
+
} else {
toast.error(json.description)
}
@@ -465,8 +473,6 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
document.body.removeChild(link);
});
};
-
-
return (
@@ -542,52 +548,36 @@ const TenantStatistics = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+