-const {app, BrowserWindow,TouchBar} = require('electron')
+const {app, BrowserWindow, TouchBar} = require('electron')
const path = require('path')
let mainWindow = null
new (TouchBar.Button)({
label: 'Hello World!',
// image: '/path/to/image',
- backgroundColor: "FF0000",
- labelColor: "0000FF",
+ backgroundColor: 'FF0000',
+ labelColor: '0000FF',
click: () => {
console.log('Hello World Clicked')
}
change: (newVal) => {
console.log('Slider was changed', newVal, typeof newVal)
}
- }),
+ })
]))
})
}
'use strict'
-const {ipcMain,TouchBar} = require('electron')
+const {ipcMain, TouchBar} = require('electron')
const {EventEmitter} = require('events')
const {BrowserWindow} = process.atomBinding('window')
const v8Util = process.atomBinding('v8_util')
})
// Proxy TouchBar events
- this.on('-touch-bar-interaction', (event, item_type, id, ...args) => {
- TouchBar._event(item_type, id, ...args)
+ this.on('-touch-bar-interaction', (event, itemType, id, ...args) => {
+ TouchBar._event(itemType, id, ...args)
})
}
// TouchBar API
BrowserWindow.prototype.setTouchBar = function (touchBar) {
if (touchBar === null || typeof touchBar === 'undefined') {
- this._destroyTouchBar();
+ this._destroyTouchBar()
} else if (Array.isArray(touchBar)) {
- this._setTouchBar((new TouchBar(touchBar)).toJSON());
+ this._setTouchBar((new TouchBar(touchBar)).toJSON())
} else {
this._setTouchBar(touchBar.toJSON())
}
-const {EventEmitter} = require('events')
-const {app} = require('electron')
-
class TouchBar {
constructor (items) {
- this.items = items;
+ this.items = items
if (!Array.isArray(items)) {
throw new Error('The items object provided has to be an array')
}
}
toJSON () {
- return this.items.map((item) => item.toJSON ? item.toJSON() : item);
+ return this.items.map((item) => item.toJSON ? item.toJSON() : item)
}
}
-let item_id_incrementor = 1
-const item_event_handlers = {}
+let itemIdIncrementor = 1
+const itemEventHandlers = {}
TouchBar._event = (itemType, eventArgs) => {
let args = eventArgs.slice(1)
if (itemType === 'slider') {
args = args.map(val => parseInt(val, 10))
}
- const id_parts = eventArgs[0].split('.')
- const item_id = id_parts[id_parts.length - 1]
- if (item_event_handlers[item_id]) item_event_handlers[item_id](...args)
+ const idParts = eventArgs[0].split('.')
+ const itemId = idParts[idParts.length - 1]
+ if (itemEventHandlers[itemId]) itemEventHandlers[itemId](...args)
}
class TouchBarItem {
constructor (config) {
- this.id = item_id_incrementor++
+ this.id = itemIdIncrementor++
const mConfig = Object.assign({}, config || {})
Object.defineProperty(this, 'config', {
configurable: false,
enumerable: false,
get: () => mConfig
})
- this.config.id = `${this.config.id || this.id}`;
+ 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')
}
this.config.type = 'button'
const click = config.click
if (typeof click === 'function') {
- item_event_handlers[`${this.id}`] = click
+ itemEventHandlers[`${this.id}`] = click
}
}
}
this.config.type = 'colorpicker'
const change = this.config.change
if (typeof change === 'function') {
- item_event_handlers[`${this.id}`] = change
+ itemEventHandlers[`${this.id}`] = change
}
}
}
}
toJSON () {
- const config = this.config;
+ const config = this.config
return Object.assign({}, config, {
items: config.items && config.items.toJSON ? config.items.toJSON() : []
})
}
toJSON () {
- const config = this.config;
+ 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)
- this.config.type = 'slider';
+ this.config.type = 'slider'
const change = this.config.change
if (typeof change === 'function') {
- item_event_handlers[this.id] = change
+ itemEventHandlers[this.id] = change
}
}
}
-module.exports = TouchBar;
+module.exports = TouchBar