/** @Name: Fly社区主入口 */ layui.define(['layer', 'laytpl', 'form', 'element', 'upload', 'util'], function(exports){ var $ = layui.jquery ,layer = layui.layer ,laytpl = layui.laytpl ,form = layui.form ,element = layui.element ,upload = layui.upload ,util = layui.util ,device = layui.device() ,DISABLED = 'layui-btn-disabled'; //阻止IE7以下访问 if(device.ie && device.ie < 8){ layer.alert('如果您非得使用 IE 浏览器访问Fly社区,那么请使用 IE8+'); } layui.focusInsert = function(obj, str){ var result, val = obj.value; obj.focus(); if(document.selection){ //ie result = document.selection.createRange(); document.selection.empty(); result.text = str; } else { result = [val.substring(0, obj.selectionStart), str, val.substr(obj.selectionEnd)]; obj.focus(); obj.value = result.join(''); } }; //数字前置补零 layui.laytpl.digit = function(num, length, end){ var str = ''; num = String(num); length = length || 2; for(var i = num.length; i < length; i++){ str += '0'; } return num < Math.pow(10, length) ? str + (num|0) : num; }; var fly = { dir: layui.cache.host + 'static/res/mods/' //模块路径 //Ajax ,json: function(url, data, success, options){ var that = this, type = typeof data === 'function'; if(type){ options = success success = data; data = {}; } options = options || {}; return $.ajax({ type: options.type || 'post', dataType: options.dataType || 'json', data: data, url: url, success: function(res){ if(res.status === 0) { success && success(res); } else { layer.msg(res.msg || res.code, {shift: 6}); options.error && options.error(); } }, error: function(e){ layer.msg('请求异常,请重试', {shift: 6}); options.error && options.error(e); } }); } //计算字符长度 ,charLen: function(val){ var arr = val.split(''), len = 0; for(var i = 0; i < val.length ; i++){ arr[i].charCodeAt(0) < 299 ? len++ : len += 2; } return len; } ,form: {} //简易编辑器 ,layEditor: function(options){ var html = ['
' ,'' ,'' ,'' ,'' ,'' ,'hr' ,'' ,'
'].join(''); var closeTips = function(){ layer.close(mod.face.index); }; var log = {}, mod = { face: function(editor, self){ //插入表情 var str = '', ul, face = fly.faces; for(var key in face){ str += '
  • '; } str = ''; layer.close(mod.face.index); mod.face.index = layer.tips(str, self, { tips: 3 ,time: 0 ,skin: 'layui-edit-face' ,tipsMore: true }); $(document).off('click', closeTips).on('click', closeTips); $('#LAY-editface li').on('click', function(){ var title = $(this).attr('title') + ' '; layui.focusInsert(editor[0], 'face' + title); editor.trigger('keyup'); }); } ,picture: function(editor){ //插入图片 layer.open({ type: 1 ,id: 'fly-jie-upload' ,title: '插入图片' ,area: 'auto' ,shade: false ,area: '465px' ,fixed: false ,offset: [ editor.offset().top - $(window).scrollTop() + 'px' ,editor.offset().left + 'px' ] ,skin: 'layui-layer-border' ,content: [''].join('') ,success: function(layero, index){ var image = layero.find('input[name="image"]'); //执行上传实例 upload.render({ elem: '#uploadImg' ,acceptMime: 'image/*' ,exts: 'jpg|png|gif|bmp|jpeg' ,url: '/index/article/text_img_upload' ,size: 2048 ,done: function(res){ if(res.status == 0){ image.val(res.url); } else { layer.msg(res.msg, {icon: 5}); } } }); form.on('submit(uploadImages)', function(data){ var field = data.field; if(!field.image) return image.focus(); layui.focusInsert(editor[0], 'img['+ field.image + '] '); layer.close(index); editor.trigger('keyup'); }); } }); } ,href: function(editor){ //超链接 layer.prompt({ title: '请输入合法链接' ,shade: false ,fixed: false ,id: 'LAY_flyedit_href' ,offset: [ editor.offset().top - $(window).scrollTop() + 1 + 'px' ,editor.offset().left + 1 + 'px' ] }, function(val, index, elem){ if(!/^http(s*):\/\/[\S]/.test(val)){ layer.tips('请务必 http 或 https 开头', elem, {tips:1}) return; } layui.focusInsert(editor[0], ' a('+ val +')['+ val + '] '); layer.close(index); editor.trigger('keyup'); }); } ,quote: function(editor){ //引用 layer.prompt({ title: '请输入引用内容' ,formType: 2 ,maxlength: 10000 ,shade: false ,id: 'LAY_flyedit_quote' ,offset: [ editor.offset().top - $(window).scrollTop() + 1 + 'px' ,editor.offset().left + 1 + 'px' ] ,area: ['300px', '100px'] }, function(val, index, elem){ layui.focusInsert(editor[0], '[quote]\n '+ val + '\n[/quote]\n'); layer.close(index); editor.trigger('keyup'); }); } ,code: function(editor){ //插入代码 layer.prompt({ title: '请贴入代码' ,formType: 2 ,maxlength: 10000 ,shade: false ,id: 'LAY_flyedit_code' ,area: ['800px', '360px'] }, function(val, index, elem){ layui.focusInsert(editor[0], '[pre]\n'+ val + '\n[/pre]\n'); layer.close(index); editor.trigger('keyup'); }); } ,hr: function(editor){ //插入水平分割线 layui.focusInsert(editor[0], '[hr]\n'); editor.trigger('keyup'); } ,preview: function(editor, span){ //预览 var othis = $(span), getContent = function(){ var content = editor.val(); return /^\{html\}/.test(content) ? content.replace(/^\{html\}/, '') : fly.content(content) }, isMobile = device.ios || device.android; if(mod.preview.isOpen) return layer.close(mod.preview.index); mod.preview.index = layer.open({ type: 1 ,title: '预览' ,shade: false ,offset: 'r' ,id: 'LAY_flyedit_preview' ,area: [ isMobile ? '100%' : '775px' ,'100%' ] ,scrollbar: isMobile ? false : true ,anim: -1 ,isOutAnim: false ,content: '
    '+ getContent() +'
    ' ,success: function(layero){ editor.on('keyup', function(val){ layero.find('.detail-body').html(getContent()); }); mod.preview.isOpen = true; othis.addClass('layui-this'); } ,end: function(){ delete mod.preview.isOpen; othis.removeClass('layui-this'); } }); } }; layui.use('face', function(face){ options = options || {}; fly.faces = face; $(options.elem).each(function(index){ var that = this, othis = $(that), parent = othis.parent(); parent.prepend(html); parent.find('.fly-edit span').on('click', function(event){ var type = $(this).attr('type'); mod[type].call(that, othis, this); if(type === 'face'){ event.stopPropagation() } }); }); }); } ,escape: function(html){ return String(html||'').replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&') .replace(//g, '>').replace(/'/g, ''').replace(/"/g, '"'); } //内容转义 ,content: function(content){ var util = fly ,item = fly.faces; //支持的html标签 var html = function(end){ return new RegExp('\\n*\\|\\-'+ (end||'') +'(div|span|p|button|table|thead|th|tbody|tr|td|ul|li|ol|li|dl|dt|dd|h2|h3|h4|h5)([\\s\\S]*?)\\-\\|\\n*', 'g'); }; //XSS content = util.escape(content||'') //转义图片 .replace(/img\[([^\s]+?)\]/g, function(img){ return ''; }) //转义@ .replace(/@(\S+)(\s+?|$)/g, '@$1$2') //转义表情 .replace(/face\[([^\s\[\]]+?)\]/g, function(face){ var alt = face.replace(/^face/g, ''); return ''+ alt +''; }) //转义脚本 .replace(/a(\(javascript:)(.+)(;*\))/g, 'a(javascript:layer.msg(\'非法脚本\');)') //转义链接 .replace(/a\([\s\S]+?\)\[[\s\S]*?\]/g, function(str){ var href = (str.match(/a\(([\s\S]+?)\)\[/)||[])[1]; var text = (str.match(/\)\[([\s\S]*?)\]/)||[])[1]; if(!href) return str; var rel = /^(http(s)*:\/\/)\b(?!(\w+\.)*(sentsin.com|layui.com))\b/.test(href.replace(/\s/g, '')); return ''+ (text||href) +''; }) //转义横线 .replace(/\[hr\]\n*/g, '
    ') //转义表格 .replace(/\[table\]([\s\S]*)\[\/table\]\n*/g, function(str){ return str.replace(/\[(thead|th|tbody|tr|td)\]\n*/g, '<$1>') .replace(/\n*\[\/(thead|th|tbody|tr|td)\]\n*/g, '') .replace(/\[table\]\n*/g, '') .replace(/\n*\[\/table\]\n*/g, '
    '); }) //转义 div/span .replace(/\n*\[(div|span)([\s\S]*?)\]([\s\S]*?)\[\/(div|span)\]\n*/g, function(str){ return str.replace(/\[(div|span)([\s\S]*?)\]\n*/g, '<$1 $2>') .replace(/\n*\[\/(div|span)\]\n*/g, ''); }) //转义列表 .replace(/\[ul\]([\s\S]*)\[\/ul\]\n*/g, function(str){ return str.replace(/\[li\]\n*/g, '
  • ') .replace(/\n*\[\/li\]\n*/g, '
  • ') .replace(/\[ul\]\n*/g, ''); }) //转义代码 .replace(/\[pre\]([\s\S]*)\[\/pre\]\n*/g, function(str){ return str.replace(/\[pre\]\n*/g, '
    ')
                          .replace(/\n*\[\/pre\]\n*/g, '
    '); }) //转义引用 .replace(/\[quote\]([\s\S]*)\[\/quote\]\n*/g, function(str){ return str.replace(/\[quote\]\n*/g, '
    ') .replace(/\n*\[\/quote\]\n*/g, '
    '); }) //转义换行 .replace(/\n/g, '
    ') return content; } //新消息通知 ,newmsg: function(){ var elemUser = $('.fly-nav-user'); if(layui.cache.user.uid !== -1 && elemUser[0]){ fly.json('/index/message/nums', { _: new Date().getTime() }, function(res){ if(res.status === 0 && res.count > 0){ var msg = $(''+ res.count +''); elemUser.append(msg); msg.on('click', function(){ fly.json('/message/read', {}, function(res){ if(res.status === 0){ location.href = '/user/message'; } }); }); layer.tips('你有 '+ res.count +' 条未读消息', msg, { tips: 3 ,tipsMore: true ,fixed: true }); msg.on('mouseenter', function(){ layer.closeAll('tips'); }) } }); } return arguments.callee; } //手机绑定弹窗 ,setPhoneNotice: function(){ layer.open({ type: 1 ,id: 'LAY_Notice_add' ,title: '手机号绑定通知' ,content: '
    您需要绑定手机号后,才可进行发帖/回帖等操作。
    ' ,btnAlign: 'c' ,btn: ['立即绑定', '朕偏不!'] ,yes: function(){ location.href = '/user/set' } ,btn2: function(){ layer.msg('少年,我看好你!'); } }); } //邮箱激活提示 ,setEmailNotice: function(){ layer.open({ type: 1 ,id: 'LAY_Notice_add' ,title: '邮箱激活通知' ,content: '
    您需要激活邮箱后,才可进行发帖/回帖等操作。
    ' ,btnAlign: 'c' ,btn: ['前往激活', '朕偏不!'] ,yes: function(){ location.href = '/user/set' } ,btn2: function(){ layer.msg('少年,我看好你!'); } }); } }; //加载扩展模块 layui.config({ base: fly.dir }).extend({ im: 'im' ,face: 'face' }); //头像 if(device.android || device.ios){ $('#LAY_header_avatar').on('click', function(){ return false; }) } //刷新图形验证码 $('body').on('click', '.fly-imagecode', function(){ this.src = '/index/captcha?id='+ new Date().getTime(); }); //头条轮播 if($('#FLY_topline')[0]){ layui.use('carousel', function(){ var carousel = layui.carousel; var ins = carousel.render({ elem: '#FLY_topline' ,width: '100%' ,height: '172px' ,anim: 'fade' }); var resizeTopline = function(){ var width = $(this).prop('innerWidth'); if(width >= 1200){ ins.reload({ height: '172px' }); } else if(width >= 992){ ins.reload({ height: '141px' }); } else if(width >= 768){ ins.reload({ height: '166px' }); } }; resizeTopline() $(window).on('resize', resizeTopline); }); } /* //签到 var tplSignin = ['{{# if(d.signed){ }}' ,'' ,'获得了{{ d.experience }}飞吻' ,'{{# } else { }}' ,'' ,'可获得{{ d.experience }}飞吻' ,'{{# } }}'].join('') ,tplSigninDay = '已连续签到{{ d.days }}天' ,signRender = function(data){ laytpl(tplSignin).render(data, function(html){ elemSigninMain.html(html); }); laytpl(tplSigninDay).render(data, function(html){ elemSigninDays.html(html); }); } ,elemSigninHelp = $('#LAY_signinHelp') ,elemSigninTop = $('#LAY_signinTop') ,elemSigninMain = $('.fly-signin-main') ,elemSigninDays = $('.fly-signin-days'); if(elemSigninMain[0]){ fly.json('/sign/status', function(res){ if(!res.data) return; signRender.token = res.data.token; signRender(res.data); }); } $('body').on('click', '#LAY_signin', function(){ var othis = $(this); if(othis.hasClass(DISABLED)) return; fly.json('/sign/in/', { token: signRender.token || 1 }, function(res){ signRender(res.data); }, { error: function(){ othis.removeClass(DISABLED); } }); othis.addClass(DISABLED); }); //签到说明 elemSigninHelp.on('click', function(){ layer.open({ type: 1 ,title: '签到说明' ,area: '300px' ,shade: 0.8 ,shadeClose: true ,content: ['
    ' ,'
    “签到”可获得社区飞吻,规则如下
    ' ,'' ,'' ,'' ,'' ,'' ,'' ,'' ,'' ,'' ,'' ,'
    连续签到天数每天可获飞吻
    <55
    ≥510
    ≥1515
    ≥3020
    ' ,'' ,'
    '].join('') }); }); //签到活跃榜 var tplSigninTop = ['{{# layui.each(d.data, function(index, item){ }}' ,'
  • ' ,'' ,'' ,'{{item.user.username}}' ,'' ,'{{# var date = new Date(item.time); if(d.index < 2){ }}' ,'签到于 {{ layui.laytpl.digit(date.getHours()) + ":" + layui.laytpl.digit(date.getMinutes()) + ":" + layui.laytpl.digit(date.getSeconds()) }}' ,'{{# } else { }}' ,'已连续签到 {{ item.days }}' ,'{{# } }}' ,'
  • ' ,'{{# }); }}' ,'{{# if(d.data.length === 0) { }}' ,'{{# if(d.index < 2) { }}' ,'
  • 今天还没有人签到
  • ' ,'{{# } else { }}' ,'
  • 还没有签到记录
  • ' ,'{{# } }}' ,'{{# } }}'].join(''); elemSigninTop.on('click', function(){ var loadIndex = layer.load(1, {shade: 0.8}); fly.json('../json/signin.js', function(res){ //实际使用,请将 url 改为真实接口 var tpl = $(['
    ' ,'' ,'
    ' ,'' ,'' ,'' ,'
    ' ,'
    '].join('')) ,signinItems = tpl.find('.layui-tab-item'); layer.close(loadIndex); layui.each(signinItems, function(index, item){ var html = laytpl(tplSigninTop).render({ data: res.data[index] ,index: index }); $(item).html(html); }); layer.open({ type: 1 ,title: '签到活跃榜 - TOP 20' ,area: '300px' ,shade: 0.8 ,shadeClose: true ,id: 'layer-pop-signintop' ,content: tpl.prop('outerHTML') }); }, {type: 'get'}); }); */ //回帖榜 var tplReply = ['{{# layui.each(d.data, function(index, item){ }}' ,'
    ' ,'' ,'' ,'{{item.user.username}}' ,'{{item["count(*)"]}}次回答' ,'' ,'
    ' ,'{{# }); }}'].join('') ,elemReply = $('#LAY_replyRank'); if(elemReply[0]){ fly.json('/index/index/reply', { limit: 20 }, function(res){ var html = laytpl(tplReply).render(res); elemReply.find('dl').html(html); }); }; //相册 if($(window).width() > 750){ layer.photos({ photos: '.photos' ,zIndex: 9999999999 ,anim: -1 }); } else { $('body').on('click', '.photos img', function(){ window.open(this.src); }); } //搜索 $('.fly-search').on('click', function(){ layer.open({ type: 1 ,title: false ,closeBtn: false //,shade: [0.1, '#fff'] ,shadeClose: true ,maxWidth: 10000 ,skin: 'fly-layer-search' ,content: ['
    ' ,'' ,'
    '].join('') ,success: function(layero){ var input = layero.find('input'); input.focus(); layero.find('form').submit(function(){ var val = input.val(); if(val.replace(/\s/g, '') === ''){ return false; } input.val(); }); } }) }); //新消息通知 fly.newmsg(); //发送激活邮件 fly.activate = function(email){ fly.json('/api/activate/', {}, function(res){ if(res.status === 0){ layer.alert('已成功将激活链接发送到了您的邮箱,接受可能会稍有延迟,请注意查收。', { icon: 1 }); }; }); }; $('#LAY-activate').on('click', function(){ fly.activate($(this).attr('email')); }); //点击@ $('body').on('click', '.fly-aite', function(){ var othis = $(this), text = othis.text(); if(othis.attr('href') !== 'javascript:;'){ return; } text = text.replace(/^@|([\s\S]+?)/g, ''); othis.attr({ href: '/index/jump/index?name='+ text ,target: '_blank' }); }); //表单提交 form.on('submit(*)', function(data){ var action = $(data.form).attr('action'), button = $(data.elem); fly.json(action, data.field, function(res){ var end = function(){ if(res.action){ location.href = res.action; } else { fly.form[action||button.attr('key')](data.field, data.form); } }; if(res.status == 0){ button.attr('alert') ? layer.alert(res.msg, { icon: 1, time: 10*1000, end: end }) : end(); }; }); //return false; }); //加载特定模块 if(layui.cache.page && layui.cache.page !== 'index'){ var extend = {}; extend[layui.cache.page] = layui.cache.page; layui.extend(extend); layui.use(layui.cache.page); } //加载IM if(!device.android && !device.ios){ //layui.use('im'); } //加载编辑器 fly.layEditor({ elem: '.fly-editor' }); //手机设备的简单适配 var treeMobile = $('.site-tree-mobile') ,shadeMobile = $('.site-mobile-shade') treeMobile.on('click', function(){ $('body').addClass('site-mobile'); }); shadeMobile.on('click', function(){ $('body').removeClass('site-mobile'); }); //获取统计数据 $('.fly-handles').each(function(){ var othis = $(this); $.get('/api/handle?alias='+ othis.data('alias'), function(res){ othis.html('(下载量:'+ res.number +')'); }) }); //添加文章 $('#add_post').click(function() { if (layui.cache.user.uid !== -1) { loading = layer.load(2, { shade: [0.2, '#000'] }); location.href = '/index/add'; } else { layer.msg('请先登陆',{ icon:5, time:2000 },function () { location.href = '/index/login'; }); } return false; }); //退出登录 $('.logi_logout').click(function() { loading = layer.load(2, { shade: [0.2, '#000'] }); var url = $(this).data('url'); var locationurl = $(this).attr('location-url'); $.getJSON(url, function(data) { if (data.code == 200) { layer.close(loading); layer.msg(data.msg, { icon: 1, time: 1000 }, function() { location.href = locationurl; }); } else { layer.close(loading); layer.msg(data.msg, { icon: 2, anim: 6, time: 1000 }); } }); }); //固定Bar util.fixbar({ bar1: '' ,bgcolor: '#009688' ,click: function(type){ if(type === 'bar1'){ //slayer.msg('打开 index.js,开启发表新帖的路径'); location.href = '/index/add'; } } }); exports('fly', fly); });