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

opt proto.js

This commit is contained in:
shaoying 2020-12-12 17:54:16 +08:00
parent 2df8fd6192
commit d45af932f1
4 changed files with 42 additions and 60 deletions

View File

@ -1,7 +1,7 @@
<!DOCTYPE html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=0.7,user-scalable=no">
<meta charset="utf-8">
<title>volcanos</title>
<link rel="shortcut icon" type="image/ico" href="favicon.ico">
<link rel="stylesheet" type="text/css" href="cache.css">

View File

@ -6,7 +6,7 @@ Volcanos({name: "chat", iceberg: "/chat/", volcano: "/frame.js",
{name: "River", help: "群聊组", pos: "left"},
{name: "Action", help: "工作台", pos: "middle"},
{name: "Footer", help: "状态条", pos: "foot", state: ["ncmd", "keys"]},
], main: {name: "Header", engine: "remote", list: ["publish/order.js"]}, plugin: [
], main: {name: "Header", engine: "remote", list: ["/publish/order.js"]}, plugin: [
"/plugin/state.js",
"/plugin/input.js",
"/plugin/table.js",

View File

@ -21,6 +21,7 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
// 添加插件
can.onappend._init(can, value, ["/plugin/state.js"], function(plugin) {
can._plugins = (can._plugins||[]).concat([plugin])
plugin.run = function(event, cmds, cb, silent) { var msg = plugin.request(event); cmds = cmds || []
can.run(event, can.onengine[cmds[0]]? cmds: [river, storm, value.action].concat(cmds), function(msg) {
typeof cb == "function" && cb(msg)

View File

@ -1,8 +1,8 @@
function shy(help, meta, list, cb) {
var index = -1, value = "", type = "string", args = arguments; function next(check) {
if (++index >= args.length) {return false}
if (check && check != typeof args[index]) {index--; return false}
return value = args[index], type = typeof value, value
var index = -1, args = arguments; function next(check) {
if (++index >= args.length) { return }
if (check && check != typeof args[index]) { index--; return }
return args[index]
}
var cb = arguments[arguments.length-1] || function() {}
@ -14,15 +14,16 @@ function shy(help, meta, list, cb) {
var Volcanos = shy("火山架", {libs: [], 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
// 预加载
var Preload = Config.libs; Config.panes.forEach(function(pane) {
Preload = Preload.concat(pane.list = pane.list || ["/pane/"+pane.name+".css", "/pane/"+pane.name+".js"])
Preload = Preload.concat(pane.list = pane.list || ["/pane/"+pane.name+".js"])
}); Preload = Preload.concat(Config.plugin)
// 根模块
meta.libs = Config.libs, meta.volcano = Config.volcano
name = Config.name, can = { _follow: Config.name,
_width: window.innerWidth, _height: window.innerHeight,
_target: document.body, _head: document.head, _body: document.body,
_width: window.innerWidth, _height: window.innerHeight,
}, libs = Preload.concat(Config.volcano), cb = function(can) {
can.onengine._init(can, can.Conf(Config), [], function(msg) {
can.base.Log(can)
@ -31,30 +32,24 @@ var Volcanos = shy("火山架", {libs: [], cache: {}, index: 1}, [], function(na
}
var conf = {}, conf_cb = {}
can = can || {}, list.push(can) && (can.__proto__ = {__proto__: Volcanos.meta, _name: name, _create_time: new Date(), _load: function(name, cb) {
list.push(can = can || {}), can.__proto__ = {__proto__: Volcanos.meta, _name: name, _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 }
if (list[meta.index] == can) { continue }
cache.push(list[meta.index])
// 加载缓存
}
list[meta.index] != can && cache.push(list[meta.index])
}; meta.cache[name] = cache
for (var i = 0; i < cache.length; i++) {
if (can[cache[i]._name] && can[cache[i]._name]._merge && can[cache[i]._name]._merge(can, cache[i])) { continue }
if (typeof cb == "function" && cb(can, name, cache[i])) { continue}
if (can[cache[i]._name]) {
for (var k in cache[i]) {
can[cache[i]._name].hasOwnProperty(k) || (can[cache[i]._name][k] = cache[i][k])
// 加载模块
for (var i = 0; i < cache.length; i++) { var sub = cache[i]
if (can[sub._name] && can[sub._name]._merge && can[sub._name]._merge(can, sub)) { continue }
if (typeof cb == "function" && cb(can, name, sub)) { continue}
if (can[sub._name]) {
for (var k in sub) {
can[sub._name].hasOwnProperty(k) || (can[sub._name][k] = sub[k])
}
} else {
can[cache[i]._name] = cache[i]
can[sub._name] = sub
}
// 加载索引
}
meta.cache[name] = cache
},
require: function(libs, cb, each) { if (!libs || libs.length == 0) {
typeof cb == "function" && setTimeout(function() { cb(can) }, 10)
@ -66,60 +61,46 @@ var Volcanos = shy("火山架", {libs: [], cache: {}, index: 1}, [], function(na
if (meta.cache[source]) {
can._load(source, each), can.require(libs.slice(1), cb, each)
return // 缓存加载
return // 加载缓存
}
if (source.endsWith(".js")) { var script = document.createElement("script")
if (can.user && source.indexOf("publish") == 0) {
source += "?pod="+(can.user.Search(can, "pod")||"")
}
if (can.user && source.indexOf("/publish") == 0) {
if (source.endsWith(".css")) { var style = document.createElement("link")
style.rel = "stylesheet", style.type = "text/css"
style.href = source; style.onload = function() {
can._load(source, each), can.require(libs.slice(1), cb, each)
} // 加载样式
target.appendChild(style)
} else if (source.endsWith(".js")) { var script = document.createElement("script")
if (source.indexOf("/publish") == 0 && can.user) {
source += "?pod="+(can.user.Search(can, "pod")||"")
}
script.src = source, script.onload = function() {
can._load(source, each), can.require(libs.slice(1), cb, each)
} // 加载脚本
target.appendChild(script)
} else if (source.endsWith(".css")) { var style = document.createElement("link")
style.rel = "stylesheet", style.type = "text/css"
style.href = source; style.onload = function() {
can._load(source, each), can.require(libs.slice(1), cb, each)
} // 加载样式
target.appendChild(style)
}
},
request: function(event, option) { event = event || {}
if (event._msg) {
can.core.Item(option, event._msg.Option)
return event._msg
}
var ls = (can._name||can._help).split("/")
event._pane = ls[ls.length-1]
var msg = can.misc.Message(event, can)
can.core.Item(option, msg.Option)
return event._msg = msg
event._msg = event._msg || can.misc.Message(event, can)
can.core.Item(option, event._msg.Option)
return event._msg
},
Conf: function(key, value, cb) {
Conf: function(key, value) {
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;
conf[key] = conf_cb[key] && (res = conf_cb[key](value, old, key)) != undefined && res || value
}
conf[key] = value == undefined? conf[key]: value
if (conf[key] == undefined && key.indexOf(".") > 0) {
var p = conf, ls = key.split(".")
while (p && ls.length > 0) {
var p = conf, ls = key.split("."); while (p && ls.length > 0) {
p = p[ls[0]], ls = ls.slice(1)
}
return p
}
return conf[key] || ""
return conf[key]
},
})
}
if (_can_name) {
meta.cache[_can_name] = meta.cache[_can_name] || []