DrawerContainer.js 2.84 KB
'use strict';

import React from 'react';
import ReactNative from 'react-native';
import Drawer from 'react-native-drawer';
import SideMenu from '../components/SideMenu';
import {DefaultRenderer} from 'react-native-router-flux';

import  * as homeActions from '../reducers/home/homeActions';
import * as messageActions from '../reducers/message/messageActions';

import {bindActionCreators} from 'redux';
import {connect} from 'react-redux';
import {Map} from 'immutable';
import {Actions} from 'react-native-router-flux';

const {
    Component,
} = React;

const {
    StyleSheet,
} = ReactNative;

const actions = [
    homeActions,
    messageActions,
];

import Immutable, {Record, List} from 'immutable';

function mapStateToProps(state) {
    return {
        ...state
    }
}

function mapDispatchToProps(dispatch) {

    const creators = Map()
            .merge(...actions)
            .filter(value => typeof value === 'function')
            .toObject();

    return {
        actions: bindActionCreators(creators, dispatch),
        dispatch
    };
}


class DrawerContainer extends Component {

    constructor(props) {
        super(props);

        this._onPressItem = this._onPressItem.bind(this);
    }

    _onPressItem(brand) {
        //选择店铺
        this.drawer.close();
        this.props.actions.setupDefaultShop(brand.get('shopsId'), brand.get('shopName'));
        this.props.actions.overview(brand.get('shopsId'));
        this.props.actions.brandRank(brand.get('shopsId'));
        this.props.actions.requestUnreadMsgNum(brand.get('shopsId'), 'N');
        this.props.actions.getMsgList(brand.get('shopsId'));
    }

    render() {

        const children = this.props.navigationState.children;
        let disabled = children[0].index === 0 ? false : true;  //只在第一个tab页启用抽屉菜单

        return (
            <Drawer
                ref={(ref) => this.drawer = ref}
                type="displace"
                content={<SideMenu items={this.props.user.brands} onPressItem={this._onPressItem}/>}
                tapToClose={true}
                openDrawerOffset={0.2}
                panCloseMask={0.2}
                negotiatePan={true}
                disabled={disabled}
                acceptPan={false}
                styles={{
                    mainOverlay: {
                        backgroundColor: 'black',
                        opacity: 0,
                    }
                }}
                tweenHandler={(ratio) => ({
                    mainOverlay: {
                        opacity: Math.min(0.5, ratio)
                    }

                })}
            >
                <DefaultRenderer navigationState={children[0]} onNavigate={this.props.onNavigate}/>
            </Drawer>
        );
    }
}

let styles = StyleSheet.create({

})

export default connect(mapStateToProps, mapDispatchToProps)(DrawerContainer);