manual override for pump
This commit is contained in:
@@ -91,6 +91,14 @@
|
|||||||
<label for="day_7">Nedjelja</label>
|
<label for="day_7">Nedjelja</label>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="form-group">
|
||||||
|
<div>
|
||||||
|
<input type="checkbox" value="true" id="manual_inflow" name="manual_inflow" class="manual_inflow_checkbox form_control" checked="{{ manualInflowChecked }}" /> Ručna kontrola pumpe
|
||||||
|
</div>
|
||||||
|
<div class="bg-danger">
|
||||||
|
PAŽNJA! Ako pumpa predugo bude radila - rezervoar se može prepuniti.
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="modal-footer">
|
<div class="modal-footer">
|
||||||
|
|||||||
@@ -25,6 +25,11 @@ Template.settings.helpers({
|
|||||||
return days.includes(day)
|
return days.includes(day)
|
||||||
},
|
},
|
||||||
|
|
||||||
|
manualInflowChecked: function(day) {
|
||||||
|
var config = controller_state().config;
|
||||||
|
return config.manualInflow;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -38,8 +43,10 @@ Template.settings.events({
|
|||||||
selectedDays.push(instance.$(this).val());
|
selectedDays.push(instance.$(this).val());
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
var manualInflow = instance.$('#manual_inflow').is(':checked');
|
||||||
|
console.log("MI ", manualInflow);
|
||||||
var controller_id = Session.get('controller_id');
|
var controller_id = Session.get('controller_id');
|
||||||
Meteor.call('saveControllerConfig', controller_id, selectedTime, selectedDays);
|
Meteor.call('saveControllerConfig', controller_id, selectedTime, selectedDays, manualInflow);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|||||||
@@ -14,6 +14,8 @@
|
|||||||
<div>
|
<div>
|
||||||
<button id="water_now" class="{{ water_now_button_class }}">Zalij sada</button>
|
<button id="water_now" class="{{ water_now_button_class }}">Zalij sada</button>
|
||||||
<button id="stop_water_now" class="{{ stop_button_class }}">Prekini zalijevanje</button>
|
<button id="stop_water_now" class="{{ stop_button_class }}">Prekini zalijevanje</button>
|
||||||
|
<button id="start_inflow_now" class="{{ start_inflow_button_class }}">Počni punjenje</button>
|
||||||
|
<button id="stop_inflow_now" class="{{ stop_inflow_button_class }}">Prekini punjenje</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@@ -90,6 +90,25 @@ Template.state.helpers({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
start_inflow_button_class: function() {
|
||||||
|
var stateObject = controller_state();
|
||||||
|
if(stateObject.config && stateObject.config.manualInflow && stateObject.state.out_valve === 'closed' && ( stateObject.state.in_valve === 'closed' || stateObject.state.in_valve === 'closing')) {
|
||||||
|
return 'btn btn-danger'
|
||||||
|
} else {
|
||||||
|
return 'hidden btn btn-danger'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
stop_inflow_button_class: function() {
|
||||||
|
var stateObject = controller_state();
|
||||||
|
if(stateObject.config && stateObject.config.manualInflow && stateObject.state.out_valve === 'closed' && ( stateObject.state.in_valve === 'open' || stateObject.state.in_valve === 'opening')) {
|
||||||
|
return 'btn btn-danger'
|
||||||
|
} else {
|
||||||
|
return 'hidden btn btn-danger'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
pretty_days: function(daysInNumbers) {
|
pretty_days: function(daysInNumbers) {
|
||||||
var days = ["Nedjelja", "Ponedjeljak", "Utorak", "Srijeda", "Četvrtak", "Petak", "Subota"];
|
var days = ["Nedjelja", "Ponedjeljak", "Utorak", "Srijeda", "Četvrtak", "Petak", "Subota"];
|
||||||
if (!daysInNumbers || daysInNumbers.length == 0) {
|
if (!daysInNumbers || daysInNumbers.length == 0) {
|
||||||
@@ -125,6 +144,16 @@ Template.state.events({
|
|||||||
Meteor.call('closeOutValve', controller_id)
|
Meteor.call('closeOutValve', controller_id)
|
||||||
},
|
},
|
||||||
|
|
||||||
|
'click #start_inflow_now': function() {
|
||||||
|
var controller_id = Session.get('controller_id');
|
||||||
|
Meteor.call('openInValve', controller_id)
|
||||||
|
},
|
||||||
|
|
||||||
|
'click #stop_inflow_now': function() {
|
||||||
|
var controller_id = Session.get('controller_id');
|
||||||
|
Meteor.call('closeInValve', controller_id)
|
||||||
|
},
|
||||||
|
|
||||||
'click #run_settings': function() {
|
'click #run_settings': function() {
|
||||||
Modal.show('settings');
|
Modal.show('settings');
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -30,10 +30,12 @@ Api.addRoute('sensorData', {
|
|||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
function reactToSensorData(nextSensorReading) {
|
reactToSensorData = function(nextSensorReading) {
|
||||||
console.log("reacting to sensor");
|
console.log("reacting to sensor");
|
||||||
var controllerId = nextSensorReading.controllerId;
|
var controllerId = nextSensorReading.controllerId;
|
||||||
var state = stateOrDefault(controllerId).state;
|
var stateObject = stateOrDefault(controllerId);
|
||||||
|
var state = stateObject.state;
|
||||||
|
var config = stateObject.config;
|
||||||
|
|
||||||
var startPumpingLevelReached;
|
var startPumpingLevelReached;
|
||||||
if (nextSensorReading.startPumpingAt == 'TANKLEVEL0') startPumpingLevelReached = (parseInt(nextSensorReading.tankLevel0) === 0)
|
if (nextSensorReading.startPumpingAt == 'TANKLEVEL0') startPumpingLevelReached = (parseInt(nextSensorReading.tankLevel0) === 0)
|
||||||
@@ -43,7 +45,15 @@ function reactToSensorData(nextSensorReading) {
|
|||||||
else if (nextSensorReading.startPumpingAt == 'TANKLEVEL4') startPumpingLevelReached = (parseInt(nextSensorReading.tankLevel4) === 0)
|
else if (nextSensorReading.startPumpingAt == 'TANKLEVEL4') startPumpingLevelReached = (parseInt(nextSensorReading.tankLevel4) === 0)
|
||||||
else startPumpingLevelReached = true;
|
else startPumpingLevelReached = true;
|
||||||
|
|
||||||
var shouldStartPumping = (!state.in_valve || state.in_valve === 'closed') && ((parseInt(nextSensorReading.tankFull) === 0) && startPumpingLevelReached && (state.out_valve === 'closed' || state.out_valve === 'closing'));
|
var shouldStartAutomaticPumping = (!state.in_valve || state.in_valve === 'closed') && ((parseInt(nextSensorReading.tankFull) === 0) && startPumpingLevelReached && (state.out_valve === 'closed' || state.out_valve === 'closing'));
|
||||||
|
|
||||||
|
console.log("State: ", state);
|
||||||
|
|
||||||
|
var shouldStartPumping = shouldStartAutomaticPumping && config && !config.manualInflow;
|
||||||
|
|
||||||
|
console.log("shouldStartAutomaticPumping: ", shouldStartAutomaticPumping);
|
||||||
|
|
||||||
|
console.log("shouldStartPumping: ", shouldStartPumping);
|
||||||
|
|
||||||
if (shouldStartPumping) {
|
if (shouldStartPumping) {
|
||||||
ControllerState.update({
|
ControllerState.update({
|
||||||
@@ -65,7 +75,12 @@ function reactToSensorData(nextSensorReading) {
|
|||||||
else if (nextSensorReading.stopPumpingAt == 'TANKLEVEL4') stopPumpingLevelReached = (parseInt(nextSensorReading.tankLevel4) === 1)
|
else if (nextSensorReading.stopPumpingAt == 'TANKLEVEL4') stopPumpingLevelReached = (parseInt(nextSensorReading.tankLevel4) === 1)
|
||||||
else stopPumpingLevelReached = false;
|
else stopPumpingLevelReached = false;
|
||||||
|
|
||||||
var shouldStopPumping = (state.in_valve === 'open' || state.in_valve === 'opening') && (parseInt(nextSensorReading.tankFull) === 1 || stopPumpingLevelReached || state.out_valve === 'open' || state.out_valve === 'opening');
|
var shouldStopAutomaticPumping = (state.in_valve === 'open' || state.in_valve === 'opening') && (parseInt(nextSensorReading.tankFull) === 1 || stopPumpingLevelReached || state.out_valve === 'open' || state.out_valve === 'opening');
|
||||||
|
|
||||||
|
var shouldStopPumping = shouldStopAutomaticPumping && config && !config.manualInflow;
|
||||||
|
|
||||||
|
console.log("shouldStopPumping: ", shouldStopPumping);
|
||||||
|
|
||||||
|
|
||||||
if (shouldStopPumping) {
|
if (shouldStopPumping) {
|
||||||
ControllerState.update({
|
ControllerState.update({
|
||||||
@@ -117,7 +132,8 @@ function stateOrDefault(id) {
|
|||||||
time: new Date(),
|
time: new Date(),
|
||||||
config: {
|
config: {
|
||||||
draining_period_amount: 40,
|
draining_period_amount: 40,
|
||||||
draining_period_unit: 'minutes'
|
draining_period_unit: 'minutes',
|
||||||
|
manualInflow: true
|
||||||
},
|
},
|
||||||
set_by: 'server'
|
set_by: 'server'
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -22,7 +22,7 @@ function setOutValveTo(controller_id, nextState) {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
if(nextState === "open") {
|
if (nextState === "open") {
|
||||||
ControllerState.update(state._id, {
|
ControllerState.update(state._id, {
|
||||||
'$set': {
|
'$set': {
|
||||||
'significantEvents.lastOutValveOpen': new Date(),
|
'significantEvents.lastOutValveOpen': new Date(),
|
||||||
@@ -32,8 +32,50 @@ function setOutValveTo(controller_id, nextState) {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function setInValveTo(controller_id, nextState) {
|
||||||
|
var state = controller_state(controller_id);
|
||||||
|
ControllerState.update(state._id, {
|
||||||
|
'$set': {
|
||||||
|
'state.in_valve': nextState,
|
||||||
|
'time': new Date(),
|
||||||
|
'set_by': 'server'
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (nextState === "open") {
|
||||||
|
ControllerState.update(state._id, {
|
||||||
|
'$set': {
|
||||||
|
'significantEvents.lastInValveOpen': new Date(),
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function openInValve(controller_id) {
|
||||||
|
var state = controller_state(controller_id);
|
||||||
|
var config = state.config;
|
||||||
|
if (config.manualInflow) {
|
||||||
|
setInValveTo(controller_id, 'opening');
|
||||||
|
}
|
||||||
|
reactToSensorData(last_sensor_reading(controller_id));
|
||||||
|
}
|
||||||
|
|
||||||
|
function closeInValve(controller_id) {
|
||||||
|
var state = controller_state(controller_id);
|
||||||
|
var config = state.config;
|
||||||
|
if (config.manualInflow) {
|
||||||
|
setInValveTo(controller_id, 'closing');
|
||||||
|
}
|
||||||
|
reactToSensorData(last_sensor_reading(controller_id));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
function openOutValve(controller_id) {
|
function openOutValve(controller_id) {
|
||||||
setOutValveTo(controller_id, 'opening');
|
setOutValveTo(controller_id, 'opening');
|
||||||
|
setInValveTo(controller_id, 'closing');
|
||||||
var state = controller_state(controller_id);
|
var state = controller_state(controller_id);
|
||||||
var config = state.config;
|
var config = state.config;
|
||||||
var jobName = "Close out valve " + state.controller_id + " after draining";
|
var jobName = "Close out valve " + state.controller_id + " after draining";
|
||||||
@@ -51,7 +93,7 @@ function openOutValve(controller_id) {
|
|||||||
});
|
});
|
||||||
console.log(Meteor.sharedFunctions);
|
console.log(Meteor.sharedFunctions);
|
||||||
|
|
||||||
Meteor.sharedFunctions.reactToSensorData(last_sensor_reading(controller_id));
|
reactToSensorData(last_sensor_reading(controller_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
function closeOutValve(controller_id) {
|
function closeOutValve(controller_id) {
|
||||||
@@ -65,7 +107,7 @@ function closeOutValve(controller_id) {
|
|||||||
|
|
||||||
console.log(Meteor.sharedFunctions);
|
console.log(Meteor.sharedFunctions);
|
||||||
|
|
||||||
Meteor.sharedFunctions.reactToSensorData(last_sensor_reading(controller_id));
|
reactToSensorData(last_sensor_reading(controller_id));
|
||||||
}
|
}
|
||||||
|
|
||||||
function clearLog() {
|
function clearLog() {
|
||||||
@@ -73,12 +115,13 @@ function clearLog() {
|
|||||||
SensorData.remove({});
|
SensorData.remove({});
|
||||||
}
|
}
|
||||||
|
|
||||||
function saveControllerConfig(controller_id, time, days) {
|
function saveControllerConfig(controller_id, time, days, manualInflow) {
|
||||||
var state = controller_state(controller_id);
|
var state = controller_state(controller_id);
|
||||||
ControllerState.update(state._id, {
|
ControllerState.update(state._id, {
|
||||||
'$set': {
|
'$set': {
|
||||||
'config.automaticTimeOfDay': time,
|
'config.automaticTimeOfDay': time,
|
||||||
'config.automaticDaysOfWeek': days
|
'config.automaticDaysOfWeek': days,
|
||||||
|
'config.manualInflow': manualInflow
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
var jobName = "automatic_" + controller_id;
|
var jobName = "automatic_" + controller_id;
|
||||||
@@ -128,6 +171,8 @@ function last_sensor_reading(controller_id) {
|
|||||||
Meteor.methods({
|
Meteor.methods({
|
||||||
openOutValve: openOutValve,
|
openOutValve: openOutValve,
|
||||||
closeOutValve: closeOutValve,
|
closeOutValve: closeOutValve,
|
||||||
|
openInValve: openInValve,
|
||||||
|
closeInValve: closeInValve,
|
||||||
clearLog: clearLog,
|
clearLog: clearLog,
|
||||||
saveControllerConfig: saveControllerConfig
|
saveControllerConfig: saveControllerConfig
|
||||||
});
|
});
|
||||||
|
|||||||
Reference in New Issue
Block a user