123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- define(['jquery', 'underscore', 'bootstrap'], function($, _){
- var coupon = {
- 'defaultoptions' : {
- callback : null,
- type : 'all',
- multiple : true,
- ignore : {
- 'local' : false,
- 'wechat' : false
- }
- },
- 'init' : function(callback, options) {
- var $this = this;
- $this.options = $.extend({}, $this.defaultoptions, options);
- $this.options.callback = callback;
-
- $('#counpon-Modal').remove();
- $(document.body).append($this.buildHtml().mainDialog);
-
- $this.modalobj = $('#counpon-Modal');
- $this.modalobj.find('.modal-header .nav li a').click(function(){
- var type = $(this).data('type');
- $this.localPage(type, 1);
- $(this).tab('show')
- return false;
- });
- if (!$(this).data('init')) {
- if($this.options.type && $this.options.type != 'all') {
- $this.modalobj.find('.modal-header .nav li.' + $this.options.type + ' a').trigger('click');
- } else {
- $this.modalobj.find('.modal-header .nav li.show:first a').trigger('click');
- }
- }
- $this.modalobj.modal('show');
- return $this.modalobj;
- },
-
- 'localPage' : function(type, page) {
- var $this = this;
- var $history = $this.modalobj.find('.coupon-content #' + type);
- $history.html('<div class="info"><i class="fa fa-spinner fa-pulse fa-lg"></i> 数据加载中</div>');
- $.getJSON('./index.php?c=utility&a=coupon&do=' + type, {'page': page}, function(data){
- data = data.message;
- $this.modalobj.find('#coupon-list-pager').html('');
- if(!_.isEmpty(data.items)) {
- $this.modalobj.find('#btn-select').show();
- $history.data('attachment', data.items);
- $history.empty();
- var Dialog = type + 'Dialog';
- $history.html(_.template($this.buildHtml()[Dialog])(data));
- $this.modalobj.find('#coupon-list-pager').html(data.page);
- $this.modalobj.find('.pagination a').click(function(){
- $this.localPage(type, $(this).attr('page'));
- });
- $history.find('.conpon-list').click(function(){
- $this.selectCoupon(this);
- });
- } else {
- $history.html('<div class="info"><i class="fa fa-info-circle fa-lg"></i> 暂无数据</div>');
- }
- });
-
- $this.modalobj.find('.modal-footer .btn-primary').unbind('click').click(function(){
- var attachment = [];
- $history.find('.btn-primary').each(function(){
- attachment.push($history.data('attachment')[$(this).data('attachid')]);
- $(this).removeClass('btn-primary');
- });
- $this.finish(attachment);
- });
- return false;
- },
-
- 'selectCoupon' : function(obj) {
- var $this = this;
- $(obj).toggleClass('btn-primary');
- if (!$this.options.multiple) {
- $this.modalobj.find('.modal-footer .btn-primary').trigger('click');
- }
- },
-
- 'finish' : function(attachment) {
- var $this = this;
- if($.isFunction($this.options.callback)) {
- if ($this.options.multiple == false) {
- $this.options.callback(attachment[0]);
- } else {
- $this.options.callback(attachment);
- }
- $this.modalobj.modal('hide');
- }
- },
-
- 'buildHtml' : function() {
- var dialog = {};
- dialog['mainDialog'] = '<div id="counpon-Modal" class="modal fade" tabindex="-1" role="dialog" aria-hidden="true">\n' +
- ' <div class="modal-dialog">\n' +
- ' <div class="modal-content modal-lg">\n' +
- ' <div class="modal-header">\n' +
- ' <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>\n' +
- ' <h3>'+
- ' <ul role="tablist" class="nav nav-pills" style="font-size:14px; margin-top:-20px;">'+
- ' <li role="presentation" class="wechat ' + (this.options.ignore.wechat ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="wechat" role="tab" aria-controls="wechat" href="#wechat">卡券列表</a>'+
- ' </li>'+
- ' </ul>'+
- ' </h3>'+
- ' </div>\n' +
- ' <div class="modal-body coupon-content">\n' +
- ' <div class="tab-content">'+
- ' <div id="local" class="tab-pane" class="active" role="tabpanel"></div>'+
- ' <div id="wechat" class="tab-pane" role="tabpanel"></div>'+
- ' </div>' +
- ' </div>\n' +
- ' <div class="modal-footer">\n' +
- ' <div style="float: left;">\n' +
- ' <nav id="coupon-list-pager">\n' +
- ' <ul class="pager" style="margin: 0;"></ul>\n' +
- ' </nav>\n' +
- ' </div>\n' +
- ' <div id="btn-select" style="float: right; display: none">\n' +
- ' <button '+(this.options.multiple ? '' : 'style="display:none;"')+' type="button" class="btn btn-primary">确认</button>\n' +
- (this.options.multiple ? '<button type="button" class="btn btn-default" data-dismiss="modal">取消</button>\n' : '') +
- ' </div>\n' +
- ' </div>\n'+
- ' </div>\n' +
- ' </div>\n' +
- '</div>';
-
- dialog['wechatDialog'] ='<table class="table table-hover table-bordered">\n'+
- ' <thead>\n'+
- ' <tr>\n'+
- ' <th width="130" class="text-center">标题</th>\n'+
- ' <th class="text-center">类型</th>\n'+
- ' <th width="250" class="text-center">卡券有效期</th>\n'+
- ' <th class="text-center">库存/每人限领</th>\n'+
- ' <th class="text-center">操作</th>\n'+
- ' </tr>'+
- ' </thead>'+
- ' <tbody>'+
- ' <%var items = _.sortBy(items, function(item) {return -item.id;});%>' +
- ' <%_.each(items, function(item) {%> \n' +
- ' <tr title="<%=item.title%>">' +
- ' <td><%=item.title%></td>' +
- ' <td><%if(item.type == "1") {%><span class="label label-info"><%=item.extra.discount%>折</span> <span class="label label-success">折扣券</span><%} else if(item.type == "2") {%><span class="label label-info"><%=item.extra.reduce_cost%>元</span> <span class="label label-danger">代金券</span><%} else if(item.type == "4") {%><span class="label label-danger">礼品券</span><%} else if(item.type == "3") {%><span class="label label-danger">团购券</span><%} else if(item.type == "5") {%><span class="label label-danger">优惠券</span><%}%></td>' +
- ' <td><%if(item.date_info.time_type == 1) {%><%=item.date_info.time_limit_start%> ~ <%=item.date_info.time_limit_end%><%} else {%>领取后<%=item.date_info.date_info%>天后生效,<%=item.date_info.limit%>天有效期<%}%></td>' +
- ' <td><%=item.quantity%>/<strong class="text-danger"><%=item.get_limit%></strong></td>' +
- ' <td><a href="javascript:;" class="btn btn-default conpon-list" data-title="<%=item.title%>" data-attachid="<%=item.id%>">选取</a></td>' +
- ' </tr>' +
- ' <%});%>' +
- ' </tbody>'+
- ' </table>';
- return dialog;
- }
- };
- return coupon;
- });
|