Remove CoffeeScript class wrapper

This commit is contained in:
Kevin Sawicki 2016-06-21 15:41:37 -07:00
parent 7274c69bc6
commit ca57f8a391

View file

@ -31,97 +31,94 @@ const methodInApp = {
quit: true quit: true
} }
const MenuItem = (function () { const MenuItem = function (options) {
MenuItem.types = ['normal', 'separator', 'submenu', 'checkbox', 'radio'] const {app, Menu} = require('electron')
function MenuItem (options) { const click = options.click
const {app, Menu} = require('electron') this.selector = options.selector
this.type = options.type
this.role = options.role
this.label = options.label
this.sublabel = options.sublabel
this.accelerator = options.accelerator
this.icon = options.icon
this.enabled = options.enabled
this.visible = options.visible
this.checked = options.checked
const click = options.click this.submenu = options.submenu
this.selector = options.selector if (this.submenu != null && this.submenu.constructor !== Menu) {
this.type = options.type this.submenu = Menu.buildFromTemplate(this.submenu)
this.role = options.role }
this.label = options.label if (this.type == null && this.submenu != null) {
this.sublabel = options.sublabel this.type = 'submenu'
this.accelerator = options.accelerator }
this.icon = options.icon if (this.type === 'submenu' && (this.submenu == null || this.submenu.constructor !== Menu)) {
this.enabled = options.enabled throw new Error('Invalid submenu')
this.visible = options.visible }
this.checked = options.checked
this.submenu = options.submenu this.overrideReadOnlyProperty('type', 'normal')
if ((this.submenu != null) && this.submenu.constructor !== Menu) { this.overrideReadOnlyProperty('role')
this.submenu = Menu.buildFromTemplate(this.submenu) this.overrideReadOnlyProperty('accelerator')
this.overrideReadOnlyProperty('icon')
this.overrideReadOnlyProperty('submenu')
this.overrideProperty('label', '')
this.overrideProperty('sublabel', '')
this.overrideProperty('enabled', true)
this.overrideProperty('visible', true)
this.overrideProperty('checked', false)
if (!MenuItem.types.includes(this.type)) {
throw new Error(`Unknown menu type ${this.type}`)
}
this.commandId = ++nextCommandId
this.click = (focusedWindow) => {
// Manually flip the checked flags when clicked.
if (this.type === 'checkbox' || this.type === 'radio') {
this.checked = !this.checked
} }
if ((this.type == null) && (this.submenu != null)) {
this.type = 'submenu' if (this.role && rolesMap[this.role] && process.platform !== 'darwin' && focusedWindow != null) {
} const methodName = rolesMap[this.role]
if (this.type === 'submenu' && (this.submenu != null ? this.submenu.constructor : void 0) !== Menu) { if (methodInApp[methodName]) {
throw new Error('Invalid submenu') return app[methodName]()
} } else if (typeof methodInBrowserWindow[methodName] === 'function') {
this.overrideReadOnlyProperty('type', 'normal') return methodInBrowserWindow[methodName](focusedWindow)
this.overrideReadOnlyProperty('role') } else if (methodInBrowserWindow[methodName]) {
this.overrideReadOnlyProperty('accelerator') return focusedWindow[methodName]()
this.overrideReadOnlyProperty('icon') } else {
this.overrideReadOnlyProperty('submenu') const {webContents} = focusedWindow
this.overrideProperty('label', '') return webContents != null ? webContents[methodName]() : void 0
this.overrideProperty('sublabel', '')
this.overrideProperty('enabled', true)
this.overrideProperty('visible', true)
this.overrideProperty('checked', false)
if (MenuItem.types.indexOf(this.type) === -1) {
throw new Error('Unknown menu type ' + this.type)
}
this.commandId = ++nextCommandId
this.click = (event, focusedWindow) => {
// Manually flip the checked flags when clicked.
if (this.type === 'checkbox' || this.type === 'radio') {
this.checked = !this.checked
}
if (this.role && rolesMap[this.role] && process.platform !== 'darwin' && (focusedWindow != null)) {
const methodName = rolesMap[this.role]
if (methodInApp[methodName]) {
return app[methodName]()
} else if (typeof methodInBrowserWindow[methodName] === 'function') {
return methodInBrowserWindow[methodName](focusedWindow)
} else if (methodInBrowserWindow[methodName]) {
return focusedWindow[methodName]()
} else {
const {webContents} = focusedWindow
return webContents != null ? webContents[methodName]() : void 0
}
} else if (typeof click === 'function') {
return click(this, focusedWindow, event)
} else if (typeof this.selector === 'string' && process.platform === 'darwin') {
return Menu.sendActionToFirstResponder(this.selector)
} }
} else if (typeof click === 'function') {
return click(this, focusedWindow)
} else if (typeof this.selector === 'string' && process.platform === 'darwin') {
return Menu.sendActionToFirstResponder(this.selector)
} }
} }
}
MenuItem.prototype.overrideProperty = function (name, defaultValue) { MenuItem.types = ['normal', 'separator', 'submenu', 'checkbox', 'radio']
if (defaultValue == null) {
defaultValue = null
}
this[name] != null ? this[name] : this[name] = defaultValue
return this[name] MenuItem.prototype.overrideProperty = function (name, defaultValue) {
if (defaultValue == null) {
defaultValue = null
} }
if (this[name] == null) {
MenuItem.prototype.overrideReadOnlyProperty = function (name, defaultValue) { this[name] = defaultValue
if (defaultValue == null) {
defaultValue = null
}
if (this[name] == null) {
this[name] = defaultValue
}
return Object.defineProperty(this, name, {
enumerable: true,
writable: false,
value: this[name]
})
} }
}
return MenuItem MenuItem.prototype.overrideReadOnlyProperty = function (name, defaultValue) {
})() this.overrideProperty(name, defaultValue)
Object.defineProperty(this, name, {
enumerable: true,
writable: false,
value: this[name]
})
}
module.exports = MenuItem module.exports = MenuItem