Demo `themes`: Finish basic functionality

pull/1/head
cpsdqs 7 years ago
parent 0da19bca30
commit 09da0690dd
Signed by untrusted user: cpsdqs
GPG Key ID: 3F59586BB7448DD1
  1. 135
      js/term/demo.js

@ -670,6 +670,27 @@ let demoshIndex = {
let get24FG = () => this.shell.terminal.defaultFG - 256 let get24FG = () => this.shell.terminal.defaultFG - 256
let set24FG = v => { this.shell.terminal.defaultFG = v + 256 } let set24FG = v => { this.shell.terminal.defaultFG = v + 256 }
let get24BG = () => this.shell.terminal.defaultBG - 256
let set24BG = v => { this.shell.terminal.defaultBG = v + 256 }
let make24Control = (label, index, getValue, setValue, type) => {
index *= 4
return {
label,
length: 1,
getValue: () => (getValue() >> index) & 0xF,
getDisplay: () => ((getValue() >> index) & 0xF).toString(16),
setValue: value => {
setValue((getValue() & (0xFFFFFF ^ (0xF << index))) | ((value & 0xF) << index))
},
shouldShow: () => this[type + 'Type'] === 1,
parseValue: input => {
return parseInt(input, 16) & 0xF
},
moveAfterInput: index !== 0
}
}
this.controls = [ this.controls = [
{ {
@ -682,7 +703,7 @@ let demoshIndex = {
} }
}, },
{ {
label: ' Default Foreground: ', label: ' Default Foreground: ',
length: 6, length: 6,
getValue: () => this.fgType, getValue: () => this.fgType,
getDisplay: () => this.fgType === 0 ? '256' : '24-bit', getDisplay: () => this.fgType === 0 ? '256' : '24-bit',
@ -693,46 +714,44 @@ let demoshIndex = {
{ {
label: ' ', label: ' ',
length: 3, length: 3,
getValue: () => this.shell.terminal.defaultFG, getValue: () => this.shell.terminal.defaultFG & 0xFF,
setValue: value => { setValue: value => {
this.shell.terminal.defaultFG = value & 0xFF this.shell.terminal.defaultFG = value & 0xFF
}, },
shouldShow: () => this.fgType === 0 shouldShow: () => this.fgType === 0,
}, parseValue: input => parseInt(input, 16)
{
label: ' ',
length: 2,
fill: '0',
getValue: () => get24FG() >> 16,
getDisplay: () => (get24FG() >> 16).toString(16),
setValue: value => set24FG(get24FG() & 0x00FFFF | ((value & 0xFF) << 16)),
shouldShow: () => this.fgType === 1
}, },
make24Control(' #', 5, get24FG, set24FG, 'fg'),
make24Control('', 4, get24FG, set24FG, 'fg'),
make24Control('', 3, get24FG, set24FG, 'fg'),
make24Control('', 2, get24FG, set24FG, 'fg'),
make24Control('', 1, get24FG, set24FG, 'fg'),
make24Control('', 0, get24FG, set24FG, 'fg'),
{ {
length: 2, label: ' Default Background: ',
fill: '0', length: 6,
getValue: () => (get24FG() >> 8) & 0xFF, getValue: () => this.bgType,
getDisplay: () => ((get24FG() >> 8) & 0xFF).toString(16), getDisplay: () => this.bgType === 0 ? '256' : '24-bit',
setValue: value => set24FG(get24FG() & 0xFF00FF | ((value & 0xFF) << 8)), setValue: value => {
shouldShow: () => this.fgType === 1 this.bgType = ((value % 2) + 2) % 2
}, }
{
length: 2,
fill: '0',
getValue: () => get24FG() & 0xFF,
getDisplay: () => (get24FG() & 0xFF).toString(16),
setValue: value => set24FG(get24FG() & 0xFFFF00 | (value & 0xFF)),
shouldShow: () => this.fgType === 1
}, },
{ {
label: ' Default Background: ', label: ' ',
length: 2, length: 3,
getValue: () => this.shell.terminal.defaultBG, getValue: () => this.shell.terminal.defaultBG & 0xFF,
getDisplay: () => this.shell.terminal.defaultBG.toString(16),
setValue: value => { setValue: value => {
this.shell.terminal.defaultBG = value & 0xFF this.shell.terminal.defaultBG = value & 0xFF
} },
} shouldShow: () => this.bgType === 0,
parseValue: input => parseInt(input, 16)
},
make24Control(' #', 5, get24BG, set24BG, 'bg'),
make24Control('', 4, get24BG, set24BG, 'bg'),
make24Control('', 3, get24BG, set24BG, 'bg'),
make24Control('', 2, get24BG, set24BG, 'bg'),
make24Control('', 1, get24BG, set24BG, 'bg'),
make24Control('', 0, get24BG, set24BG, 'bg')
] ]
this.selection = 0 this.selection = 0
@ -754,9 +773,10 @@ let demoshIndex = {
this.emit('write', `\x1b[1m${control.label}\x1b[m`) this.emit('write', `\x1b[1m${control.label}\x1b[m`)
} }
// TODO: colors // TODO: colors
this.emit('write', '\x1b[38;5;255m') this.emit('write', '\x1b[38;5;255m\x1b[48;5;16m')
let value = control.getDisplay ? control.getDisplay() : control.getValue().toString() let value = control.getDisplay ? control.getDisplay() : control.getValue().toString()
this.emit('write', ((control.fill || ' ').repeat(Math.max(0, control.length - value.length))) + value) this.emit('write', (control.fill || ' ').repeat(Math.max(0, control.length - value.length)))
this.emit('write', value.substr(0, control.length))
this.emit('write', '\x1b[m') this.emit('write', '\x1b[m')
if (index === this.selection) { if (index === this.selection) {
@ -779,26 +799,49 @@ let demoshIndex = {
this.parser.write(data) this.parser.write(data)
} }
getControlCount () {
let count = 0
for (let control of this.controls) {
if (control.shouldShow && !control.shouldShow()) continue
count++
}
return count
}
getSelectedControl () {
let selected = null
let index = 0
for (let control of this.controls) {
if (control.shouldShow && !control.shouldShow()) continue
if (index === this.selection) {
selected = control
break
}
index++
}
return selected
}
handler (action, ...args) { handler (action, ...args) {
console.log(action, ...args) console.log(action, ...args)
if (action === 'move-cursor-x') { if (action === 'move-cursor-x') {
this.selection += args[0] this.selection += args[0]
let count = this.controls.length let count = this.getControlCount()
this.selection = ((this.selection % count) + count) % count this.selection = ((this.selection % count) + count) % count
} else if (action === 'move-cursor-y') { } else if (action === 'move-cursor-y') {
let selected = null let control = this.getSelectedControl()
let index = 0 if (control) control.setValue(control.getValue() - args[0])
for (let control of this.controls) { } else if (action === 'write') {
if (control.shouldShow && !control.shouldShow()) continue let control = this.getSelectedControl()
if (index === this.selection) { if (control && control.parseValue) {
selected = control let parsed = control.parseValue(args[0])
break if (Number.isFinite(parsed)) {
control.setValue(parsed)
if (control.moveAfterInput) {
if (this.selection < this.getControlCount() - 1) this.selection++
}
} }
index++
}
if (selected) {
selected.setValue(selected.getValue() - args[0])
} }
} }

Loading…
Cancel
Save