1
0
mirror of https://shylinux.com/x/volcanos synced 2025-04-25 16:58:06 +08:00
This commit is contained in:
shaoying 2020-10-10 22:13:53 +08:00
parent aece57d66c
commit 98e8eab4c4
3 changed files with 64 additions and 75 deletions

View File

@ -26,7 +26,7 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
},
_daemon: function(can, name) {
return
can.misc.WSS(can, "", {name: name, type: "chrome"}, function(event, msg) {
can.misc.WSS(can, "", {type: "chrome", name: name}, function(event, msg) {
if (msg.Option("_handle")) { return can.user.toast(can, msg.result.join("")) }
can.user.toast(can, msg.detail.join(" "))
@ -55,14 +55,11 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
if (Volcanos.meta.webpack == true || location.protocol == "file:") {
var res = Volcanos.meta.pack[pane._name+","+cmds.join(",")]
if (res) {
res = can.request(event, res)
if (res) { res = can.request(event, res)
delete(msg._event), delete(msg._can)
return typeof cb == "function" && cb(res)
}
typeof cb == "function" && cb(msg)
return
return typeof cb == "function" && cb(msg)
}
can.misc.Run(event, can, {names: pane._name}, cmds, function(msg) {
@ -75,21 +72,14 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
engine: function(event, can, msg, pane, cmds, cb) { if (!can.onengine) { return false }
switch (pane._name) {
case "River":
if (cmds.length == 0) {
can.core.Item(can.onengine.river, function(key, value) {
msg.Push("hash", key)
msg.Push("name", value.name)
})
}
if (cmds.length != 1 && cmds[1] != "tool") {
break
}
cmds.length == 0 && can.core.Item(can.onengine.river, function(key, value) {
msg.Push("hash", key), msg.Push("name", value.name)
})
if (cmds.length != 1 && cmds[1] != "tool") { break }
case "Storm":
var river = can.onengine.river[cmds[0]]; if (!river) { break }
can.core.Item(river.storm, function(key, value) {
msg.Push("hash", key)
msg.Push("name", value.name)
msg.Push("count", (value.index||value.action).length)
msg.Push("hash", key), msg.Push("name", value.name)
})
typeof cb == "function" && cb(msg)
return true
@ -99,14 +89,10 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
var action = storm && storm.action && storm.action[cmds[2]]
if (!storm) { break } if (cmds.length == 2) {
if (storm.index) {
if (Volcanos.meta.webpack == true) {
typeof cb == "function" && cb(msg)
return true
}
if (Volcanos.meta.webpack == true) { typeof cb == "function" && cb(msg); return true }
can.misc.Run(event, can, {names: pane._name}, ["action", "command"].concat(storm.index), cb)
return true
}
if (location.pathname == "/share") { return false }
can.core.List(storm.action, function(value) {
msg.Push("name", value.name||"")
@ -117,16 +103,8 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
msg.Push("args", value.args||"[]")
})
typeof cb == "function" && cb(msg)
} else if (action && action.engine) {
action.engine(event, can, msg, pane, cmds, cb)
} else if (action) {
msg.Option("group", action.group)
msg.Option("index", action.index)
return false
} else {
return false
return true
}
return true
}
return false
},
@ -270,7 +248,7 @@ Volcanos("onappend", {help: "渲染引擎", list: [], _init: function(can, meta,
},
Clone: function() {
meta.args = sub.page.Select(sub, sub._option, "textarea.args,input.args,select.args", function(item) {
return item.value || ""
return item.name && item.value || ""
})
sub.onappend._init(sub, meta, list, function(sub) {
cb(sub), sub.Timer(10, function() {
@ -281,7 +259,7 @@ Volcanos("onappend", {help: "渲染引擎", list: [], _init: function(can, meta,
Option: function(key, value) {
if (typeof key == "object") { return sub.core.Item(key, sub.Option), key }
if (key == undefined) { value = {}
sub.page.Select(sub, option, "select.args,input.args,textarea.args", function(item) {
sub.page.Select(sub, option, "textarea.args,input.args,select.args", function(item) {
item.name && item.value && (value[item.name] = item.value)
})
return value
@ -309,8 +287,6 @@ Volcanos("onappend", {help: "渲染引擎", list: [], _init: function(can, meta,
sub.page.ClassList.add(sub, field, meta.style||meta.feature.style||"")
sub.onimport && sub.onimport._init(sub, sub.Conf(meta), list, function() {}, field)
// meta.detail = meta.feature["detail"] || {}
meta.inputs && sub.onappend._option(sub, meta, list, cb)
sub.onaction && sub.onappend._action(sub, sub._action, meta.button || sub.onaction.list)
sub.onexport && sub.onappend._status(sub, sub._status, sub.onexport.list)
@ -324,7 +300,7 @@ Volcanos("onappend", {help: "渲染引擎", list: [], _init: function(can, meta,
_option: can._option, _action: can._action, _output: can._output,
CloneInput: function() { add(item, function() {})._target.focus() },
CloneField: function() { can.Clone() },
}, Volcanos.meta.libs.concat([item.display||"/plugin/input.js", "/frame.js"]), function(input) { input.sup = can
}, Volcanos.meta.libs.concat([item.display||"/plugin/input.js", Volcanos.meta.volcano]), function(input) { input.sup = can
input.run = function(event, cmds, cb, silent) {
var msg = can.request(event); msg.Option(can.Conf("option"))
return can.onappend._output(can, meta, event, can.Pack(cmds), cb, silent)

View File

@ -105,15 +105,19 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
var cb = can.onimport[process]; return typeof cb == "function" && cb(can, msg)
},
_follow: function(can, msg) {
if (msg.Result() == "stop") { return }
can.onappend.board(can, can._target, "board", msg)
if (msg.Result() == "stop") { return can.user.toast(can, msg.Option("cache.action")+" done!")}
can.ui || (can.ui = can.page.Appends(can, can._target, [{view: ["content", "div"]}]))
can.page.ClassList.add(can, can.ui.content, "code")
can.page.Modify(can, can.ui.content, {style: {"max-height": 400}})
can.page.Append(can, can.ui.content, [{text: msg.Result()}])
can.ui.content.scrollBy(0, 1000)
can.Timer(100, function() {
var sub = can.request({})
sub.Option("cache.limit", msg.Option("cache.limit"))
sub.Option("cache.begin", msg.Option("cache.begin"))
sub.Option("cache.hash", msg.Option("cache.hash"))
can.run(sub._event, [msg.Option("cache.button")], function(msg) {
sub.Option("cache.begin", msg.Option("cache.begin"))
sub.Option("cache.limit", msg.Option("cache.limit"))
can.run(sub._event, [msg.Option("cache.action")], function(msg) {
can.onimport._follow(can, msg)
}, true)
})

View File

@ -11,7 +11,7 @@ function shy(help, meta, list, cb) {
cb.list = next("object") || []
return cb
}; var _can_name = ""
var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs: []}, [], function(name, can, libs, cb) {
var Volcanos = shy("火山架", {libs: [], pack: {}, order: 1, cache: {}, index: 1}, [], function(name, can, libs, cb) {
var meta = arguments.callee.meta, list = arguments.callee.list
if (typeof name == "object") { var Config = name
meta.volcano = Config.volcano, meta.libs = Config.libs
@ -30,7 +30,7 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
}
var conf = {}, conf_cb = {}, cache = {}
can = can || {}, list.push(can) && (can.__proto__ = {_name: name, _root: "volcano", _create_time: new Date(), _load: function(name, cb) {
can = can || {}, list.push(can) && (can.__proto__ = {_name: name, _create_time: new Date(), _load: function(name, cb) {
for (var cache = meta.cache[name] || []; meta.index < list.length; meta.index++) {
if (name == "/plugin/input/date.css" && cache.length > 0) { continue }
if (name == "/lib/base.js" && cache.length > 0) { continue }
@ -48,7 +48,7 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
meta.cache[name] = cache
},
require: function(libs, cb, each) { if (!libs || libs.length == 0) {
typeof cb == "function" && setTimeout(function() {cb(can)}, 10)
typeof cb == "function" && setTimeout(function() { cb(can) }, 10)
return // 加载完成
}
@ -82,33 +82,32 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
},
request: function(event, msg, proto) { event = event || {}
if (!msg && event._msg) { return event._msg }
var ls = (can._name||can._help).split("/")
event._pane = ls[ls.length-1]
event._msg = msg = msg || {}, msg._event = event, msg._can = can
msg.__proto__ = proto || { _name: meta.order++, _create_time: new Date(),
Option: function(key, val) {
if (key == undefined) { return msg && msg.option || [] }
if (typeof key == "object") { can.core.Item(key, msg.Option) }
if (val == undefined) { return msg && msg[key] && msg[key][0] || msg._msg && msg._msg.Option(key) || "" }
if (val == undefined) { return msg && msg[key] && msg[key][0] || ""}
msg.option = msg.option || [], can.core.List(msg.option, function(k) { if (k == key) {return k} }).length > 0 || msg.option.push(key)
msg[key] = can.core.List(arguments).slice(1)
return val
},
Append: function(key, val) {
if (key == undefined) { return msg && msg.append || [] }
if (typeof key == "object") { can.core.Item(key, msg.Append) }
if (val == undefined) { return msg && msg[key] && msg[key][0] || msg._msg && msg._msg.Append(key) || "" }
if (val == undefined) { return msg && msg[key] && msg[key][0] || ""}
msg.append = msg.append || [], can.core.List(msg.append, function(k) { if (k == key) {return k} }).length > 0 || msg.append.push(key)
msg[key] = can.core.List(arguments).slice(1)
return val
},
Copy: function(res) { if (!res) { return msg }
res.result && (msg.result = (msg.result||[]).concat(res.result))
res.append && (msg.append = res.append) && res.append.forEach(function(item) {
res[item] && (msg[item] = (msg[item]||[]).concat(res[item]))
})
res.option && (msg.option = res.option) && res.option.forEach(function(item) {
res[item] && (msg[item] = res[item])
})
return msg
Result: function(cb) {
return msg.result && msg.result.join("") || ""
},
Table: shy("遍历数据", function(cb) { if (!msg.append || !msg.append.length || !msg[msg.append[0]]) { return }
Table: function(cb) { if (!msg.append || !msg.append.length || !msg[msg.append[0]]) { return }
var max = "", len = 0; can.core.List(msg.append, function(key, index) {
if (msg[key] && msg[key].length > len) { max = key, len = msg[key].length }
})
@ -117,10 +116,7 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
can.core.List(msg.append, function(key) { one[key] = (msg[key]&&msg[key][index]||"").trim() })
return typeof cb == "function" && (res = cb(one, index, array)) && res != undefined && res || one
})
}),
Result: shy("遍历数据", function(cb) {
return msg.result && msg.result.join("") || ""
}),
},
Clear: function(key) {
switch (key) {
case "append":
@ -132,7 +128,17 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
msg[key] = []
}
},
Push: function(key, value, detail) {msg.append = msg.append || []
Copy: function(res) { if (!res) { return msg }
res.result && (msg.result = (msg.result||[]).concat(res.result))
res.append && (msg.append = res.append) && res.append.forEach(function(item) {
res[item] && (msg[item] = (msg[item]||[]).concat(res[item]))
})
res.option && (msg.option = res.option) && res.option.forEach(function(item) {
res[item] && (msg[item] = res[item])
})
return msg
},
Push: function(key, value, detail) { msg.append = msg.append || []
if (typeof key == "object") {
value = value || can.core.Item(key)
can.core.List(value, function(item) {
@ -152,19 +158,20 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
msg[key].push(""+(typeof value == "object"? JSON.stringify(value): value)+"")
return msg
},
Echo: shy("输出响应", function(res) {msg.result = msg.result || []
Echo: function(res) {msg.result = msg.result || []
msg._hand = true
for (var i = 0; i < arguments.length; i++) {msg.result.push(arguments[i])}
return msg
}),
},
}
return msg
},
Conf: shy("配置器", function(key, value, cb) { if (key == undefined) { return conf }
Conf: function(key, value, cb) {
if (key == undefined) { return conf }
if (typeof key == "object") { conf = key; return conf }
typeof cb == "function" && (conf_cb[key] = cb)
if (value != undefined) {var old = conf[key], res;
if (value != undefined) { var old = conf[key], res;
conf[key] = conf_cb[key] && (res = conf_cb[key](value, old, key)) != undefined && res || value
}
if (conf[key] == undefined && key.indexOf(".") > 0) {
@ -175,8 +182,8 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
return p
}
return conf[key] || ""
}),
Cache: shy("缓存器", function(name, output, data) {
},
Cache: function(name, output, data) {
if (data) { if (output.children.length == 0) { return }
// 写缓存
var temp = document.createDocumentFragment()
@ -201,15 +208,17 @@ var Volcanos = shy("火山架", {cache: {}, index: 1, order: 1, pack: {}, libs:
}
delete(cache[name])
return list.data
}),
Timer: shy("定时器, value, [1,2,3,4], {value, length}", function(interval, cb, cbs) { interval = typeof interval == "object"? interval || []: [interval]
var timer = {stop: false}
function loop(timer, i) {if (timer.stop || i >= interval.length && interval.length >= 0) {return typeof cbs == "function" && cbs(timer, interval)}
},
Timer: shy("定时器, value, [1,2,3,4], {value, length}", function(interval, cb, cbs) {
interval = typeof interval == "object"? interval || []: [interval]
var timer = {stop: false}; function loop(timer, i) {
if (timer.stop || i >= interval.length && interval.length >= 0) {
return typeof cbs == "function" && cbs(timer, interval)
}
return typeof cb == "function" && cb(timer, interval.value||interval[i], i, interval)?
typeof cbs == "function" && cbs(timer, interval):
setTimeout(function() {loop(timer, i+1)}, interval.value||interval[i+1])
typeof cbs == "function" && cbs(timer, interval): setTimeout(function() { loop(timer, i+1) }, interval.value||interval[i+1])
}
setTimeout(function() {loop(timer, 0)}, interval.value||interval[0])
setTimeout(function() { loop(timer, 0) }, interval.value||interval[0])
return timer
}),
})