mirror of
https://github.com/JamesonHuang/OpenWrt_Luci_Lua.git
synced 2024-11-27 23:40:10 +00:00
661 lines
24 KiB
HTML
661 lines
24 KiB
HTML
<%
|
||
local ver = require("xiaoqiang.XQVersion").webVersion
|
||
local cryptoUtil = require("xiaoqiang.util.XQCryptoUtil")
|
||
local XQSysUtil = require ("xiaoqiang.util.XQSysUtil")
|
||
local http = require ("luci.http")
|
||
local secretKey = "Ep9]B28z3!3D66*3CF_18663"
|
||
local routerName = XQSysUtil.getRouterName() or "miwifi"
|
||
local XQConfigs = require("xiaoqiang.common.XQConfigs")
|
||
local cmd = XQConfigs.THRIFT_TO_MQTT_GET_DEVICEID
|
||
local LuciUtil = require("luci.util")
|
||
local deviceId = LuciUtil.exec(cmd)
|
||
local from = "xiaomi_router"
|
||
local sign = cryptoUtil.md5Str(deviceId .. from .. routerName .. secretKey)
|
||
local xunleiurl = string.format("http://dynamic.i.xunlei.com/device_binding/entrance.php?deviceId=%s&from=%s&name=%s&sign=%s", http.urlencode(deviceId), http.urlencode(from), http.urlencode(routerName), http.urlencode(sign))
|
||
%>
|
||
<%include ("web/inc/head")%>
|
||
<title>应用管理 - 小米路由器</title>
|
||
<link rel="stylesheet" href="<%=resource%>/web/css/page.plugin.css?v=<%=ver%>">
|
||
</head>
|
||
<body>
|
||
<div id="doc" class="hidden">
|
||
<%include ("web/inc/header")%>
|
||
<!-- -->
|
||
<div id="nav">
|
||
<script>
|
||
var navCurrent = '.plugin';
|
||
</script>
|
||
<%include ("web/inc/nav")%>
|
||
</div>
|
||
<!-- -->
|
||
<div id="bd" class="dft">
|
||
<div id="bd-hd">在这里,你可以很便捷的安装一些别出心裁的应用功能。</div>
|
||
<div class="mod-first-bind" style="display:none">
|
||
<div class="hd">
|
||
你现在处于管理密码登录状态,管理应用需要用小米账号绑定路由器并登录,是否登录?
|
||
</div>
|
||
<div class="bd">
|
||
|
||
</div>
|
||
</div>
|
||
<div class="mod-xiaomi-login" style="display:none">
|
||
<div class="hd">
|
||
你现在处于管理密码登录状态,管理应用需要用小米账号登录,是否登录?
|
||
</div>
|
||
<div class="bd">
|
||
<form action="/" class="form form-horizontal" method="post" name="xiaomilogin" id="xiaomilogin">
|
||
<div class="item">
|
||
<label class="k">小米账号:</label>
|
||
<span class="v"><input type="text" name="uuid" class="text input-large"></span>
|
||
<em class="t"></em>
|
||
</div>
|
||
<div class="item">
|
||
<label class="k">密码:</label>
|
||
<span class="v"><input type="password" name="password" class="text input-large" placeholder="请输入密码"></span>
|
||
<em class="t"></em>
|
||
</div>
|
||
<div class="item item-control">
|
||
<button type="submit" id="btnXmSubmit" class="btn btn-primary l"><span>登录</span></button>
|
||
<a target="_blank" href="https://account.xiaomi.com/pass/forgetPassword" class="r">忘记密码?</a>
|
||
</div>
|
||
</form>
|
||
</div>
|
||
</div>
|
||
<div class="mod-plugin" style="display:none">
|
||
<div class="tab-nav">
|
||
<ul class="clearfix tab-0">
|
||
<li class="active">已安装应用</li>
|
||
<li>全部应用</li>
|
||
</ul>
|
||
</div>
|
||
<div class="loading">应用努力加载中,请稍候...</div>
|
||
<div class="tab-content" style="display:none;">
|
||
<div class="tab-panel active">
|
||
<div class="mod-plugin-list">
|
||
<ul class="list" id="installed"></ul>
|
||
</div>
|
||
</div>
|
||
<div class="tab-panel">
|
||
<div class="mod-plugin-list">
|
||
<ul class="list" id="allplugin"></ul>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
<%include ("web/inc/footer")%>
|
||
</div>
|
||
<div class="panel-plugin-mask"></div>
|
||
<div class="panel-plugin" style="display:none;">
|
||
<div class="panel-content">
|
||
|
||
</div>
|
||
<span class="close"></span>
|
||
</div>
|
||
<script type="tmpl/html" id="tmplappitem">
|
||
<li class="item" data-id="{$id}" data-installed="{$status}">
|
||
<div class="icon"><img class="appthumb" src="{$icon}" /></div>
|
||
<span class="icon-sd"></span>
|
||
<p class="name">{$name}</p>
|
||
{$installed}
|
||
</li>
|
||
</script>
|
||
<script type="tmpl/html" id="tmplappdetail">
|
||
<div class="hd">
|
||
<img class="appthumbbig" width="100%" src="{$icon_for_detail}">
|
||
</div>
|
||
<div class="bd{$bdtype}">
|
||
<div class="info">
|
||
<dl class="info-base">
|
||
<dt>开发者:</dt>
|
||
<dd>{$developer}</dd>
|
||
<dt>版本: </dt>
|
||
<dd>{$version}</dd>
|
||
</dl>
|
||
<dl class="info-detail">
|
||
<dt>功能介绍:</dt>
|
||
<dd>{$introduction}</dd>
|
||
</dl>
|
||
</div>
|
||
{$extra}
|
||
{$iframe}
|
||
</div>
|
||
{$footer}
|
||
</script>
|
||
<%include ("web/inc/g.js.base")%>
|
||
<script>
|
||
global_event.needBind = true;
|
||
global_event.mustBind = true;
|
||
</script>
|
||
<%include ("web/inc/g.js")%>
|
||
<script>
|
||
$(global_event).on('plugin:init',function(evt, data){
|
||
$('.mod-plugin').show();
|
||
$(global_event).trigger('plugin:getlist');
|
||
var pluginTabView = (function(){
|
||
var root = $('.mod-plugin')[0],
|
||
tabNavitem = $('.tab-nav li', root),
|
||
tabNavlist = $('.tab-nav ul', root),
|
||
tabConitem = $('.tab-panel', root),
|
||
switchto = function(id){
|
||
id = parseInt(id, 10);
|
||
tabNavitem.removeClass('active');
|
||
tabNavitem.eq(id).addClass('active');
|
||
tabNavlist[0].className = 'clearfix tab-' + id;
|
||
tabConitem.removeClass('active');
|
||
tabConitem.eq(id).addClass('active');
|
||
};
|
||
tabNavitem.on('click', function(e){
|
||
e.preventDefault();
|
||
var idx = $(this).index();
|
||
switchto(idx);
|
||
});
|
||
return {
|
||
switchto: switchto
|
||
};
|
||
}());
|
||
function Pluginpanel(option){
|
||
option = option || {};
|
||
this.panel = $('.panel-plugin');
|
||
this.mask = $('.panel-plugin-mask');
|
||
this.content = this.panel.find('.panel-content');
|
||
this.elclose = $('.panel-plugin .close');
|
||
this.onclose = option.onclose || function(){};
|
||
this.onopen = option.onopen || function(){};
|
||
this.init();
|
||
};
|
||
Pluginpanel.prototype.updatepos = function() {
|
||
var fwt = $(window).width(),
|
||
fht = $(document).height(),
|
||
panelHeight = this.panel.outerHeight();
|
||
this.mask.css({height:fht});
|
||
this.panel.css({'margin-top':(-panelHeight/2)});
|
||
return this;
|
||
};
|
||
Pluginpanel.prototype.open = function(){
|
||
var that = this;
|
||
this.mask.show();
|
||
this.panel.css({
|
||
visibility:'visible',
|
||
top:0,
|
||
opacity: 0
|
||
}).show();
|
||
this.panel.animate({
|
||
opacity: 1,
|
||
top: "50%"
|
||
}, 500, function(){
|
||
that.onopen();
|
||
});
|
||
};
|
||
Pluginpanel.prototype.close = function(){
|
||
this.panel.hide();
|
||
this.mask.hide();
|
||
this.onclose();
|
||
};
|
||
Pluginpanel.prototype.bindClose = function(){
|
||
var self = this;
|
||
this.elclose.on('click', function(e){
|
||
e.preventDefault();
|
||
self.close();
|
||
});
|
||
$(document).on('keydown', function(e){
|
||
if (e.keyCode == 27) {
|
||
self.close();
|
||
}
|
||
});
|
||
};
|
||
Pluginpanel.prototype.bindResize = function(){
|
||
var self = this,
|
||
timer;
|
||
$(window).on('resize', function(){
|
||
window.clearTimeout(timer);
|
||
window.setTimeout(function(){
|
||
self.updatepos();
|
||
},400);
|
||
});
|
||
};
|
||
Pluginpanel.prototype.setContent = function(content){
|
||
this.content.html(content);
|
||
return this;
|
||
};
|
||
Pluginpanel.prototype.init = function(){
|
||
this.panel.css({display:'block',visibility:'hidden'});
|
||
this.updatepos();
|
||
this.bindClose();
|
||
this.bindResize();
|
||
return this;
|
||
};
|
||
|
||
$('.mod-plugin-list').delegate('.item', 'click', function(e){
|
||
e.preventDefault();
|
||
var id = $(this).attr('data-id');
|
||
var status = $(this).attr('data-installed');
|
||
$(global_event).trigger('plugin:getdetail', {
|
||
id : id,
|
||
status : status,
|
||
cb : function(content, onopen, onclose){
|
||
onopen = onopen || function(){
|
||
console.log('open plugin');
|
||
};
|
||
onclose = onclose || function(){
|
||
console.log('close plugin');
|
||
};
|
||
var panel = new Pluginpanel({
|
||
onclose: onclose,
|
||
onopen: onopen
|
||
});
|
||
panel.setContent(content).updatepos().open();
|
||
global_event.pluginPanel = panel;
|
||
}
|
||
});
|
||
});
|
||
|
||
$('.panel-plugin').delegate('.btn-install', 'click', function(e){
|
||
e.preventDefault();
|
||
var id = $(this).attr('data-id');
|
||
$(global_event).trigger('plugin:enable', {id : id});
|
||
});
|
||
|
||
$('.panel-plugin').delegate('.btn-uninstall', 'click', function(e){
|
||
e.preventDefault();
|
||
var id = $(this).attr('data-id');
|
||
art.dialog({
|
||
width: 400,
|
||
title: '卸载应用',
|
||
content: '你确定要卸载这个应用吗?',
|
||
ok: function(){
|
||
$(global_event).trigger('plugin:disable', {id : id});
|
||
},
|
||
okValue: '确定',
|
||
cancel: function(){
|
||
this.close();
|
||
},
|
||
cancelValue: '取消'
|
||
});
|
||
});
|
||
});
|
||
|
||
$(global_event).on('plugin:getlist', function(evt, data){
|
||
$('.mod-plugin .loading').show();
|
||
$('.mod-plugin .tab-content').hide();
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport","plugin_list")%>', function(rsp){
|
||
var tpl = $('#tmplappitem').html();
|
||
if (rsp.code == 0) {
|
||
var installed = rsp.list.installed;
|
||
var available = rsp.list.available;
|
||
var domInstalled = [];
|
||
var domAvailable = [];
|
||
if ($.isArray(installed) && installed.length > 0) {
|
||
for (var i = 0; i < installed.length; i++) {
|
||
var item = StringH.tmpl(tpl,{
|
||
id : installed[i].id,
|
||
icon : installed[i].iconForList,
|
||
name : installed[i].name,
|
||
installed : '<i class="installed"></i>',
|
||
status : 1
|
||
});
|
||
domInstalled.push(item);
|
||
};
|
||
}
|
||
if ($.isArray(available) && available.length > 0) {
|
||
for (var i = 0; i < available.length; i++) {
|
||
var item = StringH.tmpl(tpl,{
|
||
id : available[i].id,
|
||
icon : available[i].iconForList,
|
||
name : available[i].name,
|
||
installed : '',
|
||
status : 0
|
||
});
|
||
domAvailable.push(item);
|
||
};
|
||
}
|
||
$('#allplugin').html(domInstalled.join('')+domAvailable.join(''));
|
||
$('#installed').html(domInstalled.join(''));
|
||
|
||
$('.appthumb').on('error', function(){
|
||
this.src = '<%=resource%>/web/img/v2/plugin_card_loading.png';
|
||
});
|
||
$('.mod-plugin .loading').fadeOut(400, function(){
|
||
$('.mod-plugin .tab-content').show();
|
||
});
|
||
}else{
|
||
$('.mod-plugin .loading').html('网络繁忙,请刷新页面重试。');
|
||
}
|
||
});
|
||
});
|
||
|
||
$(global_event).on('plugin:getdetail', function(evt, data){
|
||
var installed = data.status == 1;
|
||
var callback = data.cb;
|
||
var dlgLoading = art.dialog({
|
||
title: false,
|
||
width: 200,
|
||
content: '<p style="padding:30px;">努力加载中...</p>',
|
||
cancel: false
|
||
}).lock();
|
||
var pluginMap = {
|
||
'6': '<%=luci.dispatcher.build_url("web", "plugin","kuaipan")%>',
|
||
'7': '<%=xunleiurl%>',
|
||
'8': '<%=luci.dispatcher.build_url("web", "plugin", "guest")%>'
|
||
};
|
||
var isExtra = function(id){
|
||
var ret = false;
|
||
for(k in pluginMap){
|
||
if (id == k) {
|
||
ret = true;
|
||
break;
|
||
}
|
||
}
|
||
return ret;
|
||
};
|
||
var buildAppUrl = function(id){
|
||
var url = pluginMap[id];
|
||
var dom = '<p class="loadfrm" style="padding:30px; text-align:center;">Loading...</p><iframe style="width:100%; border:0; background:none; display:none;" frameborder="0" scrolling="no" data-src="'+ url +'" src="about:blank"></iframe>';
|
||
return dom;
|
||
};
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport","plugin_detail")%>', {
|
||
pluginId : data.id
|
||
}, function(rsp){
|
||
var tpl = $('#tmplappdetail').html();
|
||
if (rsp.code == 0) {
|
||
var action = '<div class="ft"><a href="#" class="btn btn-block btn-install" data-id="'+rsp.detail.id+'"><span>安装应用</span></a></div>';
|
||
var status = '未启用';
|
||
if (installed) {
|
||
action = '<div class="btn-uninstall" data-id="'+rsp.detail.id+'"><a href="#"></a></div>';
|
||
status = '启用';
|
||
if ( /(6|7|8)/.test(rsp.detail.id) ) {
|
||
action = '';
|
||
}
|
||
}
|
||
//内置插件,WPS快连
|
||
var extra = '';
|
||
if (rsp.detail.id == 5 && installed) {
|
||
extra = '<div class="plugin-wps"><span id="btn-wps">快连</span><p class="ret"></p></div>';
|
||
$(global_event).trigger('plugin:wpsOpen');
|
||
}
|
||
//外接插件,iframe引入。
|
||
var bdtype = '';
|
||
var iframe = '';
|
||
if (isExtra(rsp.detail.id) && installed) {
|
||
bdtype = ' iframe';
|
||
iframe = buildAppUrl(rsp.detail.id);
|
||
}
|
||
var dom = StringH.tmpl(tpl,{
|
||
id : rsp.detail.id,
|
||
name : rsp.detail.name,
|
||
version : rsp.detail.version,
|
||
introduction : rsp.detail.introduction,
|
||
developer : rsp.detail.developer,
|
||
icon_for_detail : rsp.detail.iconForDetail,
|
||
status : status,
|
||
footer : action,
|
||
extra : extra,
|
||
bdtype : bdtype,
|
||
iframe : iframe
|
||
});
|
||
$('.appthumbbig').on('error', function(){
|
||
this.src = '<%=resource%>/web/img/v2/plugin_detail_miui_bg.jpg';
|
||
});
|
||
callback(dom, function(){
|
||
if($(".panel-plugin").has(".iframe").length){
|
||
var ifm = $('.panel-plugin .iframe iframe'),
|
||
loadding = $('.panel-plugin .iframe .loadfrm');
|
||
src = ifm.attr('data-src');
|
||
ifm.attr('src', src);
|
||
ifm.on('load', function(){
|
||
loadding.fadeOut(function(){
|
||
ifm.show();
|
||
});
|
||
});
|
||
}
|
||
});
|
||
dlgLoading.close();
|
||
}else{
|
||
dlgLoading.content(rsp.msg).time(1.5 * 1000);
|
||
}
|
||
});
|
||
});
|
||
$(global_event).on('plugin:enable', function(evt, data){
|
||
$('.btn-install').prop('disable', true).html('<span>安装中,请稍候...</span>');
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport","plugin_enable")%>', {
|
||
pluginId : data.id
|
||
}, function(rsp){
|
||
var tpl = $('#tmplappitem').html();
|
||
if (rsp.code == 0) {
|
||
$('.btn-install').prop('disable', false).html('<span>安装应用成功</span>');
|
||
global_event.pluginPanel.close();
|
||
setTimeout(function(){
|
||
$(global_event).trigger('plugin:getlist');
|
||
}, 300);
|
||
}else{
|
||
$('.btn-install').prop('disable', false).html('<span>安装应用失败,请重试</span>');
|
||
}
|
||
|
||
});
|
||
});
|
||
$(global_event).on('plugin:disable', function(evt, data){
|
||
// $('.btn-uninstall').prop('disable', true).html('卸载中,请稍候...');
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport","plugin_disable")%>', {
|
||
pluginId : data.id
|
||
}, function(rsp){
|
||
var tpl = $('#tmplappitem').html();
|
||
if (rsp.code == 0) {
|
||
// $('.btn-uninstall').prop('disable', false).html('卸载应用成功');
|
||
global_event.pluginPanel.close();
|
||
setTimeout(function(){
|
||
$(global_event).trigger('plugin:getlist');
|
||
}, 300);
|
||
}else{
|
||
// $('.btn-uninstall').prop('disable', false).html('卸载应用失败,请重试');
|
||
}
|
||
|
||
});
|
||
});
|
||
|
||
$(global_event).on('plugin:wpsOpen', function(evt, data){
|
||
|
||
global_event.wpsOpened = false;
|
||
var wpsTimeout = 2 * 60,
|
||
timer,
|
||
wpsStart = function(){
|
||
var btn = $('#btn-wps'),
|
||
ret = $('.plugin-wps .ret');
|
||
btn.html('连接中...');
|
||
ret.html('正在搜索设备...');
|
||
btn[0].className = 'disabled';
|
||
btn.prop('disable', true);
|
||
},
|
||
wpsFail = function(){
|
||
var btn = $('#btn-wps'),
|
||
ret = $('.plugin-wps .ret');
|
||
btn.html('重新连接');
|
||
ret.html('开启时间内没有连接到任何设备');
|
||
btn[0].className = '';
|
||
btn.prop('disable', false);
|
||
global_event.wpsOpened = false;
|
||
},
|
||
wpsDone = function(){
|
||
var btn = $('#btn-wps'),
|
||
ret = $('.plugin-wps .ret');
|
||
btn.html('连接成功');
|
||
|
||
btn[0].className = 'success';
|
||
btn.prop('disable', false);
|
||
ret.html('已连接到你的设备');
|
||
global_event.wpsOpened = false;
|
||
};
|
||
|
||
$('body').delegate('#btn-wps', 'click', function(e){
|
||
e.preventDefault();
|
||
//已经开启WPS
|
||
if (global_event.wpsOpened) {
|
||
return;
|
||
}
|
||
if (/(success|disabled)/.test(this.className)) {
|
||
return;
|
||
}
|
||
|
||
wpsStart();
|
||
//open wps
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqsystem", "wps")%>', {}, function(rsp){
|
||
if (rsp.code == 0) {
|
||
global_event.wpsOpened = true;
|
||
// get wps status
|
||
window.clearInterval(timer);
|
||
timer = window.setInterval(function(){
|
||
getStatus();
|
||
}, 5 * 1000);
|
||
}else{
|
||
wpsFail();
|
||
}
|
||
});
|
||
});
|
||
|
||
function getStatus(){
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqsystem", "wps_status")%>', {}, function(rsp){
|
||
if (rsp.code == 0) {
|
||
console.log(rsp);
|
||
//Connected
|
||
if (rsp.status == 2) {
|
||
window.clearInterval(timer);
|
||
wpsDone();
|
||
return;
|
||
}
|
||
// Timeout
|
||
if ( (rsp.currentTime - rsp.startTime > wpsTimeout) || rsp.status == 4 ) {
|
||
window.clearInterval(timer);
|
||
wpsFail();
|
||
return;
|
||
}
|
||
}else{
|
||
window.clearInterval(timer);
|
||
$('.plugin-wps .ret').html(rsp.msg);
|
||
wpsFail();
|
||
}
|
||
});
|
||
}
|
||
});
|
||
|
||
$(global_event).on('plugin:xmbind', function(){
|
||
var dlgContent = $('#xiaomibind').html();
|
||
$('.mod-first-bind .bd').html(dlgContent);
|
||
$('.mod-first-bind').show();
|
||
$('body').delegate('#xiaomipsp', 'submit', function(e){
|
||
e.preventDefault();
|
||
var that = this;
|
||
var frm = this.name;
|
||
var url = '<%=luci.dispatcher.build_url("api", "xqpassport","login")%>';
|
||
var btnText = $('#btnBindXiaomi span').html();
|
||
var validator = FormValidator.checkAll(frm, [{
|
||
name: 'uuid',
|
||
display :'小米账号',
|
||
rules: 'required'
|
||
},{
|
||
name: 'password',
|
||
display :'密码',
|
||
rules: 'required'
|
||
}]);
|
||
if (validator) {
|
||
var pwd = $.trim($('#xmpassword').val()),
|
||
data = {
|
||
'uuid': $.trim($('#xmuuid').val()),
|
||
'password': hex_md5(pwd),
|
||
'encrypt': Base64.encode(pwd)
|
||
};
|
||
$('#btnBindXiaomi').prop('disabled', true).find('span').html('登录中...');
|
||
$.ajax({
|
||
type:'post',
|
||
url: url,
|
||
data: data,
|
||
dataType : 'json',
|
||
success : function(rsp){
|
||
if (rsp.code == 0) {
|
||
$('#btnBindXiaomi').find('span').html('绑定中...');
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport", "rigister")%>',{uuid:rsp.uuid}, function(rsp){
|
||
if (rsp.code == 0) {
|
||
$('#btnBindXiaomi').find('span').html('绑定成功');
|
||
window.location.reload();
|
||
}else{
|
||
$('#btnBindXiaomi').prop('disabled', false).find('span').html(btnText);
|
||
$('.item-rsp-err', that).show().addClass('item-err');
|
||
$('.item-rsp-err', that).find('.t').html(rsp.msg).show();
|
||
}
|
||
});
|
||
}else{
|
||
$('#btnBindXiaomi').prop('disabled', false).find('span').html(btnText);
|
||
$('.item-rsp-err', that).show().addClass('item-err');
|
||
$('.item-rsp-err', that).find('.t').html(rsp.msg).show();
|
||
}
|
||
}
|
||
});
|
||
}
|
||
});
|
||
});
|
||
|
||
$(global_event).on('plugin:xmlogin', function(){
|
||
$.getJSON('<%=luci.dispatcher.build_url("api", "xqpassport","binded")%>',{},function(rsp){
|
||
if (rsp.code == 0) {
|
||
$('.mod-xiaomi-login input[name=uuid]').val(rsp.info.userId).prop('readOnly', true);
|
||
}
|
||
$('.mod-xiaomi-login').show();
|
||
}).fail(function() {
|
||
$('.mod-xiaomi-login').show();
|
||
});
|
||
$('#xiaomilogin').on('submit',function(e){
|
||
e.preventDefault();
|
||
var that = this;
|
||
var frm = this.name;
|
||
var url = '<%=luci.dispatcher.build_url("api", "xqpassport","login")%>';
|
||
var validator = FormValidator.checkAll(frm, [{
|
||
name: 'uuid',
|
||
display :'账号',
|
||
rules: 'required'
|
||
},{
|
||
name: 'password',
|
||
display :'密码',
|
||
rules: 'required'
|
||
}]);
|
||
if (validator) {
|
||
$('#btnXmSubmit').prop('disabled', true).find('span').html('登录中...');
|
||
var data = {
|
||
'uuid' : $.trim($('input[name=uuid]').val()),
|
||
'password' : hex_md5($.trim($('input[name=password]').val()))
|
||
};
|
||
$.ajax({
|
||
type:'post',
|
||
url: url,
|
||
data:data,
|
||
dataType : 'json',
|
||
success : function(rsp){
|
||
if (rsp.code == 0) {
|
||
window.location.reload(1);
|
||
}else{
|
||
var errMsg = '密码错误请检查并重试';
|
||
if (rsp.code == 1551) {
|
||
errMsg = '网络繁忙,权限查询失败,请重试';
|
||
}
|
||
$('.item', that).eq(1).addClass('item-err').find('.t').html(errMsg).show();
|
||
}
|
||
$('#btnXmSubmit').prop('disabled', false).find('span').html('登录');
|
||
}
|
||
});
|
||
}
|
||
});
|
||
});
|
||
|
||
$(function(){
|
||
var psp = global_event.pspGet();
|
||
var logtype = psp.logtype;
|
||
if ( global_event.isBinded ) {
|
||
if (logtype == 1) {
|
||
$(global_event).trigger('plugin:init');
|
||
}else{
|
||
$(global_event).trigger('plugin:xmlogin');
|
||
}
|
||
}else{
|
||
$(global_event).trigger('plugin:xmbind');
|
||
}
|
||
});
|
||
</script>
|
||
</body>
|
||
</html> |