Autorefresh of Dashboard #3
			
				
			
		
		
		
	|  | @ -6,19 +6,12 @@ | |||
|     <link rel="stylesheet" href="{{ url_for('static', filename='Styles/switch.css') }}"> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta http-equiv="refresh" content="5" > | ||||
| 
 | ||||
| <script> | ||||
|     function executeAction(command, index, value) { | ||||
|             send_web_request('{{url_for("executeAction")}}/' + command + '/' + index + '/' + value, 'no', 'variable'); | ||||
|         } | ||||
|         function executeActionByValueID(command, index, valueID, valueFactor){ | ||||
|             var value = document.getElementById(valueID).value * valueFactor; | ||||
|             executeAction(command, index, value); | ||||
|         } | ||||
|         function switchZoneMode(autoMode, zone) { | ||||
|             executeAction('switch_zone_mode' ,zone, (autoMode ? 'automatic' : 'manual')) | ||||
|         send_web_request('{{url_for("executeAction")}}', 'no', 'command=' + command + '&index=' + index + '&value=' + value); | ||||
|     } | ||||
| </script> | ||||
|      | ||||
| </head> | ||||
| <body> | ||||
|     <header> | ||||
|  | @ -43,6 +36,7 @@ | |||
|         <img src="{{ url_for('static', filename='img/header/blumenbeet.jpg') }}" alt="" class="header-img"> | ||||
|          | ||||
|     </header> | ||||
|     <script src="{{ url_for('static', filename='js/action.js') }}"></script> | ||||
|     <script src="{{ url_for('static', filename='js/webhook.js') }}"></script> | ||||
| </body> | ||||
| </html> | ||||
|  |  | |||
|  | @ -33,13 +33,20 @@ class Webserver: | |||
|             return redirect(url_for('showDashboard')) | ||||
| 
 | ||||
|         @app.route('/action', methods=['GET', 'POST']) | ||||
|         @app.route('/action/<command>', methods=['GET', 'POST']) | ||||
|         @app.route('/action/<command>/<index_str>', methods=['GET', 'POST']) | ||||
|         @app.route('/action/<command>/<index_str>/<value_str>', methods=['GET', 'POST']) | ||||
|         def executeAction(command=False, index_str=False, value_str=False): | ||||
|             sucess = False | ||||
|             if(request.method == 'POST'): | ||||
|                 try: | ||||
|                     command = request.form['command'] | ||||
|                 except: | ||||
|                     pass | ||||
|                 try: | ||||
|                     index_str = request.form['index'] | ||||
|                     index = int(index_str) | ||||
|                 except: | ||||
|                     pass | ||||
|                 try: | ||||
|                     value_str = request.form['value'] | ||||
|                     value = int(value_str) | ||||
|                 except: | ||||
|                     pass | ||||
|  | @ -80,10 +87,13 @@ class Webserver: | |||
|                     case "delete_job_by_id": | ||||
|                         if (index): | ||||
|                             self.zoneManager.deleteIrrigationJobByID(index) | ||||
| 
 | ||||
| 
 | ||||
|                     case "get_zone_list": | ||||
|                         return self.zoneManager.zonesToJSON() | ||||
|                     case "get_pipeline": | ||||
|                         return self.zoneManager.pipelineToJSON() | ||||
|             return render_template('action.html', translater=self.translater, zones=self.zoneManager.zones, sucess=sucess) | ||||
| 
 | ||||
| 
 | ||||
|         @app.route('/dashboard') | ||||
|         def showDashboard(): | ||||
|             return render_template('dashboard.html', translater=self.translater, zoneManager=self.zoneManager) | ||||
|  |  | |||
|  | @ -0,0 +1,8 @@ | |||
| 
 | ||||
| function executeActionByValueID(command, index, valueID, valueFactor){ | ||||
|     var value = document.getElementById(valueID).value * valueFactor; | ||||
|     executeAction(command, index, value); | ||||
| } | ||||
| function switchZoneMode(autoMode, zone) { | ||||
|     executeAction('switch_zone_mode' ,zone, (autoMode ? 'automatic' : 'manual')) | ||||
| } | ||||
							
								
								
									
										14
									
								
								Zone.py
								
								
								
								
							
							
						
						
									
										14
									
								
								Zone.py
								
								
								
								
							|  | @ -1,4 +1,5 @@ | |||
| import time | ||||
| import json | ||||
| 
 | ||||
| 
 | ||||
| class Zone: | ||||
|  | @ -13,6 +14,19 @@ class Zone: | |||
|         self.endTimeSetState = endTimeSetState | ||||
|         self.planedDuration = planedDuration | ||||
| 
 | ||||
|     def toJSON(self): | ||||
|         return { | ||||
|             "number": self.number, | ||||
|             "name": self.name, | ||||
|             "actualHumidity": self.actualHumidity, | ||||
|             "desiredHumidity": self.desiredHumidity, | ||||
|             "autoMode": self.autoMode, | ||||
|             "state": self.state, | ||||
|             "setState": self.setState, | ||||
|             "endTimeSetState" : self.endTimeSetState, | ||||
|             "planedDuration": self.planedDuration, | ||||
|         } | ||||
| 
 | ||||
|     def setZoneManager(self, zoneManager): | ||||
|         self.zoneManager = zoneManager | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| import json | ||||
| import threading | ||||
| from random import Random | ||||
| from time import time | ||||
| 
 | ||||
| 
 | ||||
| from FileIO import FileIO | ||||
| 
 | ||||
|  | @ -15,6 +16,20 @@ class ZoneManager: | |||
|         self.pipeLine = [] | ||||
|         self.piplineMutexLock = threading.Lock() | ||||
| 
 | ||||
|     def zonesToJSON(self): | ||||
|         zoneList = [] | ||||
|         for zone in self.zones: | ||||
|             zoneList.append(zone.toJSON()) | ||||
|         return zoneList | ||||
| 
 | ||||
|     def pipelineToJSON(self): | ||||
|         jobList = [] | ||||
|         with self.piplineMutexLock: | ||||
|             for irrigationJob in self.pipeLine: | ||||
|                 jobList.append(irrigationJob.toJSON()) | ||||
|         return jobList | ||||
| 
 | ||||
| 
 | ||||
|     def getZone(self, number): | ||||
|         for zone in self.zones: | ||||
|             if(zone.number == number): | ||||
|  | @ -100,5 +115,12 @@ class IrrigationJob: | |||
|         self.duration = duration | ||||
|         self.zone.switchState(state=True, duration=duration, instant=False) | ||||
| 
 | ||||
|     def toJSON(self): | ||||
|         return { | ||||
|             "id": self.id, | ||||
|             "zone": self.zone.toJSON(), | ||||
|             "duration": self.duration, | ||||
|         } | ||||
| 
 | ||||
|     def process(self): | ||||
|         self.zone.switchState(state=True, duration=self.duration, instant=True) | ||||
		Loading…
	
		Reference in New Issue