const injectCss = require('inject-css') const SWcontroller = require('client-sw-ready-event/lib/sw-client.js') const SwStream = require('sw-stream/lib/sw-stream.js') const MetaMaskUiCss = require('../../ui/css') const MetamascaraPlatform = require('../../app/scripts/platforms/window') const startPopup = require('../../app/scripts/popup-core') // create platform global global.platform = new MetamascaraPlatform() var css = MetaMaskUiCss() injectCss(css) const container = document.getElementById('app-content') var name = 'popup' window.METAMASK_UI_TYPE = name let intervalDelay = Math.floor(Math.random() * (30000 - 1000)) + 1000 const background = new SWcontroller({ fileName: '/background.js', letBeIdle: false, intervalDelay, wakeUpInterval: 20000 }) // Setup listener for when the service worker is read const connectApp = function (readSw) { let connectionStream = SwStream({ serviceWorker: background.controller, context: name, }) startPopup({ container, connectionStream }, (err, store) => { if (err) return displayCriticalError(err) store.subscribe(() => { const state = store.getState() if (state.appState.shouldClose) window.close() }) }) } background.on('ready', (sw) => { background.removeListener('updatefound', connectApp) connectApp(sw) }) background.on('updatefound', windowReload) background.startWorker() .then(() => { setTimeout(() => { const container = document.getElementById(`app-content`) if (!container.children.length) windowReload() }, 2000) }) console.log('hello from MetaMascara ui!') function windowReload() { if (window.METAMASK_SKIP_RELOAD) return window.location.reload() }