@@ -565,52 +575,36 @@ const ShopfloorSaving = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Shopfloor/ShopfloorStatistics.js b/web/src/components/MyEMS/Shopfloor/ShopfloorStatistics.js
index ae331d90..a7820a34 100644
--- a/web/src/components/MyEMS/Shopfloor/ShopfloorStatistics.js
+++ b/web/src/components/MyEMS/Shopfloor/ShopfloorStatistics.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 ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
createCookie('token', token, 1000 * 60 * 60 * 8);
}
});
+
+
// State
// Query Parameters
const [selectedSpaceName, setSelectedSpaceName] = useState(undefined);
@@ -62,14 +64,28 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
const [selectedShopfloor, setSelectedShopfloor] = 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 +104,7 @@ const ShopfloorStatistics = ({ 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 ShopfloorStatistics = ({ 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 ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
console.log('handleSubmit');
console.log(selectedSpaceID);
console.log(selectedShopfloor);
+ 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);
@@ -288,7 +299,7 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setDetailedDataTableData([]);
@@ -296,10 +307,10 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
fetch(APIBaseURL + '/reports/shopfloorstatistics?' +
'shopfloorid=' + selectedShopfloor +
'&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",
@@ -312,11 +323,10 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
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) => {
@@ -350,7 +360,7 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
timestamps['a' + index] = currentValue;
});
setShopfloorLineChartLabels(timestamps);
-
+
let values = {}
json['reporting_period']['values'].forEach((currentValue, index) => {
values['a' + index] = currentValue;
@@ -363,7 +373,7 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
names.push({ 'value': 'a' + index, 'label': currentValue + ' (' + unit + ')'});
});
setShopfloorLineChartOptions(names);
-
+
timestamps = {}
json['parameters']['timestamps'].forEach((currentValue, index) => {
timestamps['a' + index] = currentValue;
@@ -385,7 +395,7 @@ const ShopfloorStatistics = ({ 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) => {
@@ -413,7 +423,7 @@ const ShopfloorStatistics = ({ 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({
@@ -427,7 +437,7 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
return null;
}
}
- })
+ });
});
setDetailedDataTableColumns(detailed_column_list);
@@ -439,7 +449,7 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(true);
// show export button
setExportButtonHidden(false);
-
+
} else {
toast.error(json.description)
}
@@ -466,7 +476,6 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
};
-
return (
@@ -541,52 +550,36 @@ const ShopfloorStatistics = ({ setRedirect, setRedirectUrl, t }) => {
-
-
+
+
-
-
-
-
-
-
-
-
-
-
-
-
-
-
+
+
+
diff --git a/web/src/components/MyEMS/Store/StoreBatch.js b/web/src/components/MyEMS/Store/StoreBatch.js
index 2ab6c389..ee34caa5 100644
--- a/web/src/components/MyEMS/Store/StoreBatch.js
+++ b/web/src/components/MyEMS/Store/StoreBatch.js
@@ -77,7 +77,6 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
};
const dateRangePickerStyle = { display: 'block', zIndex: 10};
-
// buttons
const [submitButtonDisabled, setSubmitButtonDisabled] = useState(false);
const [spinnerHidden, setSpinnerHidden] = useState(true);
@@ -168,7 +167,7 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
setSpinnerHidden(false);
// hide export button
setExportButtonHidden(true)
-
+
// Reinitialize tables
setStoreList([]);
@@ -235,7 +234,6 @@ const StoreBatch = ({ setRedirect, setRedirectUrl, t }) => {
}
})
});
- console.log(detailed_column_list);
setDetailedDataTableColumns(detailed_column_list);
setExcelBytesBase64(json['excel_bytes_base64']);
diff --git a/web/src/components/MyEMS/Store/StoreEnergyCategory.js b/web/src/components/MyEMS/Store/StoreEnergyCategory.js
index c7992472..e63b0979 100644
--- a/web/src/components/MyEMS/Store/StoreEnergyCategory.js
+++ b/web/src/components/MyEMS/Store/StoreEnergyCategory.js
@@ -329,11 +329,11 @@ const StoreEnergyCategory = ({ 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) => {