1
0
mirror of https://shylinux.com/x/volcanos synced 2025-04-25 08:48:06 +08:00

opt misc.js

This commit is contained in:
shylinux 2020-02-21 03:02:56 +08:00
parent 786e786089
commit adc9ebbf9d
4 changed files with 57 additions and 69 deletions

View File

@ -36,10 +36,14 @@ var can = Volcanos("chat", {
Export: function(event, value, key) {can.Report(event, value, key)},
Import: function(event, value, key) {var cb = pane.onimport[key];
// 导入数据
typeof cb == "function" && cb(event, pane, value, key, pane.output);
// 分发数据
can.core.List(pane._plugins, function(item) {item.Import(event, value, key)})
// 导入数据
pane.page.Select(pane, pane.action, "input."+key, function(item) {item.value = value})
},
Action: function(key, value) {
return can.page.Select(can, pane.action, "input[name="+key+"],select."+key+",select[name="+key+"]", function(item) {
value != undefined && (item.value = value), value = item.value
@ -120,9 +124,26 @@ var can = Volcanos("chat", {
Inputs: can.Inputs, Output: can.Output,
Import: function(event, value, key) {var cb = plugin.onimport[key];
// 导入数据
typeof cb == "function" && cb(event, plugin, value, key, plugin.output);
// 下发数据
key && plugin[key] && plugin[key].target && plugin[key].Import(event, value, key)
},
Report: function(event, value, key, index) {
// 导入数据
plugin.Import(event, value, key)
for (var i = 0; i < exports.length; i += 3) {
if (exports[i+1] == key) {key = exports[i]
if (exports[i+2]) {var cb = plugin.onexport[exports[i+2]], res;
// 数据转换
value = typeof cb == "function" && ((res = cb(event, plugin, plugin.msg, value, key, index)) != undefined) && res || value;
}
// 上报数据
key && can.Import(event, value, key)
}
}
},
Share: function(event) {
can.user.input(event, can, ["name", "text"], function(event, cmd, meta, list) {
@ -161,17 +182,6 @@ var can = Volcanos("chat", {
return key != undefined? option[key] && option[key].value || "":
plugin.page.Select(can, option, ".args", function(item) {return item.value})
},
Report: function(event, value, key, index) {
key && plugin[key] && plugin[key].target && plugin[key].Import(event, value, key, index)
for (var i = 0; i < exports.length; i += 3) {
if (exports[i+1] == key) {key = exports[i]
if (exports[i+2]) {var cb = plugin.onexport[exports[i+2]], res;
value = typeof cb == "function" && ((res = cb(event, plugin, plugin.msg, value, key, index)) != undefined) && res || value;
}
key && can.Import(event, value, key)
}
}
},
Check: function(event, target, cb) {
plugin.page.Select(can, option, ".args", function(item, index, list) {
if (item == target && index < list.length-1) {can._plugin && can._plugin.target == field && list[index+1].focus(); return item}

View File

@ -1,101 +1,76 @@
Volcanos("misc", {help: "工具模块",
POST: shy("请求后端", {order: 0}, function(can, msg, url, form, cb) {
var xhr = new XMLHttpRequest()
xhr.onreadystatechange = function() {
var xhr = new XMLHttpRequest();
xhr.open("POST", url), xhr.onreadystatechange = function() {
if (xhr.readyState != 4) {return}
if (xhr.status != 200) {return}
try {
var res = JSON.parse(xhr.responseText||'[{"result":[]}]')
res.length > 0 && res[0] && (res = res[0])
if (res.download_file) {
window.open(res.download_file.join(""))
} else if (res.page_redirect) {
location.href = res.page_redirect.join("")
} else if (res.page_refresh) {
location.reload()
}
try { // 解析响应
var res = JSON.parse(xhr.responseText);
} catch (e) {
var res = {"result": [xhr.responseText]}
}
typeof cb == "function" && cb(msg.Copy(res))
xhr.status == 200 && typeof cb == "function" && cb(msg.Copy(res));
}
xhr.open("POST", url)
if (msg.upload) {
var data = new FormData()
// 文件参数
var data = new FormData();
can.core.Item(form, function(key, value) {
can.core.List(value, function(item) {
data.append(key, item)
can.core.List(value, function(item) {data.append(key, item)});
})
})
data.append("upload", msg.upload)
data.append("upload", msg.upload);
} else {
var args = can.core.Items(form, function(value, index, key) {
// 表单参数
var data = can.core.Items(form, function(value, index, key) {
return key+"="+encodeURIComponent(value)
})
var data = args.join("&")
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded")
}).join("&");
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
}
// 发送请求
++arguments.callee.meta.order
xhr.setRequestHeader("Accept", "application/json")
xhr.send(data)
++arguments.callee.meta.order
}),
Run: shy("请求后端", {order: 0}, function(event, can, dataset, cmd, cb) {
var msg = can.Event(event)
var msg = can.Event(event);
// 解析参数
var option = {"cmds": cmd||msg.cmd}
msg.option && msg.option.forEach(function(item) {
msg[item] && (option[item] = msg[item])
})
// for (var k in dataset) {
// option[k] = dataset[k].toLowerCase().split(",")
// }
msg.option = can.core.Item(option, function(key, value) {
return msg[key] = value, key
})
var what = ++arguments.callee.meta.order
msg._hand = true
msg.option = []
for (var k in option) {
msg.option.push(k)
msg[k] = option[k]
}
// msg.detail = ["run", what].concat(option.group).concat(option.names).concat(option.cmds)
// kit.Log(msg.detail.concat([msg]))
//
//
// kit.History("run", -1, option)
this.POST(can, msg, can.Conf("iceberg")+(dataset.names||msg.names).toLowerCase(), option, function(msg) {
// kit.Log("run", what, "result", msg.result? msg.result[0]: "", msg)
msg._hand = true, can.misc.POST(can, msg, can.Conf("iceberg")+(dataset.names||msg.names).toLowerCase(), option, function(msg) {
typeof cb == "function" && cb(msg)
}), delete(event.msg)
}),
WSS: shy("请求后端", {order: 0}, function(can, url, args, cb, onopen, onerror, onclose) {var meta = arguments.callee.meta
can._socket = new WebSocket(url+"?"+can.base.Args(args))
var timer = can.Timer(30000, function() {
can._socket.send("{}")
})
can._socket.onerror = onerror || function() {
can._socket.close()
}, can._socket.onclose = onclose || function() {
var timer = can.Timer(30000, function() {can._socket.send("{}")})
can._socket.onclose = onclose || function() {
timer.stop = true, can.user.toast("wss redial")
can.Log("wss", "close"), delete(can._socket), setTimeout(function() {
// 断线重连
can.misc.WSS(can, url, args, cb, onerror, onclose, onopen)
}, 1000)
}, can._socket.onerror = onerror || function() {
can._socket.close()
}, can._socket.onopen = onopen
can._socket.onmessage = function(event) {var order = ++meta.order
try {
var msg = JSON.parse(event.data||'{}')
// 解析命令
var msg = JSON.parse(event.data)
} catch (e) {
var msg = {"result": [event.data]}
}
msg = can.Event(event, msg), msg.Reply = function() {
// 回复命令
msg.Option("_handle", true)
msg.Option("_target", msg.Option("_source"))
can.Log(["wss", order, "result"].concat(msg.result).concat([msg]))
@ -103,10 +78,11 @@ Volcanos("misc", {help: "工具模块",
}
try {
// 执行命令
can.Log(["wss", order].concat(msg.detail).concat([msg]))
typeof cb == "function" && cb(event, msg)
} catch (e) {
msg.Option("_handle", true)
// 执行失败
msg.Reply(can.Log("err", e))
}
}

View File

@ -199,6 +199,8 @@ Volcanos("page", {help: "网页模块",
return field.Meta = item, field;
}),
AppendTable: shy("添加表格", function(can, target, msg, list, cb, cbs) {
if (!msg.append || msg.append.length == 0) {return {}}
var table = can.page.Append(can, target, "table");
var tr = can.page.Append(can, table, "tr");
can.core.List(list, function(key, index) {can.page.Append(can, tr, "th", key).onclick = function(event) {

View File

@ -37,8 +37,8 @@ Volcanos("onimport", {help: "导入数据", list: [],
}
}
var code = can.page.Append(can, output, [{view: ["code", "div", can.page.Display(msg.Result())]}]).code;
return typeof cb == "function" && cb(msg), code;
msg.result && can.page.Append(can, output, [{view: ["code", "div", can.page.Display(msg.Result())]}]).code;
return typeof cb == "function" && cb(msg);
},
which: function(event, table, list, cb) {if (event.target == table) {return cb(-1, "")}
can.page.Select(can, table, "tr", function(tr, index) {if (event.target == tr) {return cb(tr.dataset.index, "")}