Compare commits
	
		
			15 Commits
		
	
	
		
			0.1.0
			...
			reconnect-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | c8ae6e7dde | ||
|  | a236450cb5 | ||
|  | 9d9ff8824f | ||
|  | beff41780b | ||
|  | 3666aa5e8d | ||
|  | 15889e0dc7 | ||
|  | 62a6dac6e9 | ||
|  | f8688d6415 | ||
|  | d59d041b0b | ||
|  | 175f13bbde | ||
|  | 8a9a2fe401 | ||
|  | 8a2e732663 | ||
|  | e8f9badc65 | ||
|  | 4f37707acb | ||
|  | 33b2352afb | 
							
								
								
									
										14
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								README.md
									
									
									
									
									
								
							| @@ -10,8 +10,7 @@ That's the point of an EMERGENCY stop! | |||||||
|  |  | ||||||
| ## Setup | ## Setup | ||||||
|  |  | ||||||
| Install via the bundled [Plugin Manager](https://github.com/foosel/OctoPrint/wiki/Plugin:-Plugin-Manager) | Install via the bundled plugin manager, or manually using this URL: | ||||||
| or manually using this URL: |  | ||||||
|  |  | ||||||
|     https://github.com/ntoff/OctoPrint-Estop/archive/master.zip |     https://github.com/ntoff/OctoPrint-Estop/archive/master.zip | ||||||
|  |  | ||||||
| @@ -21,12 +20,11 @@ Once installed, you may wish to move the button to the top of the sidebar, you c | |||||||
|  |  | ||||||
| Find the "appearance" section, and add the plugin to the top of the sidebar order. If no other components have been previously rearranged, you may end up with only the plugin in the order list, this  is fine, you don't need to add every item to the list (not adding them  won't stop them from showing up). | Find the "appearance" section, and add the plugin to the top of the sidebar order. If no other components have been previously rearranged, you may end up with only the plugin in the order list, this  is fine, you don't need to add every item to the list (not adding them  won't stop them from showing up). | ||||||
|  |  | ||||||
| 	appearance: |     appearance: | ||||||
| 	  color: violet |       components: | ||||||
| 	  components: |         order: | ||||||
| 		order: |           sidebar: | ||||||
| 		  sidebar: |           - plugin_estop | ||||||
| 		  - plugin_estop |  | ||||||
|  |  | ||||||
| Please note: White spaces are critical inside the config.yaml file, special care must be taken when adding or removing entries that the correct layout is maintained. For more information on config.yaml and its appearance section, see here: http://docs.octoprint.org/en/master/configuration/config_yaml.html#appearance | Please note: White spaces are critical inside the config.yaml file, special care must be taken when adding or removing entries that the correct layout is maintained. For more information on config.yaml and its appearance section, see here: http://docs.octoprint.org/en/master/configuration/config_yaml.html#appearance | ||||||
|  |  | ||||||
|   | |||||||
| @@ -3,11 +3,11 @@ layout: plugin | |||||||
|  |  | ||||||
| id: estop | id: estop | ||||||
| title: Emergency STOP! button | title: Emergency STOP! button | ||||||
| description: Adds an emergency stop (gcode M112) button to the sidebar. | description: Adds an emergency stop button to the sidebar. | ||||||
| author: ntoff | author: ntoff | ||||||
| license: AGPLv3 | license: AGPLv3 | ||||||
|  |  | ||||||
| date: 2017-03-23 | date: 2017-12-02 | ||||||
|  |  | ||||||
| homepage: https://github.com/ntoff/OctoPrint-Estop | homepage: https://github.com/ntoff/OctoPrint-Estop | ||||||
| source: https://github.com/ntoff/OctoPrint-Estop | source: https://github.com/ntoff/OctoPrint-Estop | ||||||
| @@ -21,10 +21,10 @@ tags: | |||||||
|  |  | ||||||
|  |  | ||||||
| screenshots: | screenshots: | ||||||
| - /assets/img/plugins/estop/enabled.PNG | - url: /assets/img/plugins/estop/enabled.PNG | ||||||
|   alt: enabled |   alt: enabled | ||||||
|   caption: Enabled (logged in and operational) |   caption: Enabled (logged in and operational) | ||||||
| - /assets/img/plugins/estop/disabled.PNG | - url: /assets/img/plugins/estop/disabled.PNG | ||||||
|   alt: disabled |   alt: disabled | ||||||
|   caption: Disabled (logged out or non operational) |   caption: Disabled (logged out or non operational) | ||||||
|  |  | ||||||
| @@ -42,4 +42,6 @@ compatibility: | |||||||
|   - macos |   - macos | ||||||
| --- | --- | ||||||
|  |  | ||||||
| Adds a nice big emergency stop button that sends M112 to the printer in the case of an emergency. | Adds a nice big emergency stop button that (by default) sends M112 to the printer in the case of an emergency. If your printer uses a different E-Stop command, there's a settings page entry to allow changing the command sent. | ||||||
|  |  | ||||||
|  | Please do be aware that this button is no substitute for human interaction in the case of a real emergency. How your printer responds to M112 depends entirely on its firmware. | ||||||
| @@ -3,8 +3,20 @@ from __future__ import absolute_import | |||||||
|  |  | ||||||
| import octoprint.plugin | import octoprint.plugin | ||||||
|  |  | ||||||
| class EstopPlugin(octoprint.plugin.AssetPlugin, | class EstopPlugin(octoprint.plugin.StartupPlugin, | ||||||
|                      octoprint.plugin.TemplatePlugin): | 				octoprint.plugin.AssetPlugin, | ||||||
|  | 				octoprint.plugin.TemplatePlugin, | ||||||
|  | 				octoprint.plugin.SettingsPlugin): | ||||||
|  |  | ||||||
|  | 	def get_settings_defaults(self): | ||||||
|  | 		return dict( | ||||||
|  | 			estopCommand = "M112", | ||||||
|  | 			estopReconnect = False) | ||||||
|  |  | ||||||
|  | 	def on_after_startup(self): | ||||||
|  | 		self.estopCommand = self._settings.get(["estopCommand"]) | ||||||
|  | 		if (self.estopCommand != "M112"): | ||||||
|  | 			self._logger.warn("WARNING! EMERGENCY STOP COMMAND HAS BEEN CHANGED FROM DEFAULT \"M112\" TO \"" + self.estopCommand + "\"") | ||||||
|  |  | ||||||
| 	def get_assets(self): | 	def get_assets(self): | ||||||
| 		return dict( | 		return dict( | ||||||
| @@ -13,9 +25,18 @@ class EstopPlugin(octoprint.plugin.AssetPlugin, | |||||||
| 		) | 		) | ||||||
| 	def get_template_configs(self): | 	def get_template_configs(self): | ||||||
| 		return [ | 		return [ | ||||||
| 			dict(type="sidebar", name="Emergency STOP!", icon="fa icon-print", template="estop_sidebar.jinja2", styles=["display: none"], data_bind="visible: loginState.isUser") | 			dict(type="sidebar", name="Emergency STOP!", icon="close", template="estop_sidebar.jinja2", styles=["display: none"], data_bind="visible: loginState.isUser"), | ||||||
|  | 			dict(type="settings", name="E-Stop Settings", template="estop_settings.jinja2", custom_bindings=False) | ||||||
| 			] | 			] | ||||||
| 	 | 	 | ||||||
|  | 	def on_settings_save(self, data): | ||||||
|  | 		s = self._settings | ||||||
|  | 		if "estopCommand" in data.keys(): | ||||||
|  | 			s.set(["estopCommand"], data["estopCommand"]) | ||||||
|  | 		if "estopReconnect" in data.keys(): | ||||||
|  | 			s.setBoolean(["estopReconnect"], data["estopReconnect"]) | ||||||
|  | 		s.save() | ||||||
|  |  | ||||||
| 	def get_update_information(self): | 	def get_update_information(self): | ||||||
| 		return dict( | 		return dict( | ||||||
| 			estop=dict( | 			estop=dict( | ||||||
|   | |||||||
| @@ -77,3 +77,10 @@ | |||||||
| #sidebar_plugin_estop { | #sidebar_plugin_estop { | ||||||
|     display: block !important; |     display: block !important; | ||||||
| } | } | ||||||
|  | .estop-warning-icon { | ||||||
|  |     color: #eb0000; | ||||||
|  |     font-size: 2em !important; | ||||||
|  | } | ||||||
|  | .estop-warning { | ||||||
|  |     font-style: italic; | ||||||
|  | } | ||||||
| @@ -8,8 +8,13 @@ $(function() { | |||||||
|          |          | ||||||
|         self.loginState = parameters[0]; |         self.loginState = parameters[0]; | ||||||
|         self.printerState = parameters[1]; |         self.printerState = parameters[1]; | ||||||
|  |         self.settings = parameters[2]; | ||||||
|  |  | ||||||
| 		self.enableEstop = ko.pureComputed(function() { |         self.estopCommand = ko.observable("M112"); | ||||||
|  |         self.estopReconnect = ko.observable(false); | ||||||
|  |         self.emergencyCalled = ko.observable(false); | ||||||
|  |  | ||||||
|  |         self.enableEstop = ko.pureComputed(function() { | ||||||
|             return self.printerState.isOperational() && self.loginState.isUser(); |             return self.printerState.isOperational() && self.loginState.isUser(); | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
| @@ -17,27 +22,70 @@ $(function() { | |||||||
|             return self.loginState.isUser() > 0 ? "estop_sidebar" : "estop_sidebar_disabled"; |             return self.loginState.isUser() > 0 ? "estop_sidebar" : "estop_sidebar_disabled"; | ||||||
|         }); |         }); | ||||||
|          |          | ||||||
|  |         self.reconnect = ko.pureComputed(function() { | ||||||
|  |             return self.estopReconnect() && self.emergencyCalled(); | ||||||
|  |              | ||||||
|  |         }) | ||||||
|  |  | ||||||
|         self.buttonText = ko.pureComputed(function() { |         self.buttonText = ko.pureComputed(function() { | ||||||
|             if (self.enableEstop()) { |             if (self.enableEstop()) { | ||||||
|                 return gettext("EMERGENCY STOP");  |                 return gettext("EMERGENCY STOP");  | ||||||
|             } else { |             }  | ||||||
|  |             else if (self.reconnect()) { | ||||||
|  |                 return gettext("Reconnecting...") | ||||||
|  |             } | ||||||
|  |             else if (!self.enableEstop()) { | ||||||
|                 return gettext("Offline");  |                 return gettext("Offline");  | ||||||
|             } |             } | ||||||
|  |             else { | ||||||
|  |                 return gettext("Unknown Status"); | ||||||
|  |             } | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
| 		self.sendEstopCommand = function () { |         self.buttonTitle = ko.pureComputed(function() { | ||||||
| 			if (self.enableEstop()) { |             self.estopCommand(self.settings.settings.plugins.estop.estopCommand()); | ||||||
| 				OctoPrint.control.sendGcode("M112");  |             return gettext("Sends " + self.estopCommand() + " to the printer IMMEDIATELY"); | ||||||
| 			}; |         }); | ||||||
|         }; |  | ||||||
|  |         self.onBeforeBinding = function () { | ||||||
|  |             self.updateSettingsValues(); | ||||||
|  |         } | ||||||
|  |         self.onSettingsHidden = function () { | ||||||
|  |             self.updateSettingsValues(); | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         self.updateSettingsValues = function () { | ||||||
|  |             self.estopCommand(self.settings.settings.plugins.estop.estopCommand()); | ||||||
|  |             self.estopReconnect(self.settings.settings.plugins.estop.estopReconnect()); | ||||||
|  |         } | ||||||
|  |          | ||||||
|  |         self.sendEstopCommand = function () { | ||||||
|  |             if (self.enableEstop()) { | ||||||
|  |                 self.estopCommand(self.settings.settings.plugins.estop.estopCommand()); | ||||||
|  |                 OctoPrint.control.sendGcode(self.estopCommand()); | ||||||
|  |                  | ||||||
|  |                 if (self.estopReconnect()) { | ||||||
|  |                     self.emergencyCalled(true); | ||||||
|  |                     OctoPrint.connection.disconnect(); | ||||||
|  |                     self.onEventDisconnected = function () { | ||||||
|  |                         self.timedReconnect = setTimeout(function() { | ||||||
|  |                             self.emergencyCalled(false); | ||||||
|  |                             delete self.onEventDisconnected; | ||||||
|  |                             OctoPrint.connection.connect(); | ||||||
|  |                                  | ||||||
|  |                         }, 3*1000); //3 seconds | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| 	OCTOPRINT_VIEWMODELS.push({ |     OCTOPRINT_VIEWMODELS.push({ | ||||||
|         construct: EstopViewModel, |         construct: EstopViewModel, | ||||||
|         dependencies: [ |         dependencies: [ | ||||||
| 			"loginStateViewModel",  |             "loginStateViewModel",  | ||||||
| 			"printerStateViewModel", |             "printerStateViewModel", | ||||||
| 			], |             "settingsViewModel"], | ||||||
|         elements: ["#sidebar_plugin_estop_wrapper"] |         elements: ["#sidebar_plugin_estop_wrapper"] | ||||||
|     }); |     }); | ||||||
| }); | }); | ||||||
|   | |||||||
							
								
								
									
										22
									
								
								octoprint_estop/templates/estop_settings.jinja2
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								octoprint_estop/templates/estop_settings.jinja2
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | |||||||
|  | <h3>{{ _('E-Stop Settings') }}</h3> | ||||||
|  | <div> | ||||||
|  |     <p>Here you can change the command issued to your printer when you press the emergency stop button.</p> | ||||||
|  |     <form class="form-horizontal"> | ||||||
|  |         <div class="control-group"> | ||||||
|  |             <label class="control-label">{{ _('Emergency STOP! Command') }}</label> | ||||||
|  |             <div class="controls"> | ||||||
|  |                 <input type="text" class="input-block" data-bind="value: settings.plugins.estop.estopCommand"> | ||||||
|  |                 <span class="help-block">Usually this is M112. Only change if you know what you're doing.</span> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |         <div class="control-group"> | ||||||
|  |             <label class="control-label">{{ _('Cycle the connection?') }}</label> | ||||||
|  |             <div class="controls"> | ||||||
|  |                 <input type="checkbox" class="input-block" data-bind="checked: settings.plugins.estop.estopReconnect"> | ||||||
|  |                 <span class="help-block">Enabling this will attempt to automatically cycle the connection to the printer. This may cause the printer's control board to be reset and may help break out of blocking commands. Waits 3 seconds after the printer is "offline" before reconnecting.</span> | ||||||
|  |             </div> | ||||||
|  |         </div> | ||||||
|  |     </form> | ||||||
|  |     <span class="fa fa-exclamation-triangle estop-warning-icon"> </span> | ||||||
|  |     <span class="estop-warning">A software emergency stop button is no substitute for a proper emergency stop button that physically cuts the power to the printer. How the printer responds to emergency stop commands, and connection cycling, will depend entirely on the printer's controller board and firmware. Never leave a printer unattended for extended periods of time.</span> | ||||||
|  | </div> | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| <div id="sidebar_estop_background" class="estop_sidebar" data-bind="css: estopState"> | <div id="sidebar_estop_background" class="estop_sidebar" data-bind="css: estopState"> | ||||||
| 	<button type="button" id="emergemcy_stop" title="send M112 estop gcode command" class="btn-estop" data-bind="text: buttonText, enable: enableEstop, click: function() { sendEstopCommand() }"></button> | 	<button type="button" id="emergemcy_stop" class="btn-estop" data-bind="attr: { title: buttonTitle }, text: buttonText, enable: enableEstop, click: function() { sendEstopCommand() }"></button> | ||||||
| </div> | </div> | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								setup.py
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								setup.py
									
									
									
									
									
								
							| @@ -14,7 +14,7 @@ plugin_package = "octoprint_estop" | |||||||
| plugin_name = "OctoPrint-Estop" | plugin_name = "OctoPrint-Estop" | ||||||
|  |  | ||||||
| # The plugin's version. Can be overwritten within OctoPrint's internal data via __plugin_version__ in the plugin module | # The plugin's version. Can be overwritten within OctoPrint's internal data via __plugin_version__ in the plugin module | ||||||
| plugin_version = "0.1.0" | plugin_version = "0.1.2" | ||||||
|  |  | ||||||
| # The plugin's description. Can be overwritten within OctoPrint's internal data via __plugin_description__ in the plugin | # The plugin's description. Can be overwritten within OctoPrint's internal data via __plugin_description__ in the plugin | ||||||
| # module | # module | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user