electron/lib/browser/api/touch-bar.js

131 lines
3.2 KiB
JavaScript
Raw Normal View History

class TouchBar {
constructor (items) {
2016-11-29 07:55:07 +00:00
this.items = items
if (!Array.isArray(items)) {
throw new Error('The items object provided has to be an array')
}
items.forEach((item) => {
if (!item.id) {
throw new Error('Each item must be an instance of a TouchBarItem')
}
})
}
toJSON () {
2016-11-29 07:55:07 +00:00
return this.items.map((item) => item.toJSON ? item.toJSON() : item)
}
}
2016-11-29 07:55:07 +00:00
let itemIdIncrementor = 1
const itemEventHandlers = {}
TouchBar._event = (itemType, eventArgs) => {
let args = eventArgs.slice(1)
if (itemType === 'slider') {
args = args.map(val => parseInt(val, 10))
}
2016-11-29 07:55:07 +00:00
const idParts = eventArgs[0].split('.')
const itemId = idParts[idParts.length - 1]
if (itemEventHandlers[itemId]) itemEventHandlers[itemId](...args)
}
class TouchBarItem {
constructor (config) {
2016-11-29 07:55:07 +00:00
this.id = itemIdIncrementor++
const mConfig = Object.assign({}, config || {})
Object.defineProperty(this, 'config', {
configurable: false,
enumerable: false,
get: () => mConfig
})
2016-11-29 07:55:07 +00:00
this.config.id = `${this.config.id || this.id}`
if (typeof this.config !== 'object' || this.config === null) {
throw new Error('Provided config must be a non-null object')
}
}
2017-02-27 18:40:00 +00:00
updateConfig (newConfig) {
if (!this._owner) {
2017-02-27 18:40:00 +00:00
throw new Error('Cannot call methods on TouchBarItems without assigning to a BrowserWindow')
}
2017-02-27 18:40:00 +00:00
const dupConfig = Object.assign({}, newConfig)
delete dupConfig.id
Object.assign(this.config, dupConfig)
this._owner._updateTouchBarItem(this.toJSON())
}
toJSON () {
return this.config
}
}
TouchBar.Button = class TouchBarButton extends TouchBarItem {
constructor (config) {
super(config)
2016-11-28 07:24:48 +00:00
this.config.type = 'button'
const click = config.click
if (typeof click === 'function') {
2016-11-29 07:55:07 +00:00
itemEventHandlers[`${this.id}`] = click
}
}
}
TouchBar.ColorPicker = class TouchBarColorPicker extends TouchBarItem {
constructor (config) {
super(config)
2016-11-28 07:24:48 +00:00
this.config.type = 'colorpicker'
const change = this.config.change
if (typeof change === 'function') {
2016-11-29 07:55:07 +00:00
itemEventHandlers[`${this.id}`] = change
}
}
}
2016-11-29 07:36:57 +00:00
TouchBar.Group = class TouchBarGroup extends TouchBarItem {
2016-11-28 07:24:48 +00:00
constructor (config) {
super(config)
2016-11-29 07:36:57 +00:00
this.config.type = 'group'
}
toJSON () {
2016-11-29 07:55:07 +00:00
const config = this.config
2016-11-29 07:36:57 +00:00
return Object.assign({}, config, {
items: config.items && config.items.toJSON ? config.items.toJSON() : []
})
2016-11-28 07:24:48 +00:00
}
}
2016-11-29 07:36:57 +00:00
TouchBar.Label = class TouchBarLabel extends TouchBarItem {
constructor (config) {
super(config)
2016-11-29 07:36:57 +00:00
this.config.type = 'label'
}
}
TouchBar.PopOver = class TouchBarPopOver extends TouchBarItem {
constructor (config) {
super(config)
this.config.type = 'popover'
}
toJSON () {
2016-11-29 07:55:07 +00:00
const config = this.config
return Object.assign({}, config, {
touchBar: config.touchBar && config.touchBar.toJSON ? config.touchBar.toJSON() : []
})
}
}
TouchBar.Slider = class TouchBarSlider extends TouchBarItem {
constructor (config) {
super(config)
2016-11-29 07:55:07 +00:00
this.config.type = 'slider'
2016-11-28 07:24:48 +00:00
const change = this.config.change
if (typeof change === 'function') {
2016-11-29 07:55:07 +00:00
itemEventHandlers[this.id] = change
}
}
}
2016-11-29 07:55:07 +00:00
module.exports = TouchBar