123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623 |
- define(['underscore', 'jquery.wookmark', 'jquery.jplayer'], function(_){
- var material = {
- 'defaultoptions' : {
- callback : null,
- type : 'all',
- multiple : false,
- ignore : {
- 'basic' : false,
- 'wxcard' : true,
- 'image' : false,
- 'music' : false,
- 'news' : false,
- 'video' : false,
- 'voice' : false,
- 'keyword' : false,
- 'module' : false
- },
- others : {
- 'basic' : {
- 'typeVal' : ''
- },
- 'news' : {
- 'showwx' : true,
- 'showlocal' : true
- }
- }
- },
- 'init' : function(callback, options) {
- var $this = this;
- $this.options = $.extend({}, $this.defaultoptions, options);
- $this.options.callback = callback;
- $('#material-Modal').remove();
- $(document.body).append($this.buildHtml().mainDialog);
- $this.modalobj = $('#material-Modal');
- $this.modalobj.find('.modal-header .nav li a').click(function(){
- var type = $(this).data('type');
- switch(type) {
- case 'basic':
- $('#material-Modal').addClass('basic');
- break;
- case 'news':
- $('#material-Modal').addClass('news');
- break;
- case 'music':
- $('#material-Modal').addClass('music');
- break;
- case 'voice':
- $('#material-Modal').addClass('voice');
- break;
- case 'video':
- $('#material-Modal').addClass('video');
- break;
- case 'image':
- $('#material-Modal').addClass('image');
- break;
- case 'keyword':
- $('#material-Modal').addClass('keyword');
- break;
- case 'module':
- $('#material-Modal').addClass('module');
- break;
- }
- $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');
- initSelectEmotion();
- return $this.modalobj;
- },
- //newsmodel: 微信素材wx和本地素材local
- 'localPage' : function(type, page, newsmodel) {
- var $this = this;
- var page = page || 1;
- $('.checkMedia').removeClass('checkedMedia');
- var $content = $this.modalobj.find('.material-content #' + type);
- $content.html('<div class="info text-center"><i class="fa fa-spinner fa-pulse fa-lg"></i> 数据加载中</div>');
- if(type == 'basic') {
- var Dialog = type + 'Dialog';
- $this.modalobj.find('#material-footer').show();
- $content.html(_.template($this.buildHtml()[Dialog]));
- $this.modalobj.find('.modal-footer .btn-primary').unbind('click').click(function(){
- var attachment = [];
- attachment.content = $('#basictext').val();
- $this.options.callback(attachment);
- $this.modalobj.modal('hide');
- });
- return false;
- }
- if(type == 'music') {
- var Dialog = type + 'Dialog';
- $this.modalobj.find('#material-footer').show();
- $content.html(_.template($this.buildHtml()[Dialog]));
- $this.modalobj.find('.modal-footer .btn-primary').unbind('click').click(function(){
- var attachment = [];
- attachment.title = $(':text[name="musicTitle"]').val();
- attachment.url = $(':text[name="musicUrl"]').val();
- attachment.HQUrl = $(':text[name="musicHQUrl"]').val();
- attachment.description = $(':text[name="musicDescription"]').val();
- $this.options.callback(attachment);
- $this.modalobj.modal('hide');
- });
- return false;
- }
- var url = './index.php?c=utility&a=material&do=list&type=' + type;
- if(type == 'wxcard') {
- url = './index.php?c=utility&a=coupon&do=wechat';
- }
- if(type == 'keyword') {
- url = './index.php?c=utility&a=keyword&do=keyword&type=all';
- }
- if(type == 'module') {
- url = './index.php?c=utility&a=modules&do=list';
- }
- if (type == 'news') {
- var newsmodel = newsmodel == 'local' ? 'local' : 'wx';
- url += newsmodel == 'local' ? '&newsmodel=local' : '&newsmodel=wx';
- }
- $.getJSON(url, {'page': page}, function(data){
- data = data.message.message;
- $this.modalobj.find('#material-list-pager').html('');
- if(!_.isEmpty(data.items)) {
- //$this.modalobj.find('#btn-select').show();
- $content.data('attachment', data.items);
- $content.empty();
- var Dialog = type + 'Dialog';
- $content.html(_.template($this.buildHtml()[Dialog])(data));
- if(type == 'news') {
- setTimeout(function(){
- $('.water').wookmark({
- align: 'center',
- autoResize: false,
- container: $('#news'),
- autoResize :true
- });
- }, 100);
- $this.modalobj.find('.material-content .newsmodel-type').unbind('click').click(function(){
- $(this).addClass('active').siblings().removeClass('active');
- $this.localPage(type, 1, $(this).data('type'));
- return false;
- });
- }
- $this.selectMedia();
- $this.playaudio();
- $this.modalobj.find('#material-list-pager').html(data.pager);
- $this.modalobj.find('#material-list-pager .pagination a').click(function(){
- $this.localPage(type, $(this).attr('page'), newsmodel);
- return false;
- });
- } else {
- if (type == 'news') {
- $('#news').html('<div role="tabpanel"><div class="tablepanel-top text-right"><button class="btn btn-primary" type="button"><a href="./index.php?c=platform&a=material-post&new_type=reply" target="_blank">图文编辑</a></button> <button class="btn btn-primary" type="button"><a href="./index.php?c=platform&a=material-post&new_type=link" target="_blank">跳转链接</a></button></div><div class="info text-center"><i class="wi wi-info-circle fa-lg"></i> 暂无数据</div></div>');
- } else {
- $content.html('<div class="info text-center"><i class="wi wi-info-circle fa-lg"></i> 暂无数据</div>');
- }
- }
- if (type == 'news') {
- $this.modalobj.find('.material-content .newsmodel-type').unbind('click').click(function(){
- $(this).addClass('active').siblings().removeClass('active');
- $this.localPage(type, 1, $(this).data('type'));
- return false;
- });
- }
- });
- $this.modalobj.find('#btn-select .btn-primary').unbind('click').click(function(){
- var attachment = [];
- $content.find('.checkedMedia').each(function(){
- if (type == 'module') {
- attachment.push($content.data('attachment')[$(this).data('name')]);
- } else {
- attachment.push($content.data('attachment')[$(this).data('attachid')]);
- }
- });
- $this.finish(attachment);
- });
- return false;
- },
- 'selectMedia' : function(){
- var $this = this;
- $this.modalobj.find('.checkMedia').unbind('click').click(function(){
- if(!$this.options.multiple) {
- $('.checkMedia').removeClass('checkedMedia');
- }
- $(this).addClass('checkedMedia');
- var type = $(this).data('type');
- if(type == 'news') {
- if(!$this.options.multiple) {
- $('#news .panel-group').removeClass('selected');
- }
- $(this).addClass('selected');
- } else if(type == 'image') {
- if(!$this.options.multiple) {
- $('#image div').removeClass('img-item-selected');
- }
- $(this).addClass('img-item-selected');
- } else {
- if(!$this.options.multiple) {
- $('.checkMedia').removeClass('btn-primary');
- }
- $(this).addClass('btn-primary');
- }
- if(!$this.options.multiple) {
- $this.modalobj.find('#btn-select .btn-primary').trigger('click');
- }
- });
- },
- 'playaudio' : function(){
- $("#voice, .panel").on('click', '.audio-player-play', function(){
- var src = $(this).data("attach");
- if(!src) {
- return;
- }
- if ($("#player")[0]) {
- var player = $("#player");
- } else {
- var player = $('<div id="player"></div>');
- $(document.body).append(player);
- }
- player.data('control', $(this));
- player.jPlayer({
- playing: function() {
- $(this).data('control').find("i").removeClass("fa-play").addClass("fa-stop");
- },
- pause: function (event) {
- $(this).data('control').find("i").removeClass("fa-stop").addClass("fa-play");
- },
- swfPath: "resource/components/jplayer",
- supplied: "mp3,wma,wav,amr",
- solution: "html, flash"
- });
- player.jPlayer("setMedia", {mp3: $(this).data("attach")}).jPlayer("play");
- if($(this).find("i").hasClass("fa-stop")) {
- player.jPlayer("stop");
- } else {
- $('.audio-msg').find('.fa-stop').removeClass("fa-stop").addClass("fa-play");
- player.jPlayer("setMedia", {mp3: $(this).data("attach")}).jPlayer("play");
- }
- });
- },
- '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="material-Modal" class="uploader-modal modal fade" tabindex="-1" role="dialog" aria-hidden="true">\n' +
- ' <div class="modal-dialog modal-lg">\n' +
- ' <div class="modal-content ">\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="basic ' + (this.options.ignore.basic ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="basic" role="tab" aria-controls="baisc" href="#basic">文字</a>'+
- ' </li>'+
- ' <li role="presentation" class="news ' + (this.options.ignore.news ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="news" role="tab" aria-controls="news" href="#news">图文</a>'+
- ' </li>'+
- ' <li role="presentation" class="image ' + (this.options.ignore.image ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="image" role="tab" aria-controls="image" href="#image">图片</a>'+
- ' </li>'+
- ' <li role="presentation" class="music ' + (this.options.ignore.music ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="music" role="tab" aria-controls="music" href="#music">音乐</a>'+
- ' </li>'+
- ' <li role="presentation" class="voice ' + (this.options.ignore.voice ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="voice" role="tab" aria-controls="voice" href="#voice">语音</a>'+
- ' </li>'+
- ' <li role="presentation" class="video ' + (this.options.ignore.video ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="video" role="tab" aria-controls="video" href="#video">视频</a>'+
- ' </li>'+
- ' <li role="presentation" class="wxcard ' + (this.options.ignore.wxcard ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="wxcard" role="tab" aria-controls="wxcard" href="#wxcard">微信卡券</a>'+
- ' </li>'+
- ' <li role="presentation" class="keyword ' + (this.options.ignore.keyword ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="keyword" role="tab" aria-controls="keyword" href="#keyword">关键字</a>'+
- ' </li>'+
- ' <li role="presentation" class="module ' + (this.options.ignore.module ? 'hide' : 'show') + '">'+
- ' <a data-toggle="tab" data-type="module" role="tab" aria-controls="module" href="#module">模块</a>'+
- ' </li>'+
- ' </ul>'+
- ' </h3>'+
- ' </div>\n' +
- ' <div class="modal-body material-content clearfix">\n' +
- (this.options.ignore.news ? '' :
- ' <ul class="nav nav-pills nav-stacked">'+
- (this.options.others.news.showwx ?
- ' <li role="presentation" data-type="wx" class="newsmodel-type active">微信</li>' : '') +
- (this.options.others.news.showlocal ?
- ' <li role="presentation" data-type="local" class="newsmodel-type">服务器</li>' : '') +
- ' </ul>') +
- ' <div class="material-head">'+
- ' <a class="btn btn-primary active we7-margin-vertical-sm active pull-right ' + (this.options.ignore.image ? 'hide' : 'show') + '" href="./index.php?c=platform&a=material&type=image" target="_blank">上传图片</a>'+
- ' <a class="btn btn-primary active we7-margin-vertical-sm active pull-right ' + (this.options.ignore.voice ? 'hide' : 'show') + '" href="./index.php?c=platform&a=material&type=voice" target="_blank">新建语音</a>'+
- ' <a class="btn btn-primary active we7-margin-vertical-sm active pull-right ' + (this.options.ignore.video ? 'hide' : 'show') + '" href="./index.php?c=platform&a=material&type=video" target="_blank">新建视频</a>'+
- ' <a class="btn btn-primary active we7-margin-vertical-sm active pull-right ' + (this.options.ignore.wxcard ? 'hide' : 'show') + '" href="./index.php?c=activity&a=coupon&do=display" target="_blank">新建卡券</a>'+
- ' <a class="btn btn-primary active we7-margin-vertical-sm pull-right ' + (this.options.ignore.keyword ? 'hide' : 'show') + '" href="./index.php?c=platform&a=reply&do=post&m=keyword" target="_blank">新建关键字</a>'+
- ' </div>'+
- ' <div class="tab-content">'+
- ' <div id="basic" class="tab-pane" role="tabpanel"></div>'+
- ' <div id="news" class="tab-pane material clearfix" class="active" role="tabpanel" style="position:relative"></div>'+
- ' <div id="image" class="tab-pane history" role="tabpanel"></div>'+
- ' <div id="music" class="tab-pane history" role="tabpanel"></div>'+
- ' <div id="voice" class="tab-pane" role="tabpanel"></div>'+
- ' <div id="video" class="tab-pane" role="tabpanel"></div>'+
- ' <div id="wxcard" class="tab-pane" role="tabpanel"></div>'+
- ' <div id="keyword" class="tab-pane" role="tabpanel"></div>'+
- ' <div id="module" class="tab-pane history" role="tabpanel"></div>'+
- ' </div>' +
- ' <nav id="material-list-pager" class="text-right we7-margin-vertical we7-padding-right">\n' +
- ' </nav>\n' +
- ' </div>\n' +
- ' <div class="modal-footer" id="material-footer" style="display: none">\n' +
- ' <div id="btn-select">\n' +
- ' <span class="btn btn-default" data-dismiss="modal">取消</span>\n' +
- ' <span class="btn btn-primary">确认</span>\n' +
- ' </div>\n' +
- ' </div>\n'+
- ' </div>\n' +
- ' </div>\n' +
- '</div>';
- dialog['basicDialog'] = '<div class="help-block">'+
- ' 您还可以使用表情和链接。'+
- ' <a class="emotion-triggers" href="javascript:;"><i class="fa fa-github-alt"></i> 表情</a>'+
- ' <a class="emoji-triggers" href="javascript:;" onclick="initSelectEmoji()" title="添加表情"><i class="fa fa-github-alt"></i> Emoji</a>'+
- ' </div>'+
- ' <textarea id="basictext" cols="116" rows="10">'+ (this.options.others.basic.typeVal ? this.options.others.basic.typeVal : "") +'</textarea>';
- dialog['imageDialog'] = '<ul class="img-list clearfix">\n' +
- '<%var items = _.sortBy(items, function(item) {return -item.id;});%>' +
- '<%_.each(items, function(item) {%> \n' +
- '<div class="checkMedia" data-media="<%=item.media_id%>" data-type="image" data-attachid="<%=item.id%>">' +
- ' <li class="img-item" style="padding:5px">\n' +
- ' <div class="img-container" style="background-image: url(\'<%=item.attach%>\');">\n' +
- ' <div class="select-status"><span></span></div>\n' +
- ' </div>\n' +
- ' </li>\n' +
- '</div>\n' +
- '<%});%>\n' +
- '</ul>';
- dialog['musicDialog'] = '<div class="form-group">'+
- ' <div class="col-xs-2">音乐标题</div>'+
- ' <div class="col-xs-10 input-group">'+
- ' <input type="text" value="" name="musicTitle" class="form-control" placeholder="添加音乐消息的标题">'+
- ' </div>'+
- '</div>'+
- '<div class="form-group">'+
- ' <div class="col-xs-2">选择音乐</div>'+
- ' <div class="col-xs-10 input-group">'+
- ' <input type="text" value="" name="musicUrl" class="form-control audio-player-media" autocomplete="off">'+
- ' <span class="help-block">选择上传的音频文件或直接输入URL地址,常用格式:mp3</span>'+
- ' <span class="input-group-btn" style="vertical-align: top;">'+
- ' <button class="btn btn-default audio-player-play" type="button" style="display:none;"><i class="fa fa-play"></i></button>'+
- ' <button class="btn btn-default" type="button" onclick="showAudioDialog(this);">选择媒体文件</button>'+
- ' </span>'+
- ' </div>'+
- ' <div class="input-group audio-player"></div>'+
- '</div>'+
- '<div class="form-group">'+
- ' <div class="col-xs-2">高品质链接</div>'+
- ' <div class="col-xs-10 input-group">'+
- ' <input type="text" value="" name="musicHQUrl" class="form-control">'+
- ' <span class="help-block">没有高品质音乐链接,请留空。高质量音乐链接,WIFI环境优先使用该链接播放音乐</span>'+
- ' </div>'+
- '</div>'+
- '<div class="form-group">'+
- ' <div class="col-xs-2">描述</div>'+
- ' <div class="col-xs-10 input-group">'+
- ' <input type="text" value="" name="musicDescription" class="form-control">'+
- ' <span class="help-block">描述内容将出现在音乐名称下方,建议控制在20个汉字以内最佳</span>'+
- ' </div>'+
- '</div>';
- dialog['voiceDialog'] ='<table class="table table-hover we7-table" style="margin-bottom:0">'+
- ' <col width=""/>'+
- ' <col width="150px"/>'+
- ' <col width="180px"/>'+
- ' <thead class="navbar-inner">'+
- ' <tr>'+
- ' <th>标题</th>'+
- ' <th style="text-align:center">创建时间</th>'+
- ' <th style="text-align:center"></th>'+
- ' </tr>'+
- ' </thead>'+
- ' <tbody class="history-content">'+
- ' <%var items = _.sortBy(items, function(item) {return -item.createtime;});%>' +
- ' <%_.each(items, function(item) {%> \n' +
- ' <tr>'+
- ' <td><%=item.filename%></td>'+
- ' <td align="center"><%=item.createtime_cn%></td>'+
- ' <td align="center">'+
- ' <div class="btn-group">'+
- ' <a href="javascript:;" class="btn btn-default btn-sm audio-player-play audio-msg" data-attach="<%=item.attach%>"><i class="fa fa-play"></i></a>'+
- ' <a href="javascript:;" class="btn btn-default btn-sm checkMedia" data-media="<%=item.media_id%>" data-type="voice" data-attachid="<%=item.id%>">选取</a>'+
- ' </div>'+
- ' </td>'+
- ' </tr>'+
- ' <%});%>' +
- ' </tbody>'+
- ' </table>';
- dialog['videoDialog'] ='<table class="table table-hover we7-table" style="margin-bottom:0">'+
- ' <col width=""/>'+
- ' <col width="150px"/>'+
- ' <col width="180px"/>'+
- ' <thead class="navbar-inner">'+
- ' <tr>'+
- ' <th>标题</th>'+
- ' <th style="text-align:center">创建时间</th>'+
- ' <th style="text-align:center"></th>'+
- ' </tr>'+
- ' </thead>'+
- ' <tbody class="history-content">'+
- ' <%var items = _.sortBy(items, function(item) {return -item.createtime;});%>' +
- ' <%_.each(items, function(item) {%> \n' +
- ' <tr>'+
- ' <%if(item.tag.title) {var title = item.tag.title} else {var title =item.filename}%>'+
- ' <td><%=title%></td>'+
- ' <td align="center"><%=item.createtime_cn%></td>'+
- ' <td align="center">'+
- ' <div class="btn-group">'+
- ' <a href="javascript:;" class="btn btn-default btn-sm checkMedia" data-media="<%=item.media_id%>" data-type="video" data-attachid="<%=item.id%>">选取</a>'+
- ' </div>'+
- ' </td>'+
- ' </tr>'+
- ' <%});%>' +
- ' </tbody>'+
- ' </table>';
- dialog['wxcardDialog'] ='<table class="table table-hover we7-table">\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.couponid;});%>' +
- ' <%_.each(items, function(item) {%> \n' +
- ' <tr title="<%=item.title%>">' +
- ' <td><%=item.title%></td>' +
- ' <td><%if(item.ctype == "discount") {%><span class="label label-success">折扣券</span><%} else if(item.ctype == "cash") {%><span class="label label-danger">代金券</span><%} else if(item.ctype == "gift") {%><span class="label label-danger">礼品券</span><%} else if(item.ctype == "groupon") {%><span class="label label-danger">团购券</span><%} else if(item.ctype == "general_coupon") {%><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 btn-sm checkMedia" data-title="<%=item.title%>" data-type="wxcard" data-media="<%=item.card_id%>" data-attachid="<%=item.id%>">选取</a></td>' +
- ' </tr>' +
- ' <%});%>' +
- ' </tbody>'+
- ' </table>';
- dialog['newsDialog'] = '<div role="tabpanel">'+
- ' <div class="tablepanel-top text-right">'+
- ' <button class="btn btn-primary" type="button"><a href="./index.php?c=platform&a=material-post&new_type=reply" target="_blank">图文编辑</a></button>'+
- '<button class="btn btn-primary" style="margin-left:10px" type="button"><a href="./index.php?c=platform&a=material-post&new_type=link" target="_blank">跳转链接</a></button>'+
- ' </div>'+
- ' <div class="tablepanel-con">'+
- ' <div class="graphic-list material clearfix" style="position: relative;">'+
- ' <%var items = _.sortBy(items, function(item) {return -item.createtime;});%>' +
- ' <%_.each(items, function(item) {%> \n' +
- ' <div class="col-md-5 water">'+
- ' <div class="panel-group checkMedia" data-media="<%=item.media_id%>" data-type="news" data-attachid="<%=item.id%>">'+
- ' <%var index = 0;%>\n' +
- ' <%_.each(item.items, function(data) {%>\n' +
- ' <%index++;%>\n' +
- ' <div class="panel panel-default">'+
- ' <%if(index == 1) {%>\n' +
- ' <div class="panel-body">'+
- ' <div class="img">'+
- ' <i class="default">封面图片</i>'+
- ' <img src="<%=data.thumb_url%>" width="100%">'+
- ' <span class="text-left"><%=data.title%></span>'+
- ' </div>'+
- ' </div>'+
- ' <%} else {%>\n' +
- ' <div class="panel-body">'+
- ' <div class="text">'+
- ' <h4><%=data.title%></h4>'+
- ' </div>'+
- ' <div class="img">'+
- ' <img src="<%=data.thumb_url%>">'+
- ' <i class="default">缩略图</i>'+
- ' </div>'+
- ' </div>'+
- ' <%}%>\n' +
- ' </div>'+
- ' <%});%>'+
- ' <div class="mask"></div>'+
- ' <i class="fa fa-check"></i>'+
- ' </div>'+
- ' </div>'+
- ' <%});%>'+
- ' </div>'+
- ' </div>'+
- ' </div>';
- dialog['keywordDialog'] = '<div class="row">\n'+
- '<%_.each(items, function(item) {%>' +
- ' <div class="col-sm-2">'+
- ' <a href="javascript:;" class="checkMedia" data-media="<%=item.media_id%>" data-type="keyword" data-attachid="<%=item.id%>">'+
- ' <span>'+
- ' <%=item.content%>' +
- ' </span>'+
- ' </a>'+
- ' </div>'+
- '<%});%>'+
- '</div>';
- dialog['moduleDialog'] = '<ul class="img-list clearfix">\n' +
- '<%var items = _.sortBy(items, function(item) {return -item.id;});%>' +
- '<%_.each(items, function(item) {%> \n' +
- '<div class="checkMedia" data-name="<%=item.name%>" data-type="module">' +
- ' <li class="img-item" style="padding:5px">\n' +
- ' <div class="img-container">\n' +
- ' <img src="<%=item.icon%>" width="48px" height="48px">\n' +
- ' <div class="text-over"><%=item.title%></div>\n' +
- ' <div class="select-status"><span></span></div>\n' +
- ' </div>\n' +
- ' </li>\n' +
- '</div>\n' +
- '<%});%>\n' +
- '</ul>';
- return dialog;
- }
- };
- initSelectEmotion = function() {
- var $t = $('#basictext')[0];
- var textbox = $("#basictext").val();
- util.emotion($('.emotion-triggers'), $("#basictext"), function(txt, elm, target){
- if ($t.selectionStart || $t.selectionStart == '0') {
- var startPos = $t.selectionStart;
- var endPos = $t.selectionEnd;
- var scrollTop = $t.scrollTop;
- $("#basictext").val($t.value.substring(0, startPos) + txt + $t.value.substring(endPos, $t.value.length));
- $("#basictext").focus();
- $t.selectionStart = startPos + txt.length;
- $t.selectionEnd = startPos + txt.length;
- $t.scrollTop = scrollTop;
- }
- else {
- $("#basictext").val(textbox+txt);
- $("#basictext").focus();
- }
- });
- };
- initSelectEmoji = function() {
- var textbox = $("#basictext").val();
- util.emojiBrowser(function(emoji){
- var unshift = '[U+' + emoji.find("span").text() + ']';
- $("#basictext").val(textbox+unshift);
- });
- };
- showAudioDialog = function(elm, base64options, options) {
- var btn = $(elm);
- var ipt = btn.parent().prev().prev();
- var val = ipt.val();
- util.audio(val, function(url){
- if(url && url.attachment && url.url){
- btn.prev().show();
- ipt.val(url.attachment);
- ipt.attr("filename",url.filename);
- ipt.attr("url",url.url);
- setAudioPlayer();
- }
- if(url && url.media_id){
- ipt.val(url.media_id);
- }
- }, "" , {"direct": true, "multiple": false});
- };
- setAudioPlayer = function(){
- $(function(){
- $(".audio-player").each(function(){
- $(this).prev().find("button").eq(0).click(function(){
- var src = $(this).parent().prev().prev().val();
- if($(this).find("i").hasClass("fa-stop")) {
- $(this).parent().parent().next().jPlayer("stop");
- } else {
- if(src) {
- $(this).parent().parent().next().jPlayer("setMedia", {mp3: util.tomedia(src)}).jPlayer("play");
- }
- }
- });
- });
- $(".audio-player").jPlayer({
- playing: function() {
- $(this).prev().find("i").removeClass("fa-play").addClass("fa-stop");
- },
- pause: function (event) {
- $(this).prev().find("i").removeClass("fa-stop").addClass("fa-play");
- },
- swfPath: "resource/components/jplayer",
- supplied: "mp3"
- });
- $(".audio-player-media").each(function(){
- $(this).next().find(".audio-player-play").css("display", $(this).val() == "" ? "none" : "");
- });
- });
- };
- return material;
- });
|