« get me outta code hell

ConfirmDialog.js « dialogs « ui - tui-lib - Pure Node.js library for making visual command-line programs (ala vim, ncdu)
about summary refs log tree commit diff
path: root/ui/dialogs/ConfirmDialog.js
blob: c0bcfae6e9c5d4c31f45fbed04138553740ba903 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import {Button, Form} from 'tui-lib/ui/controls'
import {Label, Pane} from 'tui-lib/ui/presentation'
import {FocusElement} from 'tui-lib/ui/primitives'

import telc from 'tui-lib/util/telchars'

export default class ConfirmDialog extends FocusElement {
  // A basic yes/no dialog. Has two buttons, confirm/cancel, and a label.
  // The escape (esc) key can be used to exit the dialog (which sends a
  // 'cancelled' event, as the cancel button also does).

  constructor(text) {
    super()

    this.pane = new Pane()
    this.addChild(this.pane)

    this.form = new Form()
    this.pane.addChild(this.form)

    this.confirmBtn = new Button('Confirm')
    this.form.addInput(this.confirmBtn)

    this.cancelBtn = new Button('Cancel')
    this.form.addInput(this.cancelBtn)

    this.label = new Label(text)
    this.form.addChild(this.label)

    this.initEventListeners()
  }

  initEventListeners() {
    this.confirmBtn.on('pressed', () => this.confirmPressed())
    this.cancelBtn.on('pressed', () => this.cancelPressed())
  }

  fixLayout() {
    this.w = this.parent.contentW
    this.h = this.parent.contentH

    this.pane.w = Math.max(40, 2 + this.label.w)
    this.pane.h = 7
    this.pane.centerInParent()

    this.form.w = this.pane.contentW
    this.form.h = this.pane.contentH

    this.label.x = Math.floor((this.form.contentW - this.label.w) / 2)
    this.label.y = 1

    this.confirmBtn.x = 1
    this.confirmBtn.y = this.form.contentH - 2

    this.cancelBtn.x = this.form.right - this.cancelBtn.w - 1
    this.cancelBtn.y = this.form.contentH - 2
  }

  selected() {
    this.root.select(this.form)
  }

  keyPressed(keyBuf) {
    if (telc.isCancel(keyBuf)) {
      this.emit('cancelled')
    }
  }

  confirmPressed() {
    this.emit('confirmed')
  }

  cancelPressed() {
    this.emit('cancelled')
  }
}