1 | "use strict";
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 |
|
7 | var _react = require("react");
|
8 |
|
9 | var _reactDom = require("react-dom");
|
10 |
|
11 | var _reactDom2 = _interopRequireDefault(_reactDom);
|
12 |
|
13 | var _utils = require("./utils");
|
14 |
|
15 | var _platform = require("./platform");
|
16 |
|
17 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
18 |
|
19 | var createElement = function createElement(x) {
|
20 | return _platform.isClient ? document.createElement(x) : _utils.noop;
|
21 | };
|
22 |
|
23 | var bodyAppendElement = function bodyAppendElement(x) {
|
24 | return _platform.isClient ? document.body.appendChild(x) : _utils.noop;
|
25 | };
|
26 |
|
27 | var bodyRemoveElement = function bodyRemoveElement(x) {
|
28 | return _platform.isClient ? document.body.removeChild(x) : _utils.noop;
|
29 | };
|
30 |
|
31 | var ReactLayerMixin = function ReactLayerMixin() {
|
32 | return {
|
33 | componentWillMount: function componentWillMount() {
|
34 | this.targetBounds = null;
|
35 |
|
36 | this.layerContainerNode = createElement("div");
|
37 | },
|
38 | componentDidMount: function componentDidMount() {
|
39 |
|
40 | bodyAppendElement(this.layerContainerNode);
|
41 | this._layerRender();
|
42 | },
|
43 | componentDidUpdate: function componentDidUpdate() {
|
44 | this._layerRender();
|
45 | },
|
46 | componentWillUnmount: function componentWillUnmount() {
|
47 | this._layerUnrender();
|
48 |
|
49 | bodyRemoveElement(this.layerContainerNode);
|
50 | },
|
51 | _layerRender: function _layerRender() {
|
52 | var layerReactEl = this.renderLayer();
|
53 | if (!layerReactEl) {
|
54 | this.layerReactComponent = null;
|
55 | _reactDom2.default.unstable_renderSubtreeIntoContainer(this, _react.DOM.noscript(), this.layerContainerNode);
|
56 | } else {
|
57 | this.layerReactComponent = _reactDom2.default.unstable_renderSubtreeIntoContainer(this, layerReactEl, this.layerContainerNode);
|
58 | }
|
59 | },
|
60 | _layerUnrender: function _layerUnrender() {
|
61 | if (this.layerWillUnmount) this.layerWillUnmount(this.layerContainerNode);
|
62 | _reactDom2.default.unmountComponentAtNode(this.layerContainerNode);
|
63 | }
|
64 | };
|
65 | };
|
66 |
|
67 | exports.default = ReactLayerMixin; |
\ | No newline at end of file |