2016-10-05 23:52:50 +00:00
|
|
|
import React from 'react'
|
|
|
|
import ReactDOM from 'react-dom'
|
|
|
|
import App from '../lib/app'
|
2016-10-06 07:07:41 +00:00
|
|
|
import Link from '../lib/link'
|
2016-10-06 22:40:15 +00:00
|
|
|
import Css from '../lib/css'
|
2016-10-07 01:57:31 +00:00
|
|
|
import Head from '../lib/head'
|
2016-10-05 23:52:50 +00:00
|
|
|
|
|
|
|
const modules = new Map([
|
|
|
|
['react', React],
|
|
|
|
['react-dom', ReactDOM],
|
2016-10-06 07:07:41 +00:00
|
|
|
['next/app', App],
|
2016-10-06 22:40:15 +00:00
|
|
|
['next/link', Link],
|
2016-10-07 01:57:31 +00:00
|
|
|
['next/css', Css],
|
|
|
|
['next/head', Head]
|
2016-10-05 23:52:50 +00:00
|
|
|
])
|
|
|
|
|
|
|
|
/**
|
|
|
|
* IMPORTANT: This module is compiled *without* `use strict`
|
|
|
|
* so that when we `eval` a dependency below, we don't enforce
|
|
|
|
* `use strict` implicitly.
|
|
|
|
*
|
|
|
|
* Otherwise, modules like `d3` get `eval`d and forced into
|
|
|
|
* `use strict` where they don't work (at least in current versions)
|
|
|
|
*
|
|
|
|
* To see the compilation details, look at `gulpfile.js` and the
|
|
|
|
* usage of `babel-plugin-transform-remove-strict-mode`.
|
|
|
|
*/
|
|
|
|
|
|
|
|
export default function evalScript (script) {
|
|
|
|
const module = { exports: {} }
|
|
|
|
const require = function (path) { // eslint-disable-line no-unused-vars
|
|
|
|
return modules.get(path)
|
|
|
|
}
|
|
|
|
// don't use Function() here since it changes source locations
|
|
|
|
eval(script) // eslint-disable-line no-eval
|
|
|
|
return module.exports
|
|
|
|
}
|