Skip to content
This repository has been archived by the owner on May 24, 2021. It is now read-only.

Commit

Permalink
Merge branch 'feature/animate-loading' of https://github.com/alexande…
Browse files Browse the repository at this point in the history
…r-heimbuch/podlove-web-player into alexander-heimbuch-feature/animate-loading

* 'feature/animate-loading' of https://github.com/alexander-heimbuch/podlove-web-player:
  feat(loader): Animate opacity on boot time
  • Loading branch information
plutonik-a committed Mar 12, 2017
2 parents 111671e + e7a37f8 commit 3c2c37a
Showing 1 changed file with 66 additions and 40 deletions.
106 changes: 66 additions & 40 deletions src/embed/embed.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import get from 'lodash/get'
import isString from 'lodash/isString'
import Bluebird from 'bluebird'
import browser from 'detect-browser'

Expand All @@ -9,8 +10,8 @@ import urlConfig from 'utils/url'
import { iframeResizer } from 'iframe-resizer'
import iframeResizerContentWindow from 'raw-loader!iframe-resizer/js/iframeResizer.contentWindow.min.js'

// Sandbox
const playerSandbox = () => {
// Player renderer
const playerSandbox = anchor => {
const frame = createNode('iframe')

if (browser.name !== 'ios') {
Expand All @@ -19,17 +20,13 @@ const playerSandbox = () => {

frame.setAttribute('seamless', '')
frame.setAttribute('scrolling', 'no')
frame.style.border = '0'
frame.setAttribute('frameborder', '0')

appendNode(anchor, frame)
return frame
}

// Player renderer
const renderPlayer = (config, player) => anchor => {
const sandbox = playerSandbox(config)

appendNode(anchor, sandbox)

const injectPlayer = (sandbox, player) => new Bluebird(resolve => {
const sandboxDoc = get(sandbox, ['contentWindow', 'document'])

sandboxDoc.open()
Expand All @@ -39,42 +36,71 @@ const renderPlayer = (config, player) => anchor => {
sandboxDoc.write(player)
sandboxDoc.close()

iframeResizer({
checkOrigin: false,
log: false
}, sandbox)
}
setInterval(() => {
if (sandboxDoc.readyState !== 'complete') {
return
}

resolve(sandbox)
}, 150)
})

const preloader = sandbox => ({
init: () => {
sandbox.style.opacity = 0
sandbox.style.transition = 'all 500ms'
},
done: () => {
sandbox.style.opacity = 1
sandbox.style.height = 'auto'
}
})

// Config Handling
const createConfigNode = (config = {}) =>
tag('script', `window.PODLOVE = ${JSON.stringify(config)}`)
const renderPlayer = player => anchor => {
const sandbox = playerSandbox(anchor)
const loader = preloader(sandbox)

const remoteConfig = (config = {}) => {
if (typeof config === 'string') {
return requestConfig(config)
}
loader.init()

return Bluebird.resolve(config)
injectPlayer(sandbox, player)
.then(() => {
loader.done()
iframeResizer({
checkOrigin: false,
log: false
}, sandbox)
})
}

// Bootstrap
window.podlovePlayer = (selector, config) => {
const anchor = typeof selector === 'string' ? findNode(selector) : [selector]
// Config Node
const configNode = (config = {}) =>
Bluebird.resolve(config)
// If the config is a string, lets assume that this will point to the remote config json
.then(config => isString(config) ? requestConfig(config) : config)
// load parameters from url
.then(config => Object.assign({}, config, urlConfig))
// Finally return the node
.then(config => tag('script', `window.PODLOVE = ${JSON.stringify(config)}`))

const appLogic = tag('script', '', {type: 'text/javascript', src: './window.bundle.js'})
const dynamicResizer = tag('script', iframeResizerContentWindow)
const playerEntry = tag('PodlovePlayer')
// Player Logic
const appLogic = tag('script', '', {type: 'text/javascript', src: './window.bundle.js'})

remoteConfig(config)
// load parameters from url
.then(config => anchor.length > 1 ? config : Object.assign({}, config, urlConfig))
.then(createConfigNode)
.then(configObject => {
anchor.forEach(renderPlayer(config, [
playerEntry,
configObject,
appLogic,
dynamicResizer
].join('')))
})
// Dynamic resizer
const dynamicResizer = tag('script', iframeResizerContentWindow)

// Transclusion point
const playerEntry = tag('PodlovePlayer')

// Bootstrap
window.podlovePlayer = (selector, config) => {
const anchors = typeof selector === 'string' ? findNode(selector) : [selector]

Bluebird.all([
playerEntry,
configNode(config),
appLogic,
dynamicResizer
])
.then(result => result.join(''))
.then(result => anchors.forEach(renderPlayer(result)))
}

0 comments on commit 3c2c37a

Please sign in to comment.