about summary refs log tree commit diff
path: root/app/javascript/mastodon/main.js
blob: 313721c88de79910d906073d899c072a08f5a4f4 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
// allow override variables here
require.context('../../assets/stylesheets/', false, /variables.*\.scss$/);

// import default stylesheet with variables
require('font-awesome/css/font-awesome.css');
require('../styles/application.scss');

function onDomContentLoaded(callback) {
  if (document.readyState !== 'loading') {
    callback();
  } else {
    document.addEventListener('DOMContentLoaded', callback);
  }
}

function main() {
  const Mastodon = require('mastodon/containers/mastodon').default;
  const React = require('react');
  const ReactDOM = require('react-dom');
  window.Perf = require('react-addons-perf');

  require.context('../images/', true);

  // import customization styles
  require.context('../../assets/stylesheets/', false, /custom.*\.scss$/);

  onDomContentLoaded(() => {
    const mountNode = document.getElementById('mastodon');
    const props = JSON.parse(mountNode.getAttribute('data-props'));

    ReactDOM.render(<Mastodon {...props} />, mountNode);
  });
}

export default main