"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 typings = require('./remote-button.type');
const mobx_react_1 = require('mobx-react');
const _ = require('lodash');
const src_1 = require('../../../../../../../button/src');
const src_2 = require('../../../../../../../modal/src');
const src_3 = require('../../../../../../../../common/auto-bind/src');
let RemoveButton = class RemoveButton extends React.Component {
    constructor(...args) {
        super(...args);
        this.state = new typings.State();
    }
    handleShowModalOrClick() {
        if (this.props.setting.confirmWhenRemoveComponent) {
            this.setState({
                show: true
            });
        }
        else {
            this.handleOk();
        }
    }
    handleOk() {
        // 取消选中会清空最后选择的 key, 所以先保存一下
        const currentEditComponentMapUniqueKey = this.props.viewport.currentEditComponentMapUniqueKey;
        // 找到父级 mapUniqueKey, 记录历史操作使用
        const parentMapUniqueKey = this.props.viewport.components.get(currentEditComponentMapUniqueKey).parentMapUniqueKey;
        // 存储组件信息
        const componentInfo = _.cloneDeep(JSON.parse(JSON.stringify(this.props.viewport.components.get(currentEditComponentMapUniqueKey))));
        // 找到是父级的第几个
        const index = this.props.viewport.components.get(parentMapUniqueKey).layoutChilds.findIndex(item => item === currentEditComponentMapUniqueKey);
        // 取消编辑状态
        this.props.viewport.cancelEditComponent();
        // 删除
        const deleteChildsComponents = this.props.viewport.deleteComponent(currentEditComponentMapUniqueKey);
        this.props.viewport.saveOperate({
            type: 'remove',
            mapUniqueKey: currentEditComponentMapUniqueKey,
            remove: {
                mapUniqueKey: currentEditComponentMapUniqueKey,
                parentMapUniqueKey: parentMapUniqueKey,
                // 删除的位置
                index: index,
                // 组件信息
                componentInfo: componentInfo,
                // 子元素列表 （包括非直接子集）
                childs: deleteChildsComponents
            }
        });
    }
    handleCancel() {
        this.setState({
            show: false
        });
    }
    render() {
        return (<src_1.default type="secondary" onClick={this.handleShowModalOrClick}>
                移除
                <src_2.default show={this.state.show} onOk={this.handleOk} onCancel={this.handleCancel}>
                    <p>是否要移除此组件?</p>
                </src_2.default>
            </src_1.default>);
    }
};
RemoveButton.defaultProps = new typings.Props();
__decorate([
    src_3.autoBindMethod
], RemoveButton.prototype, "handleShowModalOrClick", null);
__decorate([
    src_3.autoBindMethod
], RemoveButton.prototype, "handleOk", null);
__decorate([
    src_3.autoBindMethod
], RemoveButton.prototype, "handleCancel", null);
RemoveButton = __decorate([
    mobx_react_1.inject('viewport', 'setting'),
    mobx_react_1.observer
], RemoveButton);
Object.defineProperty(exports, "__esModule", { value: true });
exports.default = RemoveButton;
