/// <reference path="../../../../../typings-module/sortablejs.d.ts" />
"use strict";
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
    if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
    return c > 3 && r && Object.defineProperty(target, key, r), r;
};
const React = require('react');
const ReactDOM = require('react-dom');
const typings = require('./gaea.type');
const mobx_react_1 = require('mobx-react');
const application_1 = require('./store/application');
const viewport_1 = require('./store/viewport');
const setting_1 = require('./store/setting');
const page_component_1 = require('./page/page.component');
let Gaea = class Gaea extends React.Component {
    constructor(...args) {
        super(...args);
        this.state = new typings.State();
        this.applicationStore = new application_1.default();
        this.viewport = new viewport_1.default(this.applicationStore);
        this.setting = new setting_1.default();
        this.handleOnSaveBind = this.handleOnSave.bind(this);
    }
    componentWillMount() {
        // 将初始化的 props 赋值到 store 上
        this.setPropsToApplication.call(this, this.props);
        // 监听
        this.addListener.call(this);
    }
    componentWillUnmount() {
        // 移除监听
        this.removeListener.call(this);
    }
    componentWillReceiveProps(nextProps) {
        // TODO 别每次都更新啊,要 shadowEqual 判断下是否相等
        // 再覆盖初始化数据
        this.setPropsToApplication.call(this, nextProps);
        // 因为初始化数据不会自动更新,所以要 forceUpdate 一下
        this.forceUpdate();
    }
    /**
     * 将 props 赋值到 store 中
     */
    setPropsToApplication(props) {
        this.applicationStore.setInitPropsToApplication({
            title: props.title,
            baseComponents: this.props.baseComponents,
            customComponents: props.customComponents,
            isHideCustomComponents: props.isHideCustomComponents,
            height: props.height,
            // 页面编辑信息
            defaultValue: props.defaultValue,
            isReactNative: props.isReactNative
        });
    }
    /**
     * 获取根节点 ref
     */
    getRootRef(ref) {
        this.viewport.setRootDomInstance(ReactDOM.findDOMNode(ref));
    }
    /**
     * 添加监听
     */
    addListener() {
        this.applicationStore.event.on(this.applicationStore.event.onSave, this.handleOnSaveBind);
    }
    /**
     * 移除监听
     */
    removeListener() {
        this.applicationStore.event.off(this.applicationStore.event.onSave, this.handleOnSaveBind);
    }
    /**
     * 触发保存
     */
    handleOnSave(context, componentsInfo) {
        this.props.onSave(componentsInfo);
    }
    render() {
        return (<mobx_react_1.Provider application={this.applicationStore} viewport={this.viewport} setting={this.setting}>
                <div ref={this.getRootRef.bind(this)}>
                    <page_component_1.default />
                </div>
            </mobx_react_1.Provider>);
    }
};
Gaea.defaultProps = new typings.Props();
Gaea = __decorate([
    mobx_react_1.observer
], Gaea);
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = Gaea;
