Added on-screen docs

This commit is contained in:
Devine Lu Linvega
2019-07-18 12:01:40 +09:00
parent ef68e52438
commit 1d9f530b47
2 changed files with 29 additions and 10 deletions

View File

@@ -5,7 +5,7 @@ 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 - 90px); resize: none; font-size: 12px;line-height: 15px; padding-right: 15px} #ronin #wrapper #commander textarea { background: none; width: 100%; height: calc(100vh - 105px); resize: none; font-size: 12px;line-height: 15px; padding-right: 15px}
#ronin #wrapper #commander div#status { position: absolute; bottom: 0px; text-transform: lowercase;} #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; }

View File

@@ -8,15 +8,15 @@ function Commander (ronin) {
this._log.id = 'log' this._log.id = 'log'
this._source = document.createElement('div') this._source = document.createElement('div')
this._source.id = 'source' this._source.id = 'source'
this._help = document.createElement('div') this._docs = document.createElement('div')
this._help.id = 'help' this._docs.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._log)
this._status.appendChild(this._source) this._status.appendChild(this._source)
this._status.appendChild(this._help) this._status.appendChild(this._docs)
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)
@@ -64,22 +64,38 @@ function Commander (ronin) {
} }
this.setStatus = function (msg) { this.setStatus = function (msg) {
if (!msg || msg === this._log.textContent) { return } // Logs
if (msg && msg !== this._log.textContent) {
this._log.textContent = `${msg}` this._log.textContent = `${msg}`
this._source.textContent = `${ronin.source} ${this._input.value.split('\n').length} lines`
console.log(msg) console.log(msg)
} }
// Source
const _source = `${ronin.source} ${this._input.value.split('\n').length} lines`
if (_source !== this._source.textContent) {
this._source.textContent = _source
}
// Docs
const _docs = this.docs.print(this.getLastfn())
if (_docs !== this._docs.textContent) {
this._docs.textContent = `${_docs}`
}
}
this.update = function () { this.update = function () {
} }
this.onInput = () => { this.onInput = () => {
console.log('input', this._input.selectionStart) this.setStatus()
} }
this.onClick = () => { this.onClick = () => {
console.log('click', this._input.selectionStart) this.setStatus()
}
this.getLastfn = function () {
const pos = this._input.value.substr(0, this._input.selectionStart).lastIndexOf('(')
return this._input.value.substr(pos).split(' ')[0].replace(/\(/g, '').replace(/\)/g, '').trim()
} }
// Mouse // Mouse
@@ -223,6 +239,9 @@ function Commander (ronin) {
}, '').trim()}` }, '').trim()}`
return `${acc}- \`(${example.trim()})\` ${this.dict[item].note}\n` return `${acc}- \`(${example.trim()})\` ${this.dict[item].note}\n`
}, '') }, '')
},
print: function (name) {
return this.dict[name] ? `(${name} ${this.dict[name].params.reduce((acc, item) => { return `${acc}${item} ` }, '').trim()})` : ''
} }
} }