;(function () { //全局ajax處理 $.ajaxSetup({ complete: function (jqXHR) {}, data: { }, error: function (jqXHR, textStatus, errorThrown) { //請求失敗處理 } }); if ($.browser.msie) { //ie 都不緩存 $.ajaxSetup({ cache: false }); } //不支持placeholder瀏覽器下對placeholder進行處理 if (document.createElement('input').placeholder !== '') { $('[placeholder]').focus(function () { var input = $(this); if (input.val() == input.attr('placeholder')) { input.val(''); input.removeClass('placeholder'); } }).blur(function () { var input = $(this); if (input.val() == '' || input.val() == input.attr('placeholder')) { input.addClass('placeholder'); input.val(input.attr('placeholder')); } }).blur().parents('form').submit(function () { $(this).find('[placeholder]').each(function () { var input = $(this); if (input.val() == input.attr('placeholder')) { input.val(''); } }); }); } //提交按鈕是否固定底部 //setBtnWrap(); $(window).on('resize', function () { setBtnWrap(true); }); function setBtnWrap(reset) { if (parent.Wind && parent.Wind.art) { //過濾彈窗 return; } if ($('body').height() <= $(window).height()) { $('div.btn_wrap').removeClass('btn_wrap'); } else { if (reset) { var par = $('button.J_ajax_submit_btn:last').parent().parent(); if (!par.attr('class')) { //class必定爲空 par.addClass('btn_wrap'); } } } } //iframe頁面f5刷新 $(document).on('keydown', function (event) { var e = window.event || event; if (e.keyCode == 116) { e.keyCode = 0; var $doc = $(parent.window.document), id = $doc.find('#B_history .current').attr('data-id'), iframe = $doc.find('#iframe_' + id); try{ if (iframe[0].contentWindow) { //common.js reloadPage(iframe[0].contentWindow); } }catch(err){} //!ie return false; } }); //全部加了dialog類名的a連接,自動彈出它的href if ($('a.J_dialog').length) { Wind.use('artDialog', 'iframeTools', function () { $('.J_dialog').on('click', function (e) { e.preventDefault(); var $_this = this, _this = $($_this); art.dialog.open($(this).prop('href'), { close: function () { $_this.focus(); //關閉時讓觸發彈窗的元素獲取焦點 return true; }, title: _this.prop('title') }); }).attr('role', 'button'); }); } //全部的ajax form提交,因爲大多業務邏輯都是同樣的,故統一處理 var ajaxForm_list = $('form.J_ajaxForm'); if (ajaxForm_list.length) { Wind.use('ajaxForm', 'artDialog', function () { if ($.browser.msie) { //ie8及如下,表單中只有一個可見的input:text時,會整個頁面會跳轉提交 ajaxForm_list.on('submit', function (e) { //表單中只有一個可見的input:text時,enter提交無效 e.preventDefault(); }); } $('button.J_ajax_submit_btn').on('click', function (e) { e.preventDefault(); /*var btn = $(this).find('button.J_ajax_submit_btn'), form = $(this);*/ var btn = $(this), form = btn.parents('form.J_ajaxForm'); //批量操做 判斷選項 if (btn.data('subcheck')) { btn.parent().find('span').remove(); if (form.find('input.J_check:checked').length) { var msg = btn.data('msg'); if (msg) { art.dialog({ id: 'warning', icon: 'warning', content: btn.data('msg'), cancelVal: '關閉', cancel: function () { //btn.data('subcheck', false); //btn.click(); }, ok: function () { btn.data('subcheck', false); btn.click(); } }); } else { btn.data('subcheck', false); btn.click(); } } else { $('<div class="tips_error">請至少選擇一項</div>').appendTo(btn.parent()).fadeIn('fast'); } return false; } //ie處理placeholder提交問題 if ($.browser.msie) { form.find('[placeholder]').each(function () { var input = $(this); if (input.val() == input.attr('placeholder')) { input.val(''); } }); } form.ajaxSubmit({ url: btn.data('action') ? btn.data('action') : form.attr('action'), //按鈕上是否自定義提交地址(多按鈕狀況) dataType: 'json', beforeSubmit: function (arr, $form, options) { var text = btn.text(); //按鈕文案、狀態修改 btn.text(text + '中...').prop('disabled', true).addClass('disabled'); }, success: function (data, statusText, xhr, $form) { var text = btn.text(); //按鈕文案、狀態修改 btn.removeClass('disabled').text(text.replace('中...', '')).parent().find('div').remove(); if (data.state === 'success') { $('<div class="tips_success">' + data.info + '</div>').appendTo(btn.parent()).fadeIn('slow').delay(1000).fadeOut(function () { }); } else if (data.state === 'fail') { $('<div class="tips_error">' + data.info + '</div>').appendTo(btn.parent()).fadeIn('fast'); btn.removeProp('disabled').removeClass('disabled'); } if (data.referer) { //返回帶跳轉地址 if(window.parent.art){ //iframe彈出頁 window.parent.location.href = data.referer; }else{ window.location.href = data.referer; } } else { if (data.state === 'success') { if(window.parent.art){ reloadPage(window.parent); }else{ //刷新當前頁 reloadPage(window); } } } } }); }); }); } //dialog彈窗內的關閉方法 $('#J_dialog_close').on('click', function (e) { e.preventDefault(); try{ art.dialog.close(); }catch(err){ Wind.use('artDialog','iframeTools',function(){ art.dialog.close(); }); }; }); //全部的刪除操做,刪除數據後刷新頁面 if ($('a.J_ajax_del').length) { Wind.use('artDialog', function () { $('.J_ajax_del').on('click', function (e) { e.preventDefault(); var $_this = this, $this = $($_this), href = $this.prop('href'), msg = $this.data('msg'); art.dialog({ title: false, icon: 'question', content: '肯定要刪除嗎?', follow: $_this, close: function () { $_this.focus();; //關閉時讓觸發彈窗的元素獲取焦點 return true; }, ok: function () { $.getJSON(href).done(function (data) { if (data.state === 'success') { if (data.referer) { location.href = data.referer; } else { reloadPage(window); } } else if (data.state === 'fail') { //art.dialog.alert(data.info); alert(data.info);//暫時處理方案 } }); }, cancelVal: '關閉', cancel: true }); }); }); } if ($('a.J_ajax_dialog_btn').length) { Wind.use('artDialog', function () { $('.J_ajax_dialog_btn').on('click', function (e) { e.preventDefault(); var $_this = this, $this = $($_this), href = $this.prop('href'), msg = $this.data('msg'); if(!msg){ msg="您肯定要進行此操做嗎?"; } art.dialog({ title: false, icon: 'question', content: msg, follow: $_this, close: function () { $_this.focus();; //關閉時讓觸發彈窗的元素獲取焦點 return true; }, ok: function () { $.getJSON(href).done(function (data) { if (data.state === 'success') { if (data.referer) { location.href = data.referer; } else { reloadPage(window); } } else if (data.state === 'fail') { art.dialog.alert(data.info); } }); }, cancelVal: '關閉', cancel: true }); }); }); } //全部的請求刷新操做 var ajax_refresh = $('a.J_ajax_refresh'), refresh_lock = false; if (ajax_refresh.length) { ajax_refresh.on('click', function (e) { e.preventDefault(); if (refresh_lock) { return false; } refresh_lock = true; $.post(this.href, function (data) { refresh_lock = false; if (data.state === 'success') { if (data.referer) { location.href = data.referer; } else { reloadPage(window); } } else if (data.state === 'fail') { Wind.art.dialog.alert(data.info); } }, 'json'); }); } //拾色器 var color_pick = $('.J_color_pick'); if (color_pick.length) { Wind.use('colorPicker', function () { color_pick.each(function () { $(this).colorPicker({ default_color: 'url("' + GV.DIMAUB + 'statics/images/transparent.png")', //寫死 callback: function (color) { var em = $(this).find('em'), input = $(this).next('.J_hidden_color'); em.css('background', color); input.val(color.length === 7 ? color : ''); } }); }); }); } //字體配置 if ($('.J_font_config').length) { Wind.use('colorPicker', function () { var elem = $('.color_pick'); elem.each(function () { var panel = $(this).parent('.J_font_config'); var bg_elem = $(this).find('.J_bg'); $(this).colorPicker({ default_color: 'url("' + GV.DIMAUB + 'statics/images/transparent.png")', callback: function (color) { bg_elem.css('background', color); panel.find('.case').css('color', color.length === 7 ? color : ''); panel.find('.J_hidden_color').val(color.length === 7 ? color : ''); } }); }); }); //加粗、斜體、下劃線的處理 $('.J_bold,.J_italic,.J_underline').on('click', function () { var panel = $(this).parents('.J_font_config'); var c = $(this).data('class'); if ($(this).prop('checked')) { panel.find('.case').addClass(c); } else { panel.find('.case').removeClass(c); } }); } /*複選框全選(支持多個,縱橫雙控全選)。 *實例:版塊編輯-權限相關(雙控),驗證機制-驗證策略(單控) *說明: * "J_check"的"data-xid"對應其左側"J_check_all"的"data-checklist"; * "J_check"的"data-yid"對應其上方"J_check_all"的"data-checklist"; * 全選框的"data-direction"表明其控制的全選方向(x或y); * "J_check_wrap"同一塊全選操做區域的父標籤class,多個調用考慮 */ if ($('.J_check_wrap').length) { var total_check_all = $('input.J_check_all'); //遍歷全部全選框 $.each(total_check_all, function () { var check_all = $(this), check_items; //分組各縱橫項 var check_all_direction = check_all.data('direction'); check_items = $('input.J_check[data-' + check_all_direction + 'id="' + check_all.data('checklist') + '"]'); //點擊全選框 check_all.change(function (e) { var check_wrap = check_all.parents('.J_check_wrap'); //當前操做區域全部複選框的父標籤(重用考慮) if ($(this).attr('checked')) { //全選狀態 check_items.attr('checked', true); //全部項都被選中 if (check_wrap.find('input.J_check').length === check_wrap.find('input.J_check:checked').length) { check_wrap.find(total_check_all).attr('checked', true); } } else { //非全選狀態 check_items.removeAttr('checked'); //另外一方向的全選框取消全選狀態 var direction_invert = check_all_direction === 'x' ? 'y' : 'x'; check_wrap.find($('input.J_check_all[data-direction="' + direction_invert + '"]')).removeAttr('checked'); } }); //點擊非全選時判斷是否所有勾選 check_items.change(function () { if ($(this).attr('checked')) { if (check_items.filter(':checked').length === check_items.length) { //已選擇和未選擇的複選框數相等 check_all.attr('checked', true); } } else { check_all.removeAttr('checked'); } }); }); } /*li列表添加&刪除(支持多個),實例(「驗證機制-添加驗證問題」,「附件相關-添加附件類型」): <ul id="J_ul_list_verify" class="J_ul_list_public"> <li><input type="text" value="111" ><a class="J_ul_list_remove" href="#">[刪除]</a></li> <li><input type="text" value="111" ><a class="J_ul_list_remove" href="#">[刪除]</a></li> </ul> <a data-related="verify" class="J_ul_list_add" href="#">添加驗證</a> <ul id="J_ul_list_rule" class="J_ul_list_public"> <li><input type="text" value="111" ><a class="J_ul_list_remove" href="#">[刪除]</a></li> <li><input type="text" value="111" ><a class="J_ul_list_remove" href="#">[刪除]</a></li> </ul> <a data-related="rule" class="J_ul_list_add" href="#">添加規則</a> */ var ul_list_add = $('a.J_ul_list_add'); if (ul_list_add.length) { var new_key = 0; //添加 ul_list_add.click(function (e) { e.preventDefault(); new_key++; var $this = $(this); //"new_"字符加上惟一的key值,_li_html 由列具體頁面定義 var $li_html = $(_li_html.replace(/new_/g, 'new_' + new_key)); $('#J_ul_list_' + $this.data('related')).append($li_html); $li_html.find('input.input').first().focus(); }); //刪除 $('ul.J_ul_list_public').on('click', 'a.J_ul_list_remove', function (e) { e.preventDefault(); $(this).parents('li').remove(); }); } //日期選擇器 var dateInput = $("input.J_date") if (dateInput.length) { Wind.use('datePicker', function () { dateInput.datePicker(); }); } //日期+時間選擇器 var dateTimeInput = $("input.J_datetime"); if (dateTimeInput.length) { Wind.use('datePicker', function () { dateTimeInput.datePicker({ time: true }); }); } //圖片上傳預覽 if ($("input.J_upload_preview").length) { Wind.use('uploadPreview', function () { $("input.J_upload_preview").uploadPreview(); }); } //代碼複製 var copy_btn = $('a.J_copy_clipboard'); //複製按鈕 if (copy_btn.length) { Wind.use('dialog', 'textCopy', function () { for (i = 0, len = copy_btn.length; i < len; i++) { var item = $(copy_btn[i]); item.textCopy({ content: $('#' + item.data('rel')).val() }); } }); } //tab var tabs_nav = $('ul.J_tabs_nav'); if (tabs_nav.length) { Wind.use('tabs', function () { tabs_nav.tabs('.J_tabs_contents > div'); }); } //radio切換顯示對應區塊 var radio_change = $('.J_radio_change'); if (radio_change.length) { var radio_c = radio_change.find('input:checked'); if (radio_c.length) { radio_c.each(function () { var $this = $(this); //頁面載入 change($this.data('arr'), $this.parents('.J_radio_change')); }); } //切換radio $('.J_radio_change input:radio').on('change', function () { change($(this).data('arr'), $(this).parents('.J_radio_change')); }); } function change(str, radio_change) { var rel = $(radio_change.data('rel')); if (rel.length) { rel.hide(); } else { $('.J_radio_tbody, .J_radio_change_items').hide(); } if (str) { var arr = new Array(); arr = str.split(","); $.each(arr, function (i, o) { $('#' + o).show(); }); } } /* * 默認頭像 */ var avas = $('img.J_avatar'); if (avas.length) { avatarError(avas); } })(); //從新刷新頁面,使用location.reload()有可能致使從新提交 function reloadPage(win) { var location = win.location; location.href = location.pathname + location.search; } //頁面跳轉 function redirect(url) { location.href = url; } //讀取cookie function getCookie(name) { var nameEQ = name + "="; var ca = document.cookie.split(';'); for (var i = 0; i < ca.length; i++) { var c = ca[i]; while (c.charAt(0) == ' ') { c = c.substring(1, c.length); } if (c.indexOf(nameEQ) == 0) { return c.substring(nameEQ.length, c.length); } }; return null; } //設置cookie function setCookie(name, value, days) { var argc = setCookie.arguments.length; var argv = setCookie.arguments; var secure = (argc > 5) ? argv[5] : false; var expire = new Date(); if(days==null || days==0) days=1; expire.setTime(expire.getTime() + 3600000*24*days); document.cookie = name + "=" + escape(value) + ("; path=/") + ((secure == true) ? "; secure" : "") + ";expires="+expire.toGMTString(); } //浮出提示_居中 function resultTip(options) { var cls = (options.error ? 'warning' : 'success'); var pop = $('<div style="left:50%;top:30%;" class="pop_showmsg_wrap"><span class="pop_showmsg"><span class="' + cls + '">' + options.msg + '</span></span></div>'); pop.appendTo($('body')).fadeIn(function () { pop.css({ marginLeft: -pop.innerWidth() / 2 }); //水平居中 }).delay(1500).fadeOut(function () { pop.remove(); //回調 if (options.callback) { options.callback(); } }); } //彈窗居中定位 非ie6 fixed定位 function popPos(wrap) { var ie6 = false, pos = 'fixed', top, win_height = $(window).height(), wrap_height = wrap.outerHeight(); if ($.browser.msie && $.browser.version < 7) { ie6 = true; pos = 'absolute'; } if (win_height < wrap_height) { top = 0; } else { top = ($(window).height() - wrap.outerHeight()) / 2; } wrap.css({ position: pos, top: top + (ie6 ? $(document).scrollTop() : 0), left: ($(window).width() - wrap.innerWidth()) / 2 }).show(); } /* * 頭像的錯誤處理 */ function avatarError(avatars) { avatars.each(function () { this.onerror = function () { this.onerror = null; this.src = GV.URL.IMAGE_RES + '/face/face_' + $(this).data('type') + '.jpg'; //替代頭像 this.setAttribute('alt', '默認頭像'); //隱藏恢復默認頭像 $('#J_set_def').hide(); } this.src = this.src; }); } //新窗口打開 function openwinx(url,name,w,h) { if(!w) w=screen.width; if(!h) h=screen.height; //window.open(url,name,"top=100,left=400,width=" + w + ",height=" + h + ",toolbar=no,menubar=no,scrollbars=yes,resizable=yes,location=no,status=no"); window.open(url,name); } //詢問 function confirmurl(url, message) { Wind.use("artDialog", "iframeTools", function () { art.dialog.confirm(message, function () { location.href = url; }, function () { art.dialog.tips('你取消了操做'); }); }); } function open_iframe_dialog(url,title,options){ var params={ title: title, lock:true, opacity:0, width:"95%" }; params=options?$.extend(params,options):params; Wind.use('artDialog','iframeTools', function () { art.dialog.open(url, params); }); }