mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-11-27 12:56:01 +01:00
852277b2ae
The notification manager has been refactored to use the extension platform module instead of using `extensionizer` directly. The extension platform API presents a more ergonomic API, and it correctly handles errors (which the old notification manager did not). Methods that the extension platform lacked have been added. It has been updated to use `async/await` instead of callbacks as well, for readability. The `triggerUI` function has also been updated to use the extension platform instead of `extensionizer`.
208 lines
4.9 KiB
JavaScript
208 lines
4.9 KiB
JavaScript
import extension from 'extensionizer'
|
|
import { createExplorerLink as explorerLink } from '@metamask/etherscan-link'
|
|
import { getEnvironmentType, checkForError } from '../lib/util'
|
|
import { ENVIRONMENT_TYPE_BACKGROUND } from '../lib/enums'
|
|
|
|
class ExtensionPlatform {
|
|
|
|
//
|
|
// Public
|
|
//
|
|
reload () {
|
|
extension.runtime.reload()
|
|
}
|
|
|
|
openWindow (options) {
|
|
return new Promise((resolve, reject) => {
|
|
extension.windows.create(options, (newWindow) => {
|
|
const error = checkForError()
|
|
if (error) {
|
|
return reject(error)
|
|
}
|
|
return resolve(newWindow)
|
|
})
|
|
})
|
|
}
|
|
|
|
closeWindow (windowId) {
|
|
return new Promise((resolve, reject) => {
|
|
extension.windows.remove(windowId, () => {
|
|
const error = checkForError()
|
|
if (error) {
|
|
return reject(error)
|
|
}
|
|
return resolve()
|
|
})
|
|
})
|
|
}
|
|
|
|
focusWindow (windowId) {
|
|
return new Promise((resolve, reject) => {
|
|
extension.windows.update(windowId, { focused: true }, () => {
|
|
const error = checkForError()
|
|
if (error) {
|
|
return reject(error)
|
|
}
|
|
return resolve()
|
|
})
|
|
})
|
|
}
|
|
|
|
closeCurrentWindow () {
|
|
return extension.windows.getCurrent((windowDetails) => {
|
|
return extension.windows.remove(windowDetails.id)
|
|
})
|
|
}
|
|
|
|
getVersion () {
|
|
return extension.runtime.getManifest().version
|
|
}
|
|
|
|
openExtensionInBrowser (route = null, queryString = null) {
|
|
let extensionURL = extension.runtime.getURL('home.html')
|
|
|
|
if (queryString) {
|
|
extensionURL += `?${queryString}`
|
|
}
|
|
|
|
if (route) {
|
|
extensionURL += `#${route}`
|
|
}
|
|
this.openWindow({ url: extensionURL })
|
|
if (getEnvironmentType() !== ENVIRONMENT_TYPE_BACKGROUND) {
|
|
window.close()
|
|
}
|
|
}
|
|
|
|
getPlatformInfo (cb) {
|
|
try {
|
|
extension.runtime.getPlatformInfo((platform) => {
|
|
cb(null, platform)
|
|
})
|
|
} catch (e) {
|
|
cb(e)
|
|
}
|
|
}
|
|
|
|
showTransactionNotification (txMeta) {
|
|
const { status, txReceipt: { status: receiptStatus } = {} } = txMeta
|
|
|
|
if (status === 'confirmed') {
|
|
// There was an on-chain failure
|
|
receiptStatus === '0x0'
|
|
? this._showFailedTransaction(txMeta, 'Transaction encountered an error.')
|
|
: this._showConfirmedTransaction(txMeta)
|
|
} else if (status === 'failed') {
|
|
this._showFailedTransaction(txMeta)
|
|
}
|
|
}
|
|
|
|
getAllWindows () {
|
|
return new Promise((resolve, reject) => {
|
|
extension.windows.getAll((windows) => {
|
|
const error = checkForError()
|
|
if (error) {
|
|
return reject(error)
|
|
}
|
|
return resolve(windows)
|
|
})
|
|
})
|
|
}
|
|
|
|
getActiveTabs () {
|
|
return new Promise((resolve, reject) => {
|
|
extension.tabs.query({ active: true }, (tabs) => {
|
|
const error = checkForError()
|
|
if (error) {
|
|
return reject(error)
|
|
}
|
|
return resolve(tabs)
|
|
})
|
|
})
|
|
}
|
|
|
|
currentTab () {
|
|
return new Promise((resolve, reject) => {
|
|
extension.tabs.getCurrent((tab) => {
|
|
const err = checkForError()
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve(tab)
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
switchToTab (tabId) {
|
|
return new Promise((resolve, reject) => {
|
|
extension.tabs.update(tabId, { highlighted: true }, (tab) => {
|
|
const err = checkForError()
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve(tab)
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
closeTab (tabId) {
|
|
return new Promise((resolve, reject) => {
|
|
extension.tabs.remove(tabId, () => {
|
|
const err = checkForError()
|
|
if (err) {
|
|
reject(err)
|
|
} else {
|
|
resolve()
|
|
}
|
|
})
|
|
})
|
|
}
|
|
|
|
_showConfirmedTransaction (txMeta) {
|
|
|
|
this._subscribeToNotificationClicked()
|
|
|
|
const url = explorerLink(txMeta.hash, parseInt(txMeta.metamaskNetworkId))
|
|
const nonce = parseInt(txMeta.txParams.nonce, 16)
|
|
|
|
const title = 'Confirmed transaction'
|
|
const message = `Transaction ${nonce} confirmed! View on Etherscan`
|
|
this._showNotification(title, message, url)
|
|
}
|
|
|
|
_showFailedTransaction (txMeta, errorMessage) {
|
|
|
|
const nonce = parseInt(txMeta.txParams.nonce, 16)
|
|
const title = 'Failed transaction'
|
|
const message = `Transaction ${nonce} failed! ${errorMessage || txMeta.err.message}`
|
|
this._showNotification(title, message)
|
|
}
|
|
|
|
_showNotification (title, message, url) {
|
|
extension.notifications.create(
|
|
url,
|
|
{
|
|
'type': 'basic',
|
|
'title': title,
|
|
'iconUrl': extension.extension.getURL('../../images/icon-64.png'),
|
|
'message': message,
|
|
})
|
|
}
|
|
|
|
_subscribeToNotificationClicked () {
|
|
if (!extension.notifications.onClicked.hasListener(this._viewOnEtherscan)) {
|
|
extension.notifications.onClicked.addListener(this._viewOnEtherscan)
|
|
}
|
|
}
|
|
|
|
_viewOnEtherscan (txId) {
|
|
if (txId.startsWith('http://')) {
|
|
extension.tabs.create({ url: txId })
|
|
}
|
|
}
|
|
}
|
|
|
|
export default ExtensionPlatform
|