Begin implementing onscreen docs.
This commit is contained in:
		| @@ -5,8 +5,8 @@ body { margin:0px; padding:0px; overflow:hidden; font-family:"input_mono_regular | |||||||
| #ronin { height: calc(100vh - 60px); width:calc(100vw - 60px); -webkit-app-region: drag; padding: 30px;overflow: hidden; } | #ronin { height: calc(100vh - 60px); width:calc(100vw - 60px); -webkit-app-region: drag; padding: 30px;overflow: hidden; } | ||||||
| #ronin #wrapper { overflow: hidden; position: relative; } | #ronin #wrapper { overflow: hidden; position: relative; } | ||||||
| #ronin #wrapper #commander { z-index: 9000;position: relative;width: 310px;height: calc(100vh - 60px);-webkit-app-region: no-drag;padding-right: 30px;transition: margin-left 250ms;} | #ronin #wrapper #commander { z-index: 9000;position: relative;width: 310px;height: calc(100vh - 60px);-webkit-app-region: no-drag;padding-right: 30px;transition: margin-left 250ms;} | ||||||
| #ronin #wrapper #commander textarea { background: none; width: 100%; height: calc(100vh - 80px); resize: none; font-size: 12px;line-height: 15px; padding-right: 15px} | #ronin #wrapper #commander textarea { background: none; width: 100%; height: calc(100vh - 90px); resize: none; font-size: 12px;line-height: 15px; padding-right: 15px} | ||||||
| #ronin #wrapper #commander div#status { position: absolute; bottom: 0px; } | #ronin #wrapper #commander div#status { position: absolute; bottom: 0px; text-transform: lowercase;} | ||||||
| #ronin.hidden #wrapper #commander { margin-left:-331px; } | #ronin.hidden #wrapper #commander { margin-left:-331px; } | ||||||
|  |  | ||||||
| #ronin canvas#surface,#ronin canvas#guide { position: absolute; top:0px; -webkit-user-select: none;-webkit-app-region: no-drag; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20'><circle cx='10' cy='10' r='1' fill='%23555'></circle></svg>"); background-size: 10px 10px; background-position: -4px -4px; width:100%; height:100%; left:340px; transition: left 250ms} | #ronin canvas#surface,#ronin canvas#guide { position: absolute; top:0px; -webkit-user-select: none;-webkit-app-region: no-drag; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20'><circle cx='10' cy='10' r='1' fill='%23555'></circle></svg>"); background-size: 10px 10px; background-position: -4px -4px; width:100%; height:100%; left:340px; transition: left 250ms} | ||||||
|   | |||||||
| @@ -4,18 +4,28 @@ function Commander (ronin) { | |||||||
|   this._input = document.createElement('textarea') |   this._input = document.createElement('textarea') | ||||||
|   this._status = document.createElement('div') |   this._status = document.createElement('div') | ||||||
|   this._status.id = 'status' |   this._status.id = 'status' | ||||||
|  |   this._log = document.createElement('div') | ||||||
|  |   this._log.id = 'log' | ||||||
|  |   this._source = document.createElement('div') | ||||||
|  |   this._source.id = 'source' | ||||||
|  |   this._help = document.createElement('div') | ||||||
|  |   this._help.id = 'help' | ||||||
|   this.isVisible = true |   this.isVisible = true | ||||||
|  |  | ||||||
|   this.install = function (host) { |   this.install = function (host) { | ||||||
|     this.el.appendChild(this._input) |     this.el.appendChild(this._input) | ||||||
|  |     this._status.appendChild(this._log) | ||||||
|  |     this._status.appendChild(this._source) | ||||||
|  |     this._status.appendChild(this._help) | ||||||
|     this.el.appendChild(this._status) |     this.el.appendChild(this._status) | ||||||
|     host.appendChild(this.el) |     host.appendChild(this.el) | ||||||
|     this._input.addEventListener('input', this.onInput) |     this._input.addEventListener('input', this.onInput) | ||||||
|  |     this._input.addEventListener('click', this.onClick) | ||||||
|     this.docs.install() |     this.docs.install() | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.start = function () { |   this.start = function () { | ||||||
|     this._status.textContent = 'Idle. (zoom 100%)' |     this.setStatus('Ready.') | ||||||
|     this._input.focus() |     this._input.focus() | ||||||
|     this.run() |     this.run() | ||||||
|     this.hide() |     this.hide() | ||||||
| @@ -54,21 +64,22 @@ function Commander (ronin) { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.setStatus = function (msg) { |   this.setStatus = function (msg) { | ||||||
|     if (!msg || msg === this._status.textContent) { return } |     if (!msg || msg === this._log.textContent) { return } | ||||||
|     this._status.textContent = `${(msg + '').substr(0, 40)}` |     this._log.textContent = `${msg}` | ||||||
|     console.log(...msg) |     this._source.textContent = `${ronin.source} ${this._input.value.split('\n').length} lines` | ||||||
|  |     console.log(msg) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.update = function () { |   this.update = function () { | ||||||
|  |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.onInput = function () { |   this.onInput = () => { | ||||||
|  |     console.log('input', this._input.selectionStart) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.getQuery = function () { |   this.onClick = () => { | ||||||
|  |     console.log('click', this._input.selectionStart) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Mouse |   // Mouse | ||||||
| @@ -83,7 +94,6 @@ function Commander (ronin) { | |||||||
|     this.mouseRect.a.x = e.offsetX |     this.mouseRect.a.x = e.offsetX | ||||||
|     this.mouseRect.a.y = e.offsetY |     this.mouseRect.a.y = e.offsetY | ||||||
|     this.mouseRect.t = 'pos' |     this.mouseRect.t = 'pos' | ||||||
|     this._status.textContent = `${this.mouseRect.x},${this.mouseRect.y} ${this.mouseRect.w},${this.mouseRect.h}` |  | ||||||
|     this.capture() |     this.capture() | ||||||
|     this.show() |     this.show() | ||||||
|   } |   } | ||||||
| @@ -94,7 +104,6 @@ function Commander (ronin) { | |||||||
|       this.mouseRect.h = e.offsetY - this.mouseRect.y |       this.mouseRect.h = e.offsetY - this.mouseRect.y | ||||||
|       this.mouseRect.b.x = e.offsetX |       this.mouseRect.b.x = e.offsetX | ||||||
|       this.mouseRect.b.y = e.offsetY |       this.mouseRect.b.y = e.offsetY | ||||||
|       this._status.textContent = `${this.mouseRect.x},${this.mouseRect.y} ${this.mouseRect.w},${this.mouseRect.h}` |  | ||||||
|       this.commit() |       this.commit() | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| @@ -106,7 +115,6 @@ function Commander (ronin) { | |||||||
|     this.mouseRect.b.x = e.offsetX |     this.mouseRect.b.x = e.offsetX | ||||||
|     this.mouseRect.b.y = e.offsetY |     this.mouseRect.b.y = e.offsetY | ||||||
|     this.mouseRect.t = '' |     this.mouseRect.t = '' | ||||||
|     this._status.textContent = `${this.mouseRect.x},${this.mouseRect.y} ${this.mouseRect.w},${this.mouseRect.h}` |  | ||||||
|     this.commit() |     this.commit() | ||||||
|     this._input.focus() |     this._input.focus() | ||||||
|     ronin.surface.clearGuide() |     ronin.surface.clearGuide() | ||||||
|   | |||||||
| @@ -15,6 +15,7 @@ function Source (ronin) { | |||||||
|     console.log('Source', 'Make a new file..') |     console.log('Source', 'Make a new file..') | ||||||
|     this.path = null |     this.path = null | ||||||
|     ronin.surface.clear() |     ronin.surface.clear() | ||||||
|  |     ronin.log(`New file.`) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.open = function () { |   this.open = function () { | ||||||
| @@ -57,6 +58,7 @@ function Source (ronin) { | |||||||
|     if (quitAfter === true) { |     if (quitAfter === true) { | ||||||
|       app.exit() |       app.exit() | ||||||
|     } |     } | ||||||
|  |     ronin.log(`Writing file.`) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.read = function (loc = this.path) { |   this.read = function (loc = this.path) { | ||||||
| @@ -65,6 +67,7 @@ function Source (ronin) { | |||||||
|     console.log('Source', 'Reading ' + loc) |     console.log('Source', 'Reading ' + loc) | ||||||
|     this.path = loc |     this.path = loc | ||||||
|     this.load(fs.readFileSync(this.path, 'utf8')) |     this.load(fs.readFileSync(this.path, 'utf8')) | ||||||
|  |     ronin.log(`Reading file.`) | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.run = function () { |   this.run = function () { | ||||||
| @@ -144,7 +147,7 @@ function Source (ronin) { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   this.toString = function () { |   this.toString = function () { | ||||||
|     return this.path ? this.name() : 'unsaved' |     return this.path ? this.name() + '.lisp' : 'unsaved' | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   function isDifferent (a, b) { |   function isDifferent (a, b) { | ||||||
|   | |||||||
| @@ -1,7 +1,5 @@ | |||||||
| ; resize | ; resize | ||||||
|  |  | ||||||
| ( | ( | ||||||
|   (clear) |   (clear)  | ||||||
|   (open "../../PREVIEW.jpg") |   (open "../../PREVIEW.jpg")  | ||||||
|   (resize 0.5 0.5) |   (resize 0.5 0.5)) | ||||||
| ) |  | ||||||
| @@ -1,30 +1,38 @@ | |||||||
| ((clear) | ; theme | ||||||
|  (def col | ( | ||||||
|    (lambda |   (clear)  | ||||||
|     (i) |   (def col  | ||||||
|     (of |     (lambda  | ||||||
|      ((theme "f_high") |       (i)  | ||||||
|       (theme "f_med") |       (of  | ||||||
|       (theme "f_low") |         ( | ||||||
|       (theme "f_inv") |           (theme "f_high")  | ||||||
|       (theme "b_high") |           (theme "f_med")  | ||||||
|       (theme "b_med") |           (theme "f_low")  | ||||||
|       (theme "b_low") |           (theme "f_inv")  | ||||||
|       (theme "b_inv")) |           (theme "b_high")  | ||||||
|      (mod i 8)))) |           (theme "b_med")  | ||||||
|  (def rec |           (theme "b_low")  | ||||||
|    (lambda |           (theme "b_inv"))  | ||||||
|     (v i) |         (mod i 8))))  | ||||||
|     (if (gt v 0) |   (def rec  | ||||||
|       ((fill |     (lambda  | ||||||
|         (circle |       (v i)  | ||||||
|          (add |       (if  | ||||||
|           (div (of (frame) "w") 1.6) |         (gt v 0)  | ||||||
|           (mul 1.5 v)) |         ( | ||||||
|          (mul 10 v) |           (fill  | ||||||
|          (mul v (div v 5))) |             (circle  | ||||||
|         (col i)) |               (add  | ||||||
|        (rec |                 (div  | ||||||
|         (sub v 3) |                   (of  | ||||||
|         (add i 1)))))) |                     (frame) "w") 1.6)  | ||||||
|  (rec 40 0)) |                 (mul 1.5 v))  | ||||||
|  |               (mul 10 v)  | ||||||
|  |               (mul v  | ||||||
|  |                 (div v 5)))  | ||||||
|  |             (col i))  | ||||||
|  |           (rec  | ||||||
|  |             (sub v 3)  | ||||||
|  |             (add i 1))))))  | ||||||
|  |   (rec 40 0)) | ||||||
		Reference in New Issue
	
	Block a user