house_activity.js 10.2 KB
define(['jquery', 'bootstrap', 'backend', 'table', 'form', 'backend/house_activity.spec'], function ($, undefined, Backend, Table, Form, spec) {

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

            var table = $("#table");

            // 初始化表格
            table.bootstrapTable({
                url: $.fn.bootstrapTable.defaults.extend.index_url,
                pk: 'id',
                sortName: 'id',
                columns: [
                    [
                        {checkbox: true},
                        {field: 'id', title: __('Id')},
                        {field: 'title', title: __('Title')},
                        {field: 'spec_type', title: __('Spec_type'), searchList: {"0":__('Spec_type 0'),"1":__('Spec_type 1'),"2":__('Spec_type 2')}, formatter: Table.api.formatter.normal},
                        {field: 'start_time', title: __('Start_time'), operate:'RANGE', addclass:'datetimerange', formatter: Table.api.formatter.datetime},
                        {field: 'end_time', title: __('End_time'), operate:'RANGE', addclass:'datetimerange', formatter: Table.api.formatter.datetime},
                        {field: 'updatetime', title: __('Updatetime'), operate:'RANGE', addclass:'datetimerange', formatter: Table.api.formatter.datetime},
                        {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate}
                    ]
                ]
            });

            // 为表格绑定事件
            Table.api.bindevent(table);
        },
        add: function () {
			setTimeout(function () {
			    $('select[name="row[spec_type]"]').trigger("change");
			}, 100);
			Form.api.bindevent($("form[role=form]"), function(data, ret){
			    Fast.api.close(data);
			    Toastr.success("活动提交成功");
			}, function(data, ret){
			    Toastr.success("活动提交失败");
			}, function(success, error){
			    //注意如果我们需要阻止表单,可以在此使用return false;即可
			    //如果我们处理完成需要再次提交表单则可以使用submit提交,如下
			    console.log(this);
			    var form = this;
			    if (form.size() === 0) {
			        Toastr.error("表单未初始化完成,无法提交");
			        return false;
			    }
			    var type = form.attr("method") ? form.attr("method").toUpperCase() : 'GET';
			    type = type && (type === 'GET' || type === 'POST') ? type : 'GET';
			    url = form.attr("action");
			    url = url ? url : location.href;
			    //修复当存在多选项元素时提交的BUG
			    var params = {};
			    var multipleList = $("[name$='[]']", form);
			    if (multipleList.size() > 0) {
			        var postFields = form.serializeArray().map(function (obj) {
			            return $(obj).prop("name");
			        });
			        $.each(multipleList, function (i, j) {
			            if (postFields.indexOf($(this).prop("name")) < 0) {
			                params[$(this).prop("name")] = '';
			            }
			        });
			    }
			    var dataParam = {spec_many: specMany.getData()};
			    console.log(dataParam);
			    Fast.api.ajax({
			        type: type,
			        url: url,
			        data: form.serialize() + (Object.keys(params).length > 0 ? '&' + $.param(params) : '') + (Object.keys(dataParam).length > 0 ? '&' + $.param(dataParam) : ''),
			        dataType: 'json',
			        complete: function (xhr) {
			            var token = xhr.getResponseHeader('__token__');
			            if (token) {
			                $("input[name='__token__']", form).val(token);
			            }
			            //关闭弹窗
			            var index = parent.Layer.getFrameIndex(window.name);
			            var callback = parent.$("#layui-layer" + index).data("callback");
			            parent.Layer.close(index);
			            //刷新列表
			            parent.$("#table").bootstrapTable('refresh');
			        }
			    }, function (data, ret) {
			        $('.form-group', form).removeClass('has-feedback has-success has-error');
			        if (data && typeof data === 'object') {
			            if (typeof data.token !== 'undefined') {
			                $("input[name='__token__']", form).val(data.token);
			            }
			            if (typeof data.callback !== 'undefined' && typeof data.callback === 'function') {
			                data.callback.call(form, data);
			            }
			        }
			    }, function (data, ret) {
			        if (data && typeof data === 'object' && typeof data.token !== 'undefined') {
			            $("input[name='__token__']", form).val(data.token);
			        }
			    });
			    return false;
			});
			
			// 注册商品多规格组件
			var specMany = new GoodsSpec({
			    container: '.goods-spec-many',
			    OutForm:Form
			});
			
			// 切换单/多规格
			$('select[name="row[spec_type]"').change(function (e) {
			    var $goodsSpecMany = $('.goods-spec-many')
			        , $goodsSpecSingle = $('.goods-spec-single');
			    if (e.currentTarget.value === '1') {
			        $goodsSpecMany.hide() && $goodsSpecSingle.show();
			    } else if (e.currentTarget.value === '2') {
			        $goodsSpecMany.show() && $goodsSpecSingle.hide();
			    } else {
			        $goodsSpecMany.hide() && $goodsSpecSingle.hide();
			    }
			});
        },
        edit: function () {
			setTimeout(function () {
			    $('select[name="row[spec_type]"]').trigger("change");
			}, 100);
            Form.api.bindevent($("form[role=form]"), function(data, ret){
                //Fast.api.close(data);
                Toastr.success("商品提交成功");
            }, function(data, ret){
                Toastr.success("商品提交失败");
            }, function(success, error){
                //注意如果我们需要阻止表单,可以在此使用return false;即可
                //如果我们处理完成需要再次提交表单则可以使用submit提交,如下
                console.log(this);
                var form = this;
                if (form.size() === 0) {
                    Toastr.error("表单未初始化完成,无法提交");
                    return false;
                }
                var type = form.attr("method") ? form.attr("method").toUpperCase() : 'GET';
                type = type && (type === 'GET' || type === 'POST') ? type : 'GET';
                url = form.attr("action");
                url = url ? url : location.href;
                //修复当存在多选项元素时提交的BUG
                var params = {};
                var multipleList = $("[name$='[]']", form);
                if (multipleList.size() > 0) {
                    var postFields = form.serializeArray().map(function (obj) {
                        return $(obj).prop("name");
                    });
                    $.each(multipleList, function (i, j) {
                        if (postFields.indexOf($(this).prop("name")) < 0) {
                            params[$(this).prop("name")] = '';
                        }
                    });
                }
                var dataParam = {spec_many: specMany.getData()};
                console.log(dataParam);
                Fast.api.ajax({
                    type: type,
                    url: url,
                    data: form.serialize() + (Object.keys(params).length > 0 ? '&' + $.param(params) : '') + (Object.keys(dataParam).length > 0 ? '&' + $.param(dataParam) : ''),
                    dataType: 'json',
                    complete: function (xhr) {
                        var token = xhr.getResponseHeader('__token__');
                        if (token) {
                            $("input[name='__token__']", form).val(token);
                        }
                        //关闭弹窗
                        var index = parent.Layer.getFrameIndex(window.name);
                        var callback = parent.$("#layui-layer" + index).data("callback");
                        parent.Layer.close(index);
                        //刷新列表
                        parent.$("#table").bootstrapTable('refresh');
                    }
                }, function (data, ret) {
                    $('.form-group', form).removeClass('has-feedback has-success has-error');
                    if (data && typeof data === 'object') {
                        if (typeof data.token !== 'undefined') {
                            $("input[name='__token__']", form).val(data.token);
                        }
                        if (typeof data.callback !== 'undefined' && typeof data.callback === 'function') {
                            data.callback.call(form, data);
                        }
                    }
                }, function (data, ret) {
                    if (data && typeof data === 'object' && typeof data.token !== 'undefined') {
                        $("input[name='__token__']", form).val(data.token);
                    }
                });
                return false;
            });
            // 注册商品多规格组件
            var specMany = new GoodsSpec({
                container: '.goods-spec-many',
                OutForm:Form
            }, from_specData);
            
            // 切换单/多规格
            $('select[name="row[spec_type]"').change(function (e) {
                var $goodsSpecMany = $('.goods-spec-many')
                    , $goodsSpecSingle = $('.goods-spec-single');
                if (e.currentTarget.value === '1') {
                    $goodsSpecMany.hide() && $goodsSpecSingle.show();
                } else if (e.currentTarget.value === '2') {
                    $goodsSpecMany.show() && $goodsSpecSingle.hide();
                } else {
                    $goodsSpecMany.hide() && $goodsSpecSingle.hide();
                }
            });
        },
        api: {
            bindevent: function () {
                Form.api.bindevent($("form[role=form]"));
            }
        }
    };
    return Controller;
});