content.ts 1.01 KiB
Newer Older
Andrei Eres's avatar
Andrei Eres committed
import { Message } from '@polkadot/extension-base/types'
Andrei Eres's avatar
Andrei Eres committed
import { PORT_CONTENT } from '@polkadot/extension-base/defaults'
Andrei Eres's avatar
Andrei Eres committed
import chrome from './utils/chrome'
Andrei Eres's avatar
Andrei Eres committed

// connect to the extension
const port = chrome.runtime.connect({ name: PORT_CONTENT })

// send any messages from the extension back to the page
port.onMessage.addListener((data): void => {
  window.postMessage({ ...data, origin: 'content' }, '*')
})

// all messages from the page, pass them to the extension
window.addEventListener('message', ({ data, source }: Message): void => {
  // only allow messages from our window, by the inject
  if (source !== window || data.origin !== 'page') {
    return
  }

  port.postMessage(data)
})

// inject our data injector
const script = document.createElement('script')

script.src = chrome.extension.getURL('page.js')

script.onload = (): void => {
  // remove the injecting tag when loaded
  if (script.parentNode) {
    script.parentNode.removeChild(script)
  }
}
;(document.head || document.documentElement).appendChild(script)