1
0
mirror of https://github.com/kremalicious/blowfish.git synced 2025-01-01 17:43:20 +01:00

touchbar support

This commit is contained in:
Matthias Kretschmann 2019-05-13 22:54:40 +02:00
parent 9d4a38dd61
commit a5d5022688
Signed by: m
GPG Key ID: 606EEEF3C479A91F
5 changed files with 55 additions and 5 deletions

View File

@ -26,7 +26,8 @@
"react": "^16.8.6", "react": "^16.8.6",
"react-blockies": "^1.4.1", "react-blockies": "^1.4.1",
"react-dom": "^16.8.6", "react-dom": "^16.8.6",
"react-pose": "^4.0.8" "react-pose": "^4.0.8",
"react-touchbar-electron": "0.0.1"
}, },
"devDependencies": { "devDependencies": {
"@babel/core": "^7.4.4", "@babel/core": "^7.4.4",

View File

@ -3,12 +3,12 @@ import PropTypes from 'prop-types'
import { Router, Location } from '@reach/router' import { Router, Location } from '@reach/router'
import { webFrame } from 'electron' import { webFrame } from 'electron'
import posed, { PoseGroup } from 'react-pose' import posed, { PoseGroup } from 'react-pose'
import AppProvider from './store/AppProvider'
import Titlebar from './components/Titlebar' import Titlebar from './components/Titlebar'
import Home from './screens/Home' import Home from './screens/Home'
import Preferences from './screens/Preferences' import Preferences from './screens/Preferences'
import './App.css' import './App.css'
import { defaultAnimation } from './components/Animations' import { defaultAnimation } from './components/Animations'
import Touchbar from './components/Touchbar'
// //
// Disable zooming // Disable zooming
@ -37,7 +37,7 @@ PosedRouter.propTypes = {
export default class App extends PureComponent { export default class App extends PureComponent {
render() { render() {
return ( return (
<AppProvider> <>
<Titlebar /> <Titlebar />
<div className="app"> <div className="app">
<PosedRouter> <PosedRouter>
@ -45,7 +45,9 @@ export default class App extends PureComponent {
<Preferences path="/preferences" /> <Preferences path="/preferences" />
</PosedRouter> </PosedRouter>
</div> </div>
</AppProvider>
<Touchbar />
</>
) )
} }
} }

View File

@ -0,0 +1,35 @@
import React, { PureComponent } from 'react'
import { TouchBar, Button } from 'react-touchbar-electron'
import { locale } from '../util/moneyFormatter'
import { formatCurrency } from '@coingecko/cryptoformat'
import { AppContext } from '../store/createContext'
export default class Touchbar extends PureComponent {
items = (
<>
<Button
label={formatCurrency(1, 'OCEAN', locale).replace(/OCEAN/, 'Ọ')}
onClick={() => this.context.toggleCurrencies('ocean')}
/>
{Object.keys(this.context.prices).map(key => (
<Button
key={key}
label={formatCurrency(
this.context.prices[key],
key.toUpperCase(),
locale
)
.replace(/BTC/, 'Ƀ')
.replace(/ETH/, 'Ξ')}
onClick={() => this.context.toggleCurrencies(key)}
/>
))}
</>
)
render() {
return <TouchBar>{this.items}</TouchBar>
}
}
Touchbar.contextType = AppContext

View File

@ -1,5 +1,7 @@
import React from 'react' import React from 'react'
import { render } from 'react-dom' import { render } from 'react-dom'
import { TouchBarProvider } from 'react-touchbar-electron'
import AppProvider from './store/AppProvider'
import App from './App' import App from './App'
document.body.style.backgroundColor = '#141414' document.body.style.backgroundColor = '#141414'
@ -9,4 +11,11 @@ let root = document.createElement('div')
root.id = 'root' root.id = 'root'
document.body.appendChild(root) document.body.appendChild(root)
render(<App />, document.getElementById('root')) render(
<AppProvider>
<TouchBarProvider>
<App />
</TouchBarProvider>
</AppProvider>,
document.getElementById('root')
)

View File

@ -1,5 +1,6 @@
const path = require('path') const path = require('path')
const { app, BrowserWindow, systemPreferences } = require('electron') const { app, BrowserWindow, systemPreferences } = require('electron')
const { touchBarWrapper } = require('react-touchbar-electron')
let mainWindow let mainWindow
@ -106,6 +107,8 @@ const createWindow = async () => {
// Load menubar menu items // Load menubar menu items
require('./menu.js') require('./menu.js')
touchBarWrapper(mainWindow)
} }
app.on('ready', () => { app.on('ready', () => {