define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) {

    var Controller = {
        index: function () {
            // 初始化表格参数配置
            Table.api.init({
                extend: {
                    index_url: 'cloudapi/user/index' + location.search,
                    add_url: 'cloudapi/user/add',
                    edit_url: 'cloudapi/user/edit',
                    del_url: 'cloudapi/user/del',
                    multi_url: 'cloudapi/user/multi',
                    import_url: 'cloudapi/user/import',
                    table: 'cloudapi_user',
                }
            });

            var table = $("#table");

            // 初始化表格
            table.bootstrapTable({
                url: $.fn.bootstrapTable.defaults.extend.index_url,
                pk: 'id',
                sortName: 'id',
                columns: [
                    [
                        {checkbox: true},
                        {field: 'id', title: __('Id')},
                        {field: 'corporate_name', title: __('Corporate_name'), operate: 'LIKE'},

                        {field: 'admin.username', title: __('Username') ,operate:'LIKE'},
                        {field: 'admin.nickname', title: __('Nickname') ,operate:'LIKE'},
                        {field: 'groups_text', title: __('Group'), operate:false, formatter: Table.api.formatter.label},
                        {field: 'admin.email', title: __('Email') ,operate:'LIKE'},
                        {field: 'admin.status', title: __("Status"), searchList: {"normal":__('Normal'),"hidden":__('Hidden')}, formatter: Table.api.formatter.status},

                        {field: 'app_id', title: __('App_id'), operate: 'LIKE'},
                        {field: 'app_secret', title: __('App_secret'), operate: 'LIKE'},
                        // {field: 'token', title: __('Token'), operate: 'LIKE'},
                        // {field: 'expire_time', title: __('Expire_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
                        {field: 'createtime', title: __('Createtime'), operate:'RANGE', addclass:'datetimerange', autocomplete:false, formatter: Table.api.formatter.datetime},
                        {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate,
                            buttons: [
                                {
                                    name: 'permission',//按钮name属性
                                    text: 'API访问权限设置',//按钮文本
                                    title: 'API访问权限设置',//窗口title
                                    classname: 'btn btn-xs btn-warning btn-dialog',
                                    icon: 'fa fa-gears',
                                    url: 'cloudapi/user/permission',
                                    //fastadmin js中设置弹窗大小
                                    extend:' data-area=["100%","100%"]',
                                    callback: function (data) {
                                        // Layer.alert("接收到回传数据:" + JSON.stringify(data), {title: "回传数据"});
                                    },
                                    visible: function (row) {
                                        //返回true时按钮显示,返回false隐藏
                                        return true;
                                    }
                                }
                            ]
                        }
                    ]
                ]
            });

            // 为表格绑定事件
            Table.api.bindevent(table);
        },
        add: function () {
            //监听管理员选择
            $('#c-admin_id').on('change',function () {
                let admin_id = $('#c-admin_id').val()
                if (admin_id){
                    $('#f-groups').hide()
                    $('#f-username').hide()
                    $('#f-email').hide()
                    $('#f-nickname').hide()
                    $('#f-password').hide()
                    $('#f-status').hide()
                }else{
                    $('#f-groups').show()
                    $('#f-username').show()
                    $('#f-email').show()
                    $('#f-nickname').show()
                    $('#f-password').show()
                    $('#f-status').show()
                }
            })
            Controller.api.bindevent();
        },
        edit: function () {
            //监听管理员选择
            $('#c-admin_id').on('change',function () {
                let admin_id = $('#c-admin_id').val()
                if (parseInt(admin_id) !== parseInt(Config.admin_id)){
                    $('#f-groups').hide()
                    $('#f-username').hide()
                    $('#f-email').hide()
                    $('#f-nickname').hide()
                    $('#f-password').hide()
                    $('#f-status').hide()
                }else{
                    if (parseInt(admin_id) === 1 || parseInt(admin_id) === Config.admin_id){
                        $('#f-groups').hide()
                        $('#f-username').hide()
                        $('#f-email').hide()
                        $('#f-nickname').hide()
                        $('#f-password').hide()
                        $('#f-status').hide()
                    }else{
                        $('#f-groups').show()
                        $('#f-username').show()
                        $('#f-email').show()
                        $('#f-nickname').show()
                        $('#f-password').show()
                        $('#f-status').show()
                    }
                }
            })
            Controller.api.bindevent();
        },
        permission: function () {
            //监听水库全选
            $('#reservoir_ids-all').on('change',function () {
                let checked = $(this).prop('checked');
                if (checked){
                    $('input[name="row[reservoir_ids][]"]').prop('checked',true);
                }else{
                    $('input[name="row[reservoir_ids][]"]').prop('checked',false);
                }
            });
            //监听水库单个勾选
            $('input[name="row[reservoir_ids][]"]').on('change',function () {
                let checkedAll = true;
                $('input[name="row[reservoir_ids][]"]').each(function (index,one) {
                    let oneChecked = $(one).prop('checked');
                    if (!oneChecked){
                        checkedAll = false;
                    }
                });
                $('#reservoir_ids-all').prop('checked',checkedAll);
            })

            //监听API分组全选
            $('#group_ids-all').on('change',function () {
                let checked = $(this).prop('checked');
                if (checked){
                    $('input[name="row[group_ids][]"]').prop('checked',true);
                }else{
                    $('input[name="row[group_ids][]"]').prop('checked',false);
                }
            });
            //监听API分组单个勾选
            $('input[name="row[group_ids][]"]').on('change',function () {
                let checkedAll = true;
                $('input[name="row[group_ids][]"]').each(function (index,one) {
                    let oneChecked = $(one).prop('checked');
                    if (!oneChecked){
                        checkedAll = false;
                    }
                });
                $('#group_ids-all').prop('checked',checkedAll);
            })

            //监听API全选
            $('#api_ids-all').on('change',function () {
                let checked = $(this).prop('checked');
                if (checked){
                    $('input[name="row[api_ids][]"]').prop('checked',true);
                }else{
                    $('input[name="row[api_ids][]"]').prop('checked',false);
                }
            });
            //监听API单个勾选
            $('input[name="row[api_ids][]"]').on('change',function () {
                let checkedAll = true;
                $('input[name="row[api_ids][]"]').each(function (index,one) {
                    let oneChecked = $(one).prop('checked');
                    if (!oneChecked){
                        checkedAll = false;
                    }
                });
                $('#api_ids-all').prop('checked',checkedAll);
            })

            Controller.api.bindevent();
        },
        api: {
            bindevent: function () {
                Form.api.bindevent($("form[role=form]"));
            }
        }
    };
    return Controller;
});