diff --git a/Marlin/configurator/config/Configuration.h b/Marlin/configurator/config/Configuration.h
index 770c86eb1e..13d5545e40 100644
--- a/Marlin/configurator/config/Configuration.h
+++ b/Marlin/configurator/config/Configuration.h
@@ -51,6 +51,7 @@ Here are some standard links for getting your machine calibrated:
#define SERIAL_PORT 0
// This determines the communication speed of the printer
+// :[2400,9600,19200,38400,57600,115200,250000]
#define BAUDRATE 250000
// This enables the serial port associated to the Bluetooth interface
diff --git a/Marlin/configurator/config/_htaccess b/Marlin/configurator/config/_htaccess
new file mode 100644
index 0000000000..f289550940
--- /dev/null
+++ b/Marlin/configurator/config/_htaccess
@@ -0,0 +1 @@
+Header set Access-Control-Allow-Origin "*"
diff --git a/Marlin/configurator/css/configurator.css b/Marlin/configurator/css/configurator.css
index 6203114750..e9ef345d9e 100644
--- a/Marlin/configurator/css/configurator.css
+++ b/Marlin/configurator/css/configurator.css
@@ -1,22 +1,82 @@
/* configurator.css */
/* Styles for Marlin Configurator */
-body { margin: 0; padding: 0; background: #56A; color: #FFC; font-family: sans-serif; }
-fieldset { height: 16.1em; overflow: auto; margin-top: 10px; }
-#main { max-width: 1000px; margin: 0 auto; }
-#main { padding: 0 4%; width: 92%; }
-#main { font-family: monospace; }
-h1, #message { text-align: center; }
+.clear { clear: both; }
+
+/* Prevent selection except PRE tags */
+* {
+ -webkit-touch-callout: none;
+ -webkit-user-select: none;
+ -khtml-user-select: none;
+ -moz-user-select: none;
+ -ms-user-select: none;
+ user-select: none;
+ }
+pre {
+ -webkit-touch-callout: text;
+ -webkit-user-select: text;
+ -khtml-user-select: text;
+ -moz-user-select: text;
+ -ms-user-select: text;
+ user-select: text;
+ }
+
+body { margin: 0; padding: 0; background: #56A; color: #000; font-family: monospace; }
+#main {
+ max-width: 1000px;
+ margin: 0 auto;
+ padding: 0 4%; width: 92%;
+ }
+
+h1, h2, h3, h4, h5, h6 { clear: both; }
+
+h1, p.info { font-family: sans-serif; }
+h1 {
+ background: transparent url(logo.png) right top no-repeat;
+ height: 38px;
+ margin-bottom: -30px;
+ }
+p.info { padding: 0; color: #000; }
+p.info span { color: #800; }
+
+#message { text-align: center; }
#message { width: 80%; margin: 0 auto 0.25em; color: #FF0; }
#message p { padding: 2px 0; }
#message p.error, #message p.message { color: #F00; background: #FF4; font-weight: bold; border-radius: 0.8em; }
#message p.message { color: #080; background: #CFC; }
+#message p.message span {
+ color: #A00;
+ background: rgba(255, 255, 255, 1);
+ border: 1px solid rgba(0,0,0,0.5);
+ border-radius: 1em;
+ float: right;
+ margin-right: 0.5em;
+ padding: 0 3px;
+ font-family: sans-serif;
+ font-size: small;
+ position: relative;
+ top: -1px;
+ }
-.info { color: #AAF; }
-.info span { color: #FFF; }
-.info span span { color: #000; font-weight: bold; }
#help strong { color: #0DD; }
img { display: none; }
+
+/* Forms */
+
+#config_form {
+ display: block;
+ background: #EEE;
+ padding: 6px 20px 20px;
+ color: #000;
+ position: relative;
+ border-top-right-radius: 1.5em;
+ }
+fieldset {
+ height: 16.1em;
+ overflow-y: scroll;
+ overflow-x: hidden;
+ margin-top: 10px;
+ }
label, input, select, textarea { display: block; float: left; margin: 1px 0; }
label.newline, textarea, fieldset { clear: both; }
label {
@@ -28,31 +88,9 @@ label {
}
input[type="text"], select { margin: 0.75em 0 0; }
input[type="checkbox"], input[type="radio"], input[type="file"] { margin: 1em 0 0; }
-#config_form {
- display: block;
- background: #EEE;
- padding: 6px 20px 20px;
- color: #000;
- position: relative;
- }
-
-/*#config_text, #config_adv_text { font-family: "Andale mono", monospace; clear: both; }*/
-#config_text, #config_adv_text {
- height: 25em;
- padding: 10px;
- border: 2px solid #888;
- border-radius: 5px;
- overflow: auto;
- background-color: #FFF;
- color: #000;
- font-family: "Fira Mono";
- font-size: small;
- }
input[type="checkbox"], input[type="radio"].enabler { margin-left: 1em; }
+
input:disabled { color: #BBB; }
-.clear { clear: both; }
-h1, h2, h3, h4, h5, h6 { clear: both; }
-h2 { margin: 0; padding: 1em 0 0; }
ul.tabs { padding: 0; list-style: none; }
ul.tabs li { display: inline; }
@@ -100,6 +138,8 @@ fieldset legend { display: none; }
#serial_stepper { padding-top: 0.75em; display: block; float: left; }
#SERIAL_PORT { display: none; }
+/* Tooltips */
+
#tooltip {
display: none;
max-width: 30em;
@@ -138,18 +178,61 @@ fieldset legend { display: none; }
}
#tooltip>strong { color: #00B; }
-span.disclose {
+/* Tooltips Checkbox */
+
+#tipson { float: right; font-weight: bold; font-size: 100%; font-family: helvetica; }
+#tipson input { float: none; display: inline; }
+
+/* Config Text */
+
+pre.config {
+ height: 25em;
+ padding: 10px;
+ border: 2px solid #888;
+ border-radius: 5px;
+ overflow: auto;
+ clear: both;
+ background-color: #FFF;
+ color: #000;
+ font-family: "Fira Mono";
+ font-size: small;
+ }
+
+/* Pre Headers */
+
+h2 {
+ width: 100%;
+ margin: 12px -300px 4px 0;
+ padding: 0;
+ float: left;
+ }
+
+/* Disclosure Widget */
+
+span.disclose, a.download {︎
+ display: block;
float: right;
- margin-top: -10px;
+ margin-top: 12px;
+ }
+
+span.disclose {
+ margin-right: -10px; /* total width */
+ margin-left: 14px;
width: 0;
height: 0;
+ position: relative;
+ left: 3px;
+ top: 3px;
cursor: pointer;
border-left: 8px solid transparent;
border-right: 8px solid transparent;
border-top: 10px solid #000;
}
span.disclose.closed {
- margin: -14px 4px 0 0;
+ margin-right: -8px; /* total width */
+ margin-left: 10px;
+ left: 0;
+ top: 0;
border-top: 8px solid transparent;
border-bottom: 8px solid transparent;
border-right: 10px solid #000;
@@ -160,9 +243,26 @@ span.disclose.almost {
transform: rotate(45deg);
}
span.disclose.closed.almost {
+ left: 1px;
+ top: 3px;
-ms-transform: rotate(315deg); /* IE 9 */
-webkit-transform: rotate(315deg); /* Chrome, Safari, Opera */
transform: rotate(315deg);
}
-#tipson { float: right; font-weight: bold; font-size: 100%; font-family: helvetica; }
-#tipson input { float: none; display: inline; }
+
+/* Download Button */
+
+a.download {
+ visibility: hidden;
+ padding: 2px;
+ border: 1px solid #494;
+ border-radius: 4px;
+ margin: 12px 0 0;
+ background: #FFF;
+ color: #494;
+ font-family: sans-serif;
+ font-size: small;
+ font-weight: bold;
+ text-decoration: none;
+ }
+
diff --git a/Marlin/configurator/css/logo.png b/Marlin/configurator/css/logo.png
new file mode 100644
index 0000000000..0618dc17ae
Binary files /dev/null and b/Marlin/configurator/css/logo.png differ
diff --git a/Marlin/configurator/index.html b/Marlin/configurator/index.html
index 46f862bf1c..ffd4a36f53 100644
--- a/Marlin/configurator/index.html
+++ b/Marlin/configurator/index.html
@@ -2,7 +2,7 @@
- Marlin Configurator
+ Marlin Firmware Configurator
@@ -15,11 +15,9 @@
Marlin Configurator
+ Select presets (coming soon), modify, and download.
-
-
Enter values in the form, get a Marlin configuration.
Will include a drop-down of known configurations.
-
-
+
diff --git a/Marlin/configurator/js/configurator.js b/Marlin/configurator/js/configurator.js
index 7ebda35436..88af7d6524 100644
--- a/Marlin/configurator/js/configurator.js
+++ b/Marlin/configurator/js/configurator.js
@@ -16,7 +16,62 @@
$(function(){
-var marlin_config = 'https://api.github.com/repos/MarlinFirmware/Marlin/contents/Marlin';
+/**
+ * Github API useful GET paths. (Start with "https://api.github.com/repos/:owner/:repo/")
+ *
+ * contributors Get a list of contributors
+ * tags Get a list of tags
+ * contents/[path]?ref=branch/tag/commit Get the contents of a file
+ */
+
+ // GitHub
+ // Warning! Limited to 60 requests per hour!
+var config = {
+ type: 'github',
+ host: 'https://api.github.com',
+ owner: 'thinkyhead',
+ repo: 'Marlin',
+ ref: 'marlin_configurator',
+ path: 'Marlin/configurator/config'
+};
+/**/
+
+/* // Remote
+var config = {
+ type: 'remote',
+ host: 'http://www.thinkyhead.com',
+ path: '_marlin/config'
+};
+/**/
+
+/* // Local
+var config = {
+ type: 'local',
+ path: 'config'
+};
+/**/
+
+function github_command(conf, command, path) {
+ var req = conf.host+'/repos/'+conf.owner+'/'+conf.repo+'/'+command;
+ if (path) req += '/' + path;
+ return req;
+}
+function config_path(item) {
+ var path = '', ref = '';
+ switch(config.type) {
+ case 'github':
+ path = github_command(config, 'contents', config.path);
+ if (config.ref !== undefined) ref = '?ref=' + config.ref;
+ break;
+ case 'remote':
+ path = config.host + '/' + config.path + '/';
+ break;
+ case 'local':
+ path = config.path + '/';
+ break;
+ }
+ return path + '/' + item + ref;
+}
// Extend builtins
String.prototype.lpad = function(len, chr) {
@@ -25,6 +80,7 @@ String.prototype.lpad = function(len, chr) {
if (need > 0) { s = new Array(need+1).join(chr) + s; }
return s;
};
+
String.prototype.prePad = function(len, chr) { return len ? this.lpad(len, chr) : this; };
String.prototype.zeroPad = function(len) { return this.prePad(len, '0'); };
String.prototype.toHTML = function() { return jQuery('').text(this).html(); };
@@ -36,6 +92,19 @@ Number.prototype.limit = function(m1, m2) {
if (m2 == null) return this > m1 ? m1 : this;
return this < m1 ? m1 : this > m2 ? m2 : this;
};
+Date.prototype.fileStamp = function(filename) {
+ var fs = this.getFullYear()
+ + ((this.getMonth()+1)+'').zeroPad(2)
+ + (this.getDate()+'').zeroPad(2)
+ + (this.getHours()+'').zeroPad(2)
+ + (this.getMinutes()+'').zeroPad(2)
+ + (this.getSeconds()+'').zeroPad(2);
+
+ if (filename !== undefined)
+ return filename.replace(/^(.+)(\.\w+)$/g, '$1-['+fs+']$2');
+
+ return fs;
+}
/**
* selectField.addOptions takes an array or keyed object
@@ -49,6 +118,12 @@ $.fn.extend({
sel.append( $('