/**
* 用于bootstap框架下提示信息框
* demo:
*
* 模态框
* Modal.confirm({msg: "是否确定提交?"}).on( function (e) {alert("返回结果:" + e);});
* Modal.alert({msg:"该记录已删除!"})
* Modal.process('show'/'hide') 隐藏或显示全屏、进度条
*
* 非模态框
* Message.show({ type : 'S|W|E|I', msg: '提示信息' })
* Message.success('成功信息')
* Message.error('错误信息')
* Message.warn('警告信息')
* Message.info('提示信息')
* Message.warn('警告信息',10000) //10000为显示时长
*/
;$(function() {
window.Modal = function() {
var reg = new RegExp("\\[([^\\[\\]]*?)\\]", 'igm');
var alr = $("#msgAlertDiv");
if (alr.length == 0) {
alr = $('
')
$("body").append(alr);
}
var ahtml = ' '
+ '
'
+ ''
+ '
'
+ '[Message]'
+ '
'
+ '' + '
' + '
';
var _alert = function(options) {
alr.html(ahtml); // 复原
alr.find('.ok').removeClass('btn-success').addClass('btn-primary');
if (vtoy_chrome_app_mode == 0) {
if (document.body.clientHeight > 400) {
alr.find('.modal-dialog').css("top",((document.body.clientHeight - 400) / 2));
}
}
alr.find('.cancel').hide();
_dialog(options);
return {
on : function(callback) {
if (callback && callback instanceof Function) {
alr.find('.ok').click(function() {
callback(true)
});
}
}
};
};
var _confirm = function(options) {
alr.html(ahtml);
alr.find('.ok').removeClass('btn-primary').addClass('btn-success');
alr.find('.cancel').show();
if (vtoy_chrome_app_mode == 0) {
if (document.body.clientHeight > 400) {
alr.find('.modal-dialog').css("top",((document.body.clientHeight - 400) / 2));
}
}
_dialog(options);
return {
on : function(callback) {
if (callback && callback instanceof Function) {
alr.find('.ok').click(function() {
callback(true);
});
alr.find('.cancel').click(function() {
callback(false);
});
alr.find('.userDefiend').click(function() {
callback("userDefiend");
});
}
}
};
};
var _dialog = function(options) {
var ops = {
msg : "提示内容",
title : "操作提示",
btnok : "确定",
btncl : "取消",
userDefined : ""
};
$.extend(ops, options);
var html = alr.html().replace(reg, function(node, key) {
return {
Title : ops.title,
Message : ops.msg,
BtnOk : ops.btnok,
BtnCancel : ops.btncl,
UserDefined : ops.userDefined
}[key];
});
alr.html(html);
alr.modal({
width : 500,
backdrop : 'static'
});
}
var _process = function(showOrHide,time) {
var defaultTime = 100;
if($.isNumeric(time)) {
defaultTime = time;
}
var $proc;
$proc = $("#vtoy_proc");
if('hide' === showOrHide) {
$proc.remove();
} else if ('show' === showOrHide) {
if($proc.length == 1) {
return;
}
$(document).find(":focus").blur();
$proc = $('');
$("body").append($proc);
setTimeout(function() {
$proc.replaceWith('');
}, $.isNumeric(time) ? time : 100);
} else {
alert("Modal.process参数必须为show/hide");
}
}
return {
alert : _alert,
confirm : _confirm,
process : _process
}
}();
window.Message = function() {
var _showMsg = function(type, msg, time) {
var o = {type : type, msg : msg };
if(time) {
o.time = time;
}
_show(o);
}
var _show = function(options) {
var ops = {
msg : "提示内容",
type: 'S',
time: 3000
};
$.extend(ops, options);
var msg_class = 'alert-success';
if('S' === ops.type || 's' === ops.type) {
msg_class = 'alert-success';
} else if ('E' === ops.type || 'e' === ops.type) {
msg_class = 'alert-danger';
} else if ('W' === ops.type || 'w' === ops.type) {
msg_class = 'alert-warning';
} else if ('I' === ops.type || 'i' === ops.type) {
msg_class = 'alert-info';
} else {
alert("未知的类型,请使用: w-警告;s-成功;e-失败;i-提示");
return;
}
var $messageContainer = $("#fcss_message");
if($messageContainer.length === 0) {
$messageContainer = $('');
$messageContainer.appendTo($('body'));
}
var $div = $('');
var $btn = $('');
$div.append($btn).append(ops.msg).appendTo($messageContainer);
setTimeout(function() {
$div.remove();
}, ops.time);
}
var _success = function(msg, time) {
_showMsg('s', msg, time);
}
var _error = function(msg, time) {
_showMsg('e', msg, time || 6000);
}
var _warn = function(msg, time) {
_showMsg('w', msg, time);
}
var _info = function(msg, time) {
_showMsg('i', msg, time);
}
return {
success : _success,
error : _error,
warn : _warn,
info : _info,
show : _show
}
}();
});