mirror of
https://shylinux.com/x/volcanos
synced 2025-04-26 01:04:06 +08:00
opt proto.js
This commit is contained in:
parent
76d59b8467
commit
10bda20cd3
4
frame.js
4
frame.js
@ -178,7 +178,7 @@ Volcanos(chat.ONAPPEND, {_init: function(can, meta, list, cb, target, field) {
|
|||||||
can.core.ItemCB(sub.onaction, function(key, cb) { sub._target[key] = function(event) { cb(can.request(event), sub) } })
|
can.core.ItemCB(sub.onaction, function(key, cb) { sub._target[key] = function(event) { cb(can.request(event), sub) } })
|
||||||
can.core.ItemCB(item, function(key, cb) { sub._target[key] = function(event) { cb(can.request(event), sub) } })
|
can.core.ItemCB(item, function(key, cb) { sub._target[key] = function(event) { cb(can.request(event), sub) } })
|
||||||
skip? next(): can.core.CallFunc([sub.onaction, chat._INIT], {can: sub, meta: item, cb: next, target: sub._target});
|
skip? next(): can.core.CallFunc([sub.onaction, chat._INIT], {can: sub, meta: item, cb: next, target: sub._target});
|
||||||
(item.action||can.core.Value(meta, [ctx.FEATURE, ctx.INPUTS])) && can.onappend.figure(sub, item, sub._target, function(sub, value) {
|
(item.action||can.core.Value(meta, [ctx.FEATURE, ctx.INPUTS])) && can.onappend.figure(sub, item, sub._target, function(_sub, value) {
|
||||||
sub._target.value = value, can.onmotion.focus(can, sub._target), can.onmotion.delay(can, function() { can.Update() })
|
sub._target.value = value, can.onmotion.focus(can, sub._target), can.onmotion.delay(can, function() { can.Update() })
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
@ -277,7 +277,7 @@ Volcanos(chat.ONAPPEND, {_init: function(can, meta, list, cb, target, field) {
|
|||||||
if (item.type == html.TEXT) { input.onkeydown = item.onkeydown||function(event) {
|
if (item.type == html.TEXT) { input.onkeydown = item.onkeydown||function(event) {
|
||||||
can.onkeymap.input(event, can), can.onkeymap.selectOutput(event, can), event.key == lang.ENTER && can.onkeymap.prevent(event)
|
can.onkeymap.input(event, can), can.onkeymap.selectOutput(event, can), event.key == lang.ENTER && can.onkeymap.prevent(event)
|
||||||
} }
|
} }
|
||||||
if (item.range) { input._init = function(target) { item.mode = "simple"
|
if (item.range) { input._init = function(target) { item.mode = chat.SIMPLE
|
||||||
can.onappend.figure(can, item, target, function(sub, value, old) {
|
can.onappend.figure(can, item, target, function(sub, value, old) {
|
||||||
target.value = value, can.onaction[item.name](event, can, item.name)
|
target.value = value, can.onaction[item.name](event, can, item.name)
|
||||||
})
|
})
|
||||||
|
@ -50,7 +50,7 @@ Volcanos("core", {
|
|||||||
SplitInput: function(item, type) { if (typeof item == lang.OBJECT) { return item }
|
SplitInput: function(item, type) { if (typeof item == lang.OBJECT) { return item }
|
||||||
type = type||html.TEXT; switch (item) {
|
type = type||html.TEXT; switch (item) {
|
||||||
case mdb.LIST: return {type: type = html.BUTTON, name: item, action: ice.AUTO}
|
case mdb.LIST: return {type: type = html.BUTTON, name: item, action: ice.AUTO}
|
||||||
case cli.BACK: return {type: type = html.BUTTON, name: item}
|
case ice.BACK: return {type: type = html.BUTTON, name: item}
|
||||||
case mdb.NAME: return {type: type = html.TEXT, name: item}
|
case mdb.NAME: return {type: type = html.TEXT, name: item}
|
||||||
case mdb.TEXT: return {type: type = html.TEXTAREA, name: item}
|
case mdb.TEXT: return {type: type = html.TEXTAREA, name: item}
|
||||||
default: var ls = this.Split(item, " ", ":=@"), res = {type: type, name: ls[0]}; for (var i = 1; i < ls.length; i += 2) {
|
default: var ls = this.Split(item, " ", ":=@"), res = {type: type, name: ls[0]}; for (var i = 1; i < ls.length; i += 2) {
|
||||||
|
@ -117,7 +117,7 @@ Volcanos("misc", {Message: function(event, can) { var msg = {}
|
|||||||
|
|
||||||
if (msg._upload) {
|
if (msg._upload) {
|
||||||
var data = new FormData(); can.core.Items(form, function(value, index, key) { data.append(key, value) })
|
var data = new FormData(); can.core.Items(form, function(value, index, key) { data.append(key, value) })
|
||||||
data.append(ice.MSG_UPLOAD, mdb.UPLOAD), data.append(html.UPLOAD, msg._upload)
|
data.append(ice.MSG_UPLOAD, web.UPLOAD), data.append(web.UPLOAD, msg._upload)
|
||||||
xhr.upload.onprogress = function(event) { can.base.isFunc(msg._progress) && msg._progress(event, parseInt(event.loaded*100/event.total), event.total, event.loaded) }
|
xhr.upload.onprogress = function(event) { can.base.isFunc(msg._progress) && msg._progress(event, parseInt(event.loaded*100/event.total), event.total, event.loaded) }
|
||||||
} else {
|
} else {
|
||||||
var data = can.core.Items(form, function(value, index, key) { return key+ice.EQ+encodeURIComponent(value) }).join("&")
|
var data = can.core.Items(form, function(value, index, key) { return key+ice.EQ+encodeURIComponent(value) }).join("&")
|
||||||
@ -140,7 +140,7 @@ Volcanos("misc", {Message: function(event, can) { var msg = {}
|
|||||||
can.base.isFunc(onclose)? onclose(socket): can.core.Timer(can.base.random(3000, 1000), function() {
|
can.base.isFunc(onclose)? onclose(socket): can.core.Timer(can.base.random(3000, 1000), function() {
|
||||||
args.name = args.name||can._wss_name, can.misc.WSS(can, args, cb, onopen, onerror, onclose)
|
args.name = args.name||can._wss_name, can.misc.WSS(can, args, cb, onopen, onerror, onclose)
|
||||||
})
|
})
|
||||||
}, socket.onerror = function() { can.misc.Log(html.WSS, cli.ERROR, args)
|
}, socket.onerror = function() { can.misc.Log(html.WSS, log.ERROR, args)
|
||||||
can.base.isFunc(onerror)? onerror(socket): socket.close()
|
can.base.isFunc(onerror)? onerror(socket): socket.close()
|
||||||
}, socket.onopen = function() { can.misc.Log(html.WSS, cli.OPEN, args)
|
}, socket.onopen = function() { can.misc.Log(html.WSS, cli.OPEN, args)
|
||||||
can.base.isFunc(onopen) && onopen(socket)
|
can.base.isFunc(onopen) && onopen(socket)
|
||||||
|
10
lib/user.js
10
lib/user.js
@ -46,7 +46,7 @@ Volcanos("user", {info: {}, agent: {
|
|||||||
can.user.language(can) && name.push(can.user.language(can))
|
can.user.language(can) && name.push(can.user.language(can))
|
||||||
can.Conf("display") && name.push(can.Conf("display"))
|
can.Conf("display") && name.push(can.Conf("display"))
|
||||||
can.user.isWebview && name.push("webview")
|
can.user.isWebview && name.push("webview")
|
||||||
can.user.mod.isCmd && name.push("simple")
|
can.user.mod.isCmd && name.push(chat.SIMPLE)
|
||||||
can.page.styleClass(can, document.body, name.join(ice.SP))
|
can.page.styleClass(can, document.body, name.join(ice.SP))
|
||||||
},
|
},
|
||||||
language: function(can) { return can.misc.Search(can, "language") },
|
language: function(can) { return can.misc.Search(can, "language") },
|
||||||
@ -164,13 +164,13 @@ Volcanos("user", {info: {}, agent: {
|
|||||||
can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) { item.name && item.value && _msg.Option(item.name, item.value) })
|
can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) { item.name && item.value && _msg.Option(item.name, item.value) })
|
||||||
can.run(event, cmds, cb, true)
|
can.run(event, cmds, cb, true)
|
||||||
}, item._enter = function(event) { action.submit(event, can, html.SUBMIT) }
|
}, item._enter = function(event) { action.submit(event, can, html.SUBMIT) }
|
||||||
item.mode = "simple", can.onappend.figure(can, item, target)
|
item.mode = chat.SIMPLE, can.onappend.figure(can, item, target)
|
||||||
}; return {type: html.TR, list: [{type: html.TD, list: [{text: item.name||""}, {text: item.need == "must"? "*": "", style: {color: cli.RED}}]}, {type: html.TD, list: [can.page.input(can, item)]}]}
|
}; return {type: html.TR, list: [{type: html.TD, list: [{text: item.name||""}, {text: item.need == "must"? "*": "", style: {color: cli.RED}}]}, {type: html.TD, list: [can.page.input(can, item)]}]}
|
||||||
})}]}, html.ACTION,
|
})}]}, html.ACTION,
|
||||||
]}]); can.onlayout.figure(event, can, ui._target), can.onmotion.delay(can, function() { action.focus() })
|
]}]); can.onlayout.figure(event, can, ui._target), can.onmotion.delay(can, function() { action.focus() })
|
||||||
var action = can.onappend._action(can, button||[html.SUBMIT, html.CANCEL], ui.action, {
|
var action = can.onappend._action(can, button||[html.SUBMIT, html.CANCEL], ui.action, {
|
||||||
focus: function(event) { can.page.Select(can, ui.first, html.INPUT_ARGS)[0].focus() },
|
focus: function() { can.onmotion.focus(can, can.page.Select(can, ui.first, html.INPUT_ARGS)[0]) },
|
||||||
cancel: function(event) { can.page.Remove(can, ui._target) },
|
cancel: function() { can.page.Remove(can, ui._target) },
|
||||||
submit: function(event, can, button) { var args = [], data = {}, err = false
|
submit: function(event, can, button) { var args = [], data = {}, err = false
|
||||||
var list = can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) {
|
var list = can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) {
|
||||||
if (item.value == "" && need[item.name] == "must") { err = true, item.focus(), can.user.toast(can, item.name+" 是必选字段, 请重新输入") }
|
if (item.value == "" && need[item.name] == "must") { err = true, item.focus(), can.user.toast(can, item.name+" 是必选字段, 请重新输入") }
|
||||||
@ -187,7 +187,7 @@ Volcanos("user", {info: {}, agent: {
|
|||||||
},
|
},
|
||||||
upload: function(event, can, cb) { var begin = new Date()
|
upload: function(event, can, cb) { var begin = new Date()
|
||||||
var ui = can.page.Append(can, document.body, [{view: [[html.UPLOAD, chat.FLOAT]], list: [
|
var ui = can.page.Append(can, document.body, [{view: [[html.UPLOAD, chat.FLOAT]], list: [
|
||||||
html.ACTION, {view: html.OUTPUT, list: ["progress"]}, {view: html.STATUS, list: [html.SHOW, cli.COST, nfs.SIZE]},
|
html.ACTION, {view: html.OUTPUT, list: ["progress"]}, {view: html.STATUS, list: [ice.SHOW, cli.COST, nfs.SIZE]},
|
||||||
]}]); can.onlayout.figure(event, can, ui._target)
|
]}]); can.onlayout.figure(event, can, ui._target)
|
||||||
var action = can.onappend._action(can, [{type: html.UPLOAD, onchange: function(event) { action.show(event, 0, event.target.files[0].size, 0) }}, cli.CLOSE], ui.action, {
|
var action = can.onappend._action(can, [{type: html.UPLOAD, onchange: function(event) { action.show(event, 0, event.target.files[0].size, 0) }}, cli.CLOSE], ui.action, {
|
||||||
close: function(event) { can.page.Remove(can, ui._target) },
|
close: function(event) { can.page.Remove(can, ui._target) },
|
||||||
|
@ -121,7 +121,7 @@ Volcanos(chat.ONACTION, {_init: function(can, target) {
|
|||||||
can.Conf(html.MARGIN_Y, 2*html.ACTION_HEIGHT), can.Conf(html.MARGIN_X, 0)
|
can.Conf(html.MARGIN_Y, 2*html.ACTION_HEIGHT), can.Conf(html.MARGIN_X, 0)
|
||||||
can.ConfHeight(can.page.height()-can.Conf(html.MARGIN_Y)), can.ConfWidth(can.page.width())
|
can.ConfHeight(can.page.height()-can.Conf(html.MARGIN_Y)), can.ConfWidth(can.page.width())
|
||||||
can.page.style(can, can._target, html.HEIGHT, can.page.height(), html.WIDTH, can.page.width())
|
can.page.style(can, can._target, html.HEIGHT, can.page.height(), html.WIDTH, can.page.width())
|
||||||
can.page.ClassList.add(can, can._target, can.Mode(chat.CMD)), can.page.ClassList.add(can, document.body, "simple")
|
can.page.ClassList.add(can, can._target, can.Mode(chat.CMD)), can.page.ClassList.add(can, document.body, chat.SIMPLE)
|
||||||
},
|
},
|
||||||
onkeydown: function(can, msg) { var event = msg._event
|
onkeydown: function(can, msg) { var event = msg._event
|
||||||
if (event.ctrlKey && event.key >= "1" && event.key <= "9") {
|
if (event.ctrlKey && event.key >= "1" && event.key <= "9") {
|
||||||
|
@ -73,7 +73,7 @@ Volcanos(chat.ONEXPORT, {help: "导出数据",
|
|||||||
can.page.style(can, ui.output, html.MAX_HEIGHT, height-html.ACTION_HEIGHT, html.MAX_WIDTH, width)
|
can.page.style(can, ui.output, html.MAX_HEIGHT, height-html.ACTION_HEIGHT, html.MAX_WIDTH, width)
|
||||||
})
|
})
|
||||||
|
|
||||||
can.onappend._action(can, [cli.CLOSE, cli.REFRESH, {input: html.TEXT, placeholder: "filter", onkeydown: function(event) {
|
can.onappend._action(can, [cli.CLOSE, web.REFRESH, {input: html.TEXT, placeholder: "filter", onkeydown: function(event) {
|
||||||
can.onkeymap.input(event, can); if (event.key != lang.ENTER) { return }
|
can.onkeymap.input(event, can); if (event.key != lang.ENTER) { return }
|
||||||
can.onmotion.tableFilter(can, ui.output, event.target.value)
|
can.onmotion.tableFilter(can, ui.output, event.target.value)
|
||||||
can.onmotion.focus(can, event.target)
|
can.onmotion.focus(can, event.target)
|
||||||
@ -103,7 +103,7 @@ Volcanos(chat.ONEXPORT, {help: "导出数据",
|
|||||||
}
|
}
|
||||||
|
|
||||||
can.getActionSize(function(msg, left, top, width, height) {
|
can.getActionSize(function(msg, left, top, width, height) {
|
||||||
can.onappend.plugin(can, {type: "story", mode: "float", index: cmds[0], args: cmds.slice(1)}, function(sub) {
|
can.onappend.plugin(can, {type: "story", mode: chat.FLOAT, index: cmds[0], args: cmds.slice(1)}, function(sub) {
|
||||||
sub.run = function(event, cmd, cb) { can.runActionCommand(event, cmds[0], cmd, cb) }
|
sub.run = function(event, cmd, cb) { can.runActionCommand(event, cmds[0], cmd, cb) }
|
||||||
sub.onimport.size(sub, height-120-2*html.ACTION_HEIGHT-can.onexport.height(can), width, true)
|
sub.onimport.size(sub, height-120-2*html.ACTION_HEIGHT-can.onexport.height(can), width, true)
|
||||||
sub.onmotion.move(sub, sub._target, {left: left, top: top+120})
|
sub.onmotion.move(sub, sub._target, {left: left, top: top+120})
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
Volcanos(chat.ONACTION, {
|
Volcanos(chat.ONACTION, {
|
||||||
_init: function(can, meta, target) { meta.type == html.BUTTON && meta.action == ice.AUTO && !can.sup._delay_init && target.click() },
|
_init: function(can, meta, target) { meta.type == html.BUTTON && meta.action == ice.AUTO && !can.sup._delay_init && target.click() },
|
||||||
run: function(event, can) { can.run(can.request(event, {_toast: ice.PROCESS})) },
|
run: function(event, can) { can.run(can.request(event, {_toast: ice.PROCESS})) },
|
||||||
list: function(event, can) { can.sup.Conf("mode") != "simple" && can.run(event) },
|
list: function(event, can) { can.sup.Conf("mode") != chat.SIMPLE && can.run(event) },
|
||||||
back: function(event, can) { can.sup.onimport._back(can.sup) },
|
back: function(event, can) { can.sup.onimport._back(can.sup) },
|
||||||
refresh: function(event, can) { can.run(event) },
|
refresh: function(event, can) { can.run(event) },
|
||||||
|
|
||||||
|
@ -58,7 +58,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据",
|
|||||||
}, [""])
|
}, [""])
|
||||||
Volcanos(chat.ONFIGURE, {help: "索引导航",
|
Volcanos(chat.ONFIGURE, {help: "索引导航",
|
||||||
source: function(can, target, zone, path) { var total = 0
|
source: function(can, target, zone, path) { var total = 0
|
||||||
function show(target, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
function show(target, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) { var list = msg.Table()
|
||||||
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, path, item.path) }, target)
|
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, path, item.path) }, target)
|
||||||
can.Status("文件数", zone._total(total += msg.Length()))
|
can.Status("文件数", zone._total(total += msg.Length()))
|
||||||
}, true) }
|
}, true) }
|
||||||
@ -230,17 +230,17 @@ Volcanos(chat.ONIMPORT, {help: "导入数据",
|
|||||||
},
|
},
|
||||||
html.WIDTH, function(event) {
|
html.WIDTH, function(event) {
|
||||||
can.user.input(event, can, [{name: html.WIDTH, value: can.profile_size[can.onexport.keys(can)]*100/can.ConfWidth()||50}], function(list) {
|
can.user.input(event, can, [{name: html.WIDTH, value: can.profile_size[can.onexport.keys(can)]*100/can.ConfWidth()||50}], function(list) {
|
||||||
can.profile_size[can.onexport.keys(can)] = can.ConfWidth()*parseInt(list[0])/100, can.onaction[cli.SHOW](event, can)
|
can.profile_size[can.onexport.keys(can)] = can.ConfWidth()*parseInt(list[0])/100, can.onaction[ice.SHOW](event, can)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
)); can.ui.profile_output = ui.output
|
)); can.ui.profile_output = ui.output
|
||||||
},
|
},
|
||||||
_display: function(can, target) {
|
_display: function(can, target) {
|
||||||
var ui = can.onimport._panel(can, target, kit.Dict(
|
var ui = can.onimport._panel(can, target, kit.Dict(
|
||||||
cli.SHOW, function(event) { can.onaction[cli.EXEC](event, can) },
|
ice.SHOW, function(event) { can.onaction[ice.EXEC](event, can) },
|
||||||
html.HEIGHT, function(event) {
|
html.HEIGHT, function(event) {
|
||||||
can.user.input(event, can, [{name: html.HEIGHT, value: can.display_size[can.onexport.keys(can)]*100/can.ConfHeight()||50}], function(list) {
|
can.user.input(event, can, [{name: html.HEIGHT, value: can.display_size[can.onexport.keys(can)]*100/can.ConfHeight()||50}], function(list) {
|
||||||
can.display_size[can.onexport.keys(can)] = can.ConfHeight()*parseInt(list[0])/100, can.onaction[cli.EXEC](event, can)
|
can.display_size[can.onexport.keys(can)] = can.ConfHeight()*parseInt(list[0])/100, can.onaction[ice.EXEC](event, can)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
)); can.ui.display_output = ui.output, can.ui.display_status = ui.status
|
)); can.ui.display_output = ui.output, can.ui.display_status = ui.status
|
||||||
@ -341,8 +341,8 @@ Volcanos(chat.ONKEYMAP, {help: "导入数据",
|
|||||||
_mode: {
|
_mode: {
|
||||||
plugin: {
|
plugin: {
|
||||||
Escape: shy("切换模式", function(event, can) { can.onaction.clear(event, can) }),
|
Escape: shy("切换模式", function(event, can) { can.onaction.clear(event, can) }),
|
||||||
v: shy("渲染界面", function(event, can) { can.onaction[cli.SHOW](event, can) }),
|
v: shy("渲染界面", function(event, can) { can.onaction[ice.SHOW](event, can) }),
|
||||||
r: shy("执行命令", function(event, can) { can.onaction[cli.EXEC](event, can) }),
|
r: shy("执行命令", function(event, can) { can.onaction[ice.EXEC](event, can) }),
|
||||||
f: shy("打开文件", function(event, can) { can.onaction["打开"](event, can) }),
|
f: shy("打开文件", function(event, can) { can.onaction["打开"](event, can) }),
|
||||||
|
|
||||||
x: shy("关闭标签", function(can) { can._tab._close() }),
|
x: shy("关闭标签", function(can) { can._tab._close() }),
|
||||||
@ -378,14 +378,14 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
if (can.user.isWebview) { var last = can.misc.localStorage(can, "web.code.inner:currentFile"); if (last) { var ls = can.core.Split(last, ice.DF) } }
|
if (can.user.isWebview) { var last = can.misc.localStorage(can, "web.code.inner:currentFile"); if (last) { var ls = can.core.Split(last, ice.DF) } }
|
||||||
|
|
||||||
switch (can.Mode()) {
|
switch (can.Mode()) {
|
||||||
case "simple": can.onmotion.hidden(can, can.ui.project); break
|
case chat.SIMPLE: can.onmotion.hidden(can, can.ui.project); break
|
||||||
case "float": can.onmotion.hidden(can, can.ui.project); break
|
case chat.FLOAT: can.onmotion.hidden(can, can.ui.project); break
|
||||||
case "cmd": can.onimport._tabs(can), can.onmotion.hidden(can, can._status) // no break
|
case chat.CMD: can.onimport._tabs(can), can.onmotion.hidden(can, can._status) // no break
|
||||||
case "full": // no break
|
case chat.FULL: // no break
|
||||||
default: can.onimport.project(can, paths)
|
default: can.onimport.project(can, paths)
|
||||||
can.onengine.listen(can, "tabview.view.init", function() { if (can.user.isMobile) { return } var p = can.onsyntax[can.parse]
|
can.onengine.listen(can, "tabview.view.init", function() { if (can.user.isMobile) { return } var p = can.onsyntax[can.parse]
|
||||||
can.Option(nfs.PATH).indexOf("src/") == 0 && p && p.render && can.onaction[cli.SHOW]({}, can); if (can.page.ClassList.has(can, can._fields, chat.PLUGIN)) {
|
can.Option(nfs.PATH).indexOf("src/") == 0 && p && p.render && can.onaction[ice.SHOW]({}, can); if (can.page.ClassList.has(can, can._fields, chat.PLUGIN)) {
|
||||||
p && p.engine && can.onaction[cli.EXEC]({}, can)
|
p && p.engine && can.onaction[ice.EXEC]({}, can)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
can.onimport._keydown(can), can.onimport._toolkit(can, can.ui.toolkit), can.onimport._session(can, msg, function() {
|
can.onimport._keydown(can), can.onimport._toolkit(can, can.ui.toolkit), can.onimport._session(can, msg, function() {
|
||||||
|
@ -12,7 +12,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, cb) {
|
|||||||
if (msg.append.length == 2 && msg.append[0] == mdb.KEY && msg.append[1] == mdb.VALUE) {
|
if (msg.append.length == 2 && msg.append[0] == mdb.KEY && msg.append[1] == mdb.VALUE) {
|
||||||
if (key == mdb.VALUE) { key = line.key }
|
if (key == mdb.VALUE) { key = line.key }
|
||||||
}
|
}
|
||||||
if (key != ctx.ACTION) { value = sub.page.replace(sub, value, ice.PWD, "") }
|
if (key != ctx.ACTION) { value = sub.page.replace(sub, value, nfs.PWD, "") }
|
||||||
|
|
||||||
return {text: ["", html.TD], list: [{text: [value, html.DIV]}], onclick: function(event) { var target = event.target
|
return {text: ["", html.TD], list: [{text: [value, html.DIV]}], onclick: function(event) { var target = event.target
|
||||||
if ([mdb.ZONE, mdb.ID].indexOf(key) > -1) { return sub.onimport.change(event, sub, key, value) }
|
if ([mdb.ZONE, mdb.ID].indexOf(key) > -1) { return sub.onimport.change(event, sub, key, value) }
|
||||||
@ -21,7 +21,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, cb) {
|
|||||||
return sub.runAction(event, target.name, [], function(msg) { sub.run() })
|
return sub.runAction(event, target.name, [], function(msg) { sub.run() })
|
||||||
}
|
}
|
||||||
|
|
||||||
line.line && can.onimport.tabview(can, line.path, line.file.replace(ice.PWD, ""), parseInt(line.line))
|
line.line && can.onimport.tabview(can, line.path, line.file.replace(nfs.PWD, ""), parseInt(line.line))
|
||||||
}}
|
}}
|
||||||
}, sub._output), sub.onappend._status(sub, msg.Option(ice.MSG_STATUS))
|
}, sub._output), sub.onappend._status(sub, msg.Option(ice.MSG_STATUS))
|
||||||
})
|
})
|
||||||
|
@ -50,7 +50,7 @@ Volcanos(chat.ONFIGURE, {help: "索引导航",
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
source: function(can, target, zone, path) { var total = 0
|
source: function(can, target, zone, path) { var total = 0
|
||||||
function show(target, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
function show(target, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) { var list = msg.Table()
|
||||||
can.core.List(list, function(item) { item._menu = shy({trash: function(event) { can.onaction._run(event, can, nfs.TRASH, [can.base.Path(path, item.path)]) }}) })
|
can.core.List(list, function(item) { item._menu = shy({trash: function(event) { can.onaction._run(event, can, nfs.TRASH, [can.base.Path(path, item.path)]) }}) })
|
||||||
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, path, item.path) }, target)
|
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, path, item.path) }, target)
|
||||||
can.Status("文件数", zone._total(total += msg.Length()))
|
can.Status("文件数", zone._total(total += msg.Length()))
|
||||||
@ -60,7 +60,7 @@ Volcanos(chat.ONFIGURE, {help: "索引导航",
|
|||||||
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(target, path) }} }), target)
|
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(target, path) }} }), target)
|
||||||
},
|
},
|
||||||
website: function(can, target, zone) {
|
website: function(can, target, zone) {
|
||||||
can.run(can.request({}, {dir_root: "src/website/", dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
can.run(can.request({}, {dir_root: "src/website/", dir_deep: true}), [nfs.PWD], function(msg) { var list = msg.Table()
|
||||||
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, "src/website/", item.path) }, target)
|
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, "src/website/", item.path) }, target)
|
||||||
zone._total(msg.Length())
|
zone._total(msg.Length())
|
||||||
}, true)
|
}, true)
|
||||||
@ -76,7 +76,7 @@ Volcanos(chat.ONFIGURE, {help: "索引导航",
|
|||||||
}, target), {color: color})
|
}, target), {color: color})
|
||||||
}), zone._total(msg.Length()) })
|
}), zone._total(msg.Length()) })
|
||||||
return shy(kit.Dict(
|
return shy(kit.Dict(
|
||||||
cli.REFRESH, function(event, can, button) { zone.refresh() },
|
web.REFRESH, function(event, can, button) { zone.refresh() },
|
||||||
mdb.CREATE, function(event, can, button) { can.onaction.dream(event, can, web.DREAM) },
|
mdb.CREATE, function(event, can, button) { can.onaction.dream(event, can, web.DREAM) },
|
||||||
code.PUBLISH, function(event, can, button) { can.runAction(event, button, [], function(msg) { can.user.toastConfirm(can, msg.Result(), button) }) },
|
code.PUBLISH, function(event, can, button) { can.runAction(event, button, [], function(msg) { can.user.toastConfirm(can, msg.Result(), button) }) },
|
||||||
))
|
))
|
||||||
@ -277,7 +277,7 @@ Volcanos(chat.ONACTION, {help: "控件交互",
|
|||||||
}
|
}
|
||||||
|
|
||||||
var toast = can.user.toastProcess(can, "重启中...")
|
var toast = can.user.toastProcess(can, "重启中...")
|
||||||
can.onmotion.delay(can, function() { toast.close(), can.onaction[cli.SHOW]({}, can) }, 3000)
|
can.onmotion.delay(can, function() { toast.close(), can.onaction[ice.SHOW]({}, can) }, 3000)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
autogen: function(event, can, button) { can.onaction._runs(can.request(event, {path: "src/"}), can, button, function(msg) {
|
autogen: function(event, can, button) { can.onaction._runs(can.request(event, {path: "src/"}), can, button, function(msg) {
|
||||||
@ -353,7 +353,7 @@ Volcanos(chat.ONACTION, {help: "控件交互",
|
|||||||
} last = 0, can.user.toast(can, "已经到最后一行")
|
} last = 0, can.user.toast(can, "已经到最后一行")
|
||||||
}
|
}
|
||||||
function complete(target, button) {
|
function complete(target, button) {
|
||||||
can.onappend.figure(can, {action: "key", mode: "simple", _enter: function(event) {
|
can.onappend.figure(can, {action: "key", mode: chat.SIMPLE, _enter: function(event) {
|
||||||
if (event.ctrlKey) { meta.grep() } else {
|
if (event.ctrlKey) { meta.grep() } else {
|
||||||
meta[button](), can.onmotion.delay(can, function() { target.focus() })
|
meta[button](), can.onmotion.delay(can, function() { target.focus() })
|
||||||
}
|
}
|
||||||
|
@ -45,7 +45,7 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, target) { can.onmotion.clear(
|
|||||||
ondblclick: function(event) { if ([ice.POD, mdb.ZONE, mdb.ID].indexOf(key) > -1) { return }
|
ondblclick: function(event) { if ([ice.POD, mdb.ZONE, mdb.ID].indexOf(key) > -1) { return }
|
||||||
can.onmotion.modify(can, event.target, function(sub, value) {
|
can.onmotion.modify(can, event.target, function(sub, value) {
|
||||||
can.onaction.modifyTask(event, can, task, key, value)
|
can.onaction.modifyTask(event, can, task, key, value)
|
||||||
}, {name: key, action: key.indexOf(mdb.TIME) > 0? "date": "key", mode: "simple"})
|
}, {name: key, action: key.indexOf(mdb.TIME) > 0? "date": "key", mode: chat.SIMPLE})
|
||||||
},
|
},
|
||||||
}]) }), can.onimport.layout(can), task["extra.index"] && can.onimport._display(can, task)
|
}]) }), can.onimport.layout(can), task["extra.index"] && can.onimport._display(can, task)
|
||||||
},
|
},
|
||||||
|
@ -4,7 +4,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
|
|
||||||
can.page.style(can, can._output, html.MAX_WIDTH, can.ConfWidth())
|
can.page.style(can, can._output, html.MAX_WIDTH, can.ConfWidth())
|
||||||
can.page.Modify(can, target, msg.Result())
|
can.page.Modify(can, target, msg.Result())
|
||||||
can.page.Select(can, target, wiki.ITEM, function(item) { var data = item.dataset||{}
|
can.page.Select(can, target, wiki.STORY_ITEM, function(item) { var data = item.dataset||{}
|
||||||
can.page.style(can, item, can.base.Obj(data.style))
|
can.page.style(can, item, can.base.Obj(data.style))
|
||||||
can.core.CallFunc([can.onimport, data.type], [can, data, item])
|
can.core.CallFunc([can.onimport, data.type], [can, data, item])
|
||||||
})
|
})
|
||||||
@ -161,7 +161,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互",
|
|||||||
Volcanos(chat.ONACTION, {help: "控件交互",
|
Volcanos(chat.ONACTION, {help: "控件交互",
|
||||||
_trans: {view: "视图"},
|
_trans: {view: "视图"},
|
||||||
play: function(event, can) { var list = [], current = []
|
play: function(event, can) { var list = [], current = []
|
||||||
can.page.Select(can, can._output, wiki.ITEM, function(item) {
|
can.page.Select(can, can._output, wiki.STORY_ITEM, function(item) {
|
||||||
can.page.tagis(item, "h1", "h2", "h3") && list.push(current = []), current.push(item)
|
can.page.tagis(item, "h1", "h2", "h3") && list.push(current = []), current.push(item)
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -214,7 +214,7 @@ Volcanos(chat.ONACTION, {help: "控件交互",
|
|||||||
})
|
})
|
||||||
Volcanos(chat.ONDETAIL, {help: "交互操作", list: ["删除"],
|
Volcanos(chat.ONDETAIL, {help: "交互操作", list: ["删除"],
|
||||||
show: function(sub, which) { sub.page.styleClass(sub, sub.ui.content, chat.CONTENT)
|
show: function(sub, which) { sub.page.styleClass(sub, sub.ui.content, chat.CONTENT)
|
||||||
sub.page.Select(sub, sub.ui.content, wiki.DIV_PAGE, function(page, index) {
|
sub.page.Select(sub, sub.ui.content, html.DIV_PAGE, function(page, index) {
|
||||||
if (index == which || page == which) {
|
if (index == which || page == which) {
|
||||||
sub.page.Select(sub, page, sub.page.Keys(html.H1, html.H2, html.H3), function(item) { sub.Action("菜单", item.innerHTML) })
|
sub.page.Select(sub, page, sub.page.Keys(html.H1, html.H2, html.H3), function(item) { sub.Action("菜单", item.innerHTML) })
|
||||||
sub.onmotion.select(sub, sub.ui.project, html.DIV_ITEM, index)
|
sub.onmotion.select(sub, sub.ui.project, html.DIV_ITEM, index)
|
||||||
@ -226,17 +226,17 @@ Volcanos(chat.ONDETAIL, {help: "交互操作", list: ["删除"],
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
next: function(sub) {
|
next: function(sub) {
|
||||||
sub.page.Select(sub, sub.ui.content, sub.core.Keys(wiki.DIV_PAGE, ice.SHOW), function(page) {
|
sub.page.Select(sub, sub.ui.content, sub.core.Keys(html.DIV_PAGE, ice.SHOW), function(page) {
|
||||||
page.nextSibling? sub.sup.ondetail.show(sub, page.nextSibling): sub.user.toast(sub, cli.END)
|
page.nextSibling? sub.sup.ondetail.show(sub, page.nextSibling): sub.user.toast(sub, cli.END)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
prev: function(sub) {
|
prev: function(sub) {
|
||||||
sub.page.Select(sub, sub.ui.content, sub.core.Keys(wiki.DIV_PAGE, ice.SHOW), function(page) {
|
sub.page.Select(sub, sub.ui.content, sub.core.Keys(html.DIV_PAGE, ice.SHOW), function(page) {
|
||||||
page.previousSibling? sub.sup.ondetail.show(sub, page.previousSibling): sub.user.toast(sub, cli.END)
|
page.previousSibling? sub.sup.ondetail.show(sub, page.previousSibling): sub.user.toast(sub, cli.END)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
flash: function(sub) {
|
flash: function(sub) {
|
||||||
sub.core.Next(sub.page.Select(sub, sub.ui.content, wiki.DIV_PAGE), function(page, next) {
|
sub.core.Next(sub.page.Select(sub, sub.ui.content, html.DIV_PAGE), function(page, next) {
|
||||||
sub.sup.ondetail.show(sub, page), sub.onmotion.delay(sub, function() { next() })
|
sub.sup.ondetail.show(sub, page), sub.onmotion.delay(sub, function() { next() })
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
@ -31,14 +31,14 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
var action = can.onappend._action(can, [], ui.action, kit.Dict(
|
var action = can.onappend._action(can, [], ui.action, kit.Dict(
|
||||||
cli.CLOSE, function(event) { can.onmotion.hidden(can, target), can.onimport.layout(can) },
|
cli.CLOSE, function(event) { can.onmotion.hidden(can, target), can.onimport.layout(can) },
|
||||||
cli.CLEAR, function(event) { can.onmotion.clear(can, ui.output) },
|
cli.CLEAR, function(event) { can.onmotion.clear(can, ui.output) },
|
||||||
cli.SHOW, function(event) { can.onaction[cli.SHOW](event, can) },
|
ice.SHOW, function(event) { can.onaction[ice.SHOW](event, can) },
|
||||||
action,
|
action,
|
||||||
mdb.PLUGIN, function(event) { can.user.input(event, can, [ctx.INDEX, ctx.ARGS], function(data) {
|
mdb.PLUGIN, function(event) { can.user.input(event, can, [ctx.INDEX, ctx.ARGS], function(data) {
|
||||||
can.onimport.plug(can, data, function(sub) {
|
can.onimport.plug(can, data, function(sub) {
|
||||||
sub.ConfHeight(target.offsetHeight-4*html.ACTION_HEIGHT)
|
sub.ConfHeight(target.offsetHeight-4*html.ACTION_HEIGHT)
|
||||||
}, ui.output)
|
}, ui.output)
|
||||||
}) },
|
}) },
|
||||||
)); target._toggle = function(event, show) { action[show? cli.SHOW: cli.CLOSE](event) }
|
)); target._toggle = function(event, show) { action[show? ice.SHOW: cli.CLOSE](event) }
|
||||||
return ui
|
return ui
|
||||||
},
|
},
|
||||||
_title: function(can, title) {
|
_title: function(can, title) {
|
||||||
|
422
proto.js
422
proto.js
@ -1,28 +1,23 @@
|
|||||||
var kit = {
|
var kit = {
|
||||||
Dict: function() { var res = {}
|
Dict: function() { var res = {}; for (var i = 0; i < arguments.length; i += 2) {
|
||||||
for (var i = 0; i < arguments.length; i += 2) {
|
if (typeof arguments[i] == "object") {
|
||||||
if (typeof arguments[i] == "object") {
|
for (var k in arguments[i]) { res[k] = arguments[i][k] } i--
|
||||||
for (var k in arguments[i]) { res[k] = arguments[i][k] } i--
|
} else if (arguments[i] != undefined) {
|
||||||
} else if (arguments[i] != undefined) {
|
res[arguments[i]] = arguments[i+1]
|
||||||
res[arguments[i]] = arguments[i+1]
|
}
|
||||||
}
|
} return res },
|
||||||
} return res
|
|
||||||
},
|
|
||||||
proto: function(sub, sup) { return sub.__proto__ = sup, sub },
|
proto: function(sub, sup) { return sub.__proto__ = sup, sub },
|
||||||
}
|
}
|
||||||
var ice = {
|
var ice = {
|
||||||
TB: "\t", SP: " ", DF: ":", EQ: "=", AT: "@", PS: "/", PT: ".", FS: ",", NL: "\n", LT: "<", GT: ">",
|
TB: "\t", SP: " ", DF: ":", EQ: "=", AT: "@", PS: "/", PT: ".", FS: ",", NL: "\n", LT: "<", GT: ">",
|
||||||
OK: "ok", TRUE: "true", FALSE: "false", SUCCESS: "success", FAILURE: "failure", PROCESS: "process",
|
OK: "ok", TRUE: "true", FALSE: "false", SUCCESS: "success", FAILURE: "failure", PROCESS: "process",
|
||||||
|
|
||||||
AUTO: "auto", LIST: "list", BACK: "back", EXEC: "exec",
|
AUTO: "auto", HTTP: "http", HELP: "help", COPY: "copy",
|
||||||
SHOW: "show", HIDE: "hide", HELP: "help", HTTP: "http",
|
LIST: "list", BACK: "back", SHOW: "show", HIDE: "hide",
|
||||||
VIEW: "view", MODE: "mode", SHIP: "ship", COPY: "copy",
|
VIEW: "view", MODE: "mode", SHIP: "ship", EXEC: "exec",
|
||||||
|
|
||||||
POD: "pod", CTX: "ctx", CMD: "cmd", ARG: "arg", RES: "res",
|
POD: "pod", CTX: "ctx", CMD: "cmd", ARG: "arg", OPT: "opt",
|
||||||
RUN: "run", ERR: "err", OPT: "opt",
|
CAN: "can", RUN: "run", RES: "res", ERR: "err",
|
||||||
CAN: "can",
|
|
||||||
PWD: "./",
|
|
||||||
ErrWarn: "warn: ",
|
|
||||||
|
|
||||||
MSG_DETAIL: "detail",
|
MSG_DETAIL: "detail",
|
||||||
MSG_OPTION: "option",
|
MSG_OPTION: "option",
|
||||||
@ -40,12 +35,11 @@ var ice = {
|
|||||||
MSG_STATUS: "_status",
|
MSG_STATUS: "_status",
|
||||||
MSG_PREFIX: "_prefix",
|
MSG_PREFIX: "_prefix",
|
||||||
|
|
||||||
MSG_DISPLAY: "_display",
|
|
||||||
MSG_PROCESS: "_process",
|
MSG_PROCESS: "_process",
|
||||||
|
MSG_DISPLAY: "_display",
|
||||||
MSG_TOOLKIT: "_toolkit",
|
MSG_TOOLKIT: "_toolkit",
|
||||||
|
|
||||||
MSG_USERNAME: "user.name",
|
PROCESS_AGAIN: "_again",
|
||||||
MSG_USERNICK: "user.nick",
|
|
||||||
|
|
||||||
MSG_TITLE: "sess.title",
|
MSG_TITLE: "sess.title",
|
||||||
MSG_TOPIC: "sess.topic",
|
MSG_TOPIC: "sess.topic",
|
||||||
@ -53,47 +47,40 @@ var ice = {
|
|||||||
MSG_STORM: "sess.storm",
|
MSG_STORM: "sess.storm",
|
||||||
MSG_TOAST: "sess.toast",
|
MSG_TOAST: "sess.toast",
|
||||||
|
|
||||||
PROCESS_AGAIN: "_again",
|
MSG_USERNAME: "user.name",
|
||||||
|
MSG_USERNICK: "user.nick",
|
||||||
|
|
||||||
ErrWarn: "warn: ",
|
ErrWarn: "warn: ",
|
||||||
ErrNotLogin: "not login: ",
|
ErrNotLogin: "not login: ",
|
||||||
ErrNotRight: "not right: ",
|
ErrNotRight: "not right: ",
|
||||||
ErrNotFound: "not found: ",
|
ErrNotFound: "not found: ",
|
||||||
|
ErrNotValid: "not valid: ",
|
||||||
}
|
}
|
||||||
|
|
||||||
var ctx = {
|
var ctx = {
|
||||||
CONTEXT: "context", COMMAND: "command", CONFIG: "config",
|
CONTEXT: "context", COMMAND: "command", CONFIG: "config", INPUTS: "inputs", FEATURE: "feature",
|
||||||
INDEX: "index", ARGS: "args", STYLE: "style", DISPLAY: "display", ACTION: "action",
|
INDEX: "index", ARGS: "args", STYLE: "style", DISPLAY: "display", ACTION: "action",
|
||||||
INPUTS: "inputs", FEATURE: "feature",
|
|
||||||
}
|
}
|
||||||
var cli = {
|
var cli = {
|
||||||
DAEMON: "daemon",
|
DAEMON: "daemon", START: "start", STOP: "stop", OPEN: "open", CLOSE: "close", BEGIN: "begin", END: "end",
|
||||||
START: "start", STOP: "stop", OPEN: "open", CLOSE: "close", BEGIN: "begin", END: "end",
|
COLOR: "color", WHITE: "white", BLACK: "black", RED: "red", GREEN: "green", BLUE: "blue",
|
||||||
|
|
||||||
COLOR: "color",
|
|
||||||
RED: "red", GREEN: "green", BLUE: "blue",
|
|
||||||
YELLOW: "yellow", CYAN: "cyan", PURPLE: "purple", MAGENTA: "magenta",
|
YELLOW: "yellow", CYAN: "cyan", PURPLE: "purple", MAGENTA: "magenta",
|
||||||
WHITE: "white", BLACK: "black",
|
MAKE: "make", MAIN: "main", DONE: "done", COST: "cost", FROM: "from", CLEAR: "clear",
|
||||||
|
}
|
||||||
|
var aaa = {
|
||||||
|
LOGIN: "login", LOGOUT: "logout", INVITE: "invite", TOKEN: "token",
|
||||||
|
PASSWORD: "password", USERNAME: "username", USERNICK: "usernick", BACKGROUND: "background", AVATAR: "avatar",
|
||||||
|
LANGUAGE: "language", ENGLISH: "english", CHINESE: "chinese",
|
||||||
|
VOID: "void", TECH: "tech",
|
||||||
|
}
|
||||||
|
var web = {
|
||||||
|
SPACE: "space", DREAM: "dream", SHARE: "share",
|
||||||
|
WEBSITE: "website", REFRESH: "refresh", UPLOAD: "upload", DOWNLOAD: "download",
|
||||||
|
SHARE_CACHE: "/share/cache/",
|
||||||
|
|
||||||
MAKE: "make", MAIN: "main", EXEC: "exec", DONE: "done",
|
GET: "GET", PUT: "PUT", POST: "POST", DELETE: "DELETE",
|
||||||
CODE: "code", COST: "cost", BACK: "back", FROM: "from",
|
Accept: "Accept", ContentType: "Content-Type",
|
||||||
ERROR: "error", CLEAR: "clear", REFRESH: "refresh",
|
ContentJSON: "application/json", ContentFORM: "application/x-www-form-urlencoded",
|
||||||
SHOW: "show", FULL: "full",
|
|
||||||
}
|
|
||||||
var log = {
|
|
||||||
INFO: "info", WARN: "warn", ERROR: "error", DEBUG: "debug", TRACE: "trace",
|
|
||||||
}
|
|
||||||
var nfs = {
|
|
||||||
PWD: "./",
|
|
||||||
ZML: "zml", IML: "iml", TXT: "txt",
|
|
||||||
HTML: "html", CSS: "css", JS: "js", GO: "go", SH: "sh", CSV: "csv", JSON: "json",
|
|
||||||
PATH: "path", FILE: "file", LINE: "line", SIZE: "size",
|
|
||||||
SAVE: "save", LOAD: "load", TAGS: "tags", FIND: "find", GREP: "grep",
|
|
||||||
DIR: "dir", CAT: "cat", DEFS: "defs", TRASH: "trash",
|
|
||||||
DIR_ROOT: "dir_root",
|
|
||||||
SCRIPT: "script",
|
|
||||||
CONTENT: "content",
|
|
||||||
PNG: "png",
|
|
||||||
}
|
}
|
||||||
var mdb = {
|
var mdb = {
|
||||||
DICT: "dict", META: "meta", HASH: "hash", LIST: "list",
|
DICT: "dict", META: "meta", HASH: "hash", LIST: "list",
|
||||||
@ -103,89 +90,56 @@ var mdb = {
|
|||||||
SHORT: "short", FIELD: "field", TOTAL: "total", COUNT: "count", LIMIT: "limit",
|
SHORT: "short", FIELD: "field", TOTAL: "total", COUNT: "count", LIMIT: "limit",
|
||||||
INDEX: "index", VALUE: "value", EXTRA: "extra", ALIAS: "alias", EXPIRE: "expire",
|
INDEX: "index", VALUE: "value", EXTRA: "extra", ALIAS: "alias", EXPIRE: "expire",
|
||||||
|
|
||||||
CREATE: "create", REMOVE: "remove", INSERT: "insert", DELETE: "delete",
|
CREATE: "create", REMOVE: "remove", INSERT: "insert", DELETE: "delete", MODIFY: "modify", SELECT: "select",
|
||||||
MODIFY: "modify", SELECT: "select",
|
|
||||||
INPUTS: "inputs", PRUNES: "prunes", EXPORT: "export", IMPORT: "import",
|
INPUTS: "inputs", PRUNES: "prunes", EXPORT: "export", IMPORT: "import",
|
||||||
UPLOAD: "upload",
|
|
||||||
|
|
||||||
SEARCH: "search", ENGINE: "engine", RENDER: "render", PLUGIN: "plugin",
|
SEARCH: "search", ENGINE: "engine", RENDER: "render", PLUGIN: "plugin",
|
||||||
PAGE: "page", NEXT: "next", PREV: "prev", LIMIT: "limit", OFFEND: "offend",
|
|
||||||
MAIN: "main",
|
|
||||||
|
|
||||||
|
MAIN: "main", PAGE: "page", NEXT: "next", PREV: "prev", LIMIT: "limit", OFFEND: "offend",
|
||||||
FOREACH: "*", RANDOMS: "%",
|
FOREACH: "*", RANDOMS: "%",
|
||||||
}
|
}
|
||||||
var aaa = {
|
var ssh = {
|
||||||
PASSWORD: "password", USERNAME: "username", USERNICK: "usernick", BACKGROUND: "background", AVATAR: "avatar",
|
|
||||||
LANGUAGE: "language", ENGLISH: "english", CHINESE: "chinese",
|
|
||||||
LOGIN: "login", LOGOUT: "logout", INVITE: "invite",
|
|
||||||
TOKEN: "token",
|
|
||||||
VOID: "void", TECH: "tech",
|
|
||||||
}
|
}
|
||||||
var web = {
|
var nfs = {
|
||||||
SPACE: "space", DREAM: "dream", SHARE: "share",
|
PATH: "path", FILE: "file", LINE: "line", SIZE: "size",
|
||||||
REFRESH: "refresh",
|
SAVE: "save", LOAD: "load", TAGS: "tags", FIND: "find", GREP: "grep",
|
||||||
WEBSITE: "website",
|
DIR: "dir", CAT: "cat", DEFS: "defs", TRASH: "trash", SCRIPT: "script", CONTENT: "content", DIR_ROOT: "dir_root", PWD: "./",
|
||||||
SHARE_CACHE: "/share/cache/",
|
HTML: "html", CSS: "css", JS: "js", GO: "go", SH: "sh", CSV: "csv", JSON: "json",
|
||||||
DOWNLOAD: "download",
|
ZML: "zml", IML: "iml", TXT: "txt", PNG: "png",
|
||||||
|
|
||||||
GET: "GET", PUT: "PUT", POST: "POST", DELETE: "DELETE",
|
|
||||||
Accept: "Accept", ContentType: "Content-Type",
|
|
||||||
ContentJSON: "application/json", ContentFORM: "application/x-www-form-urlencoded",
|
|
||||||
}
|
}
|
||||||
var tcp = {
|
var tcp = {
|
||||||
HOST: "host", PORT: "port",
|
HOST: "host", PORT: "port",
|
||||||
}
|
}
|
||||||
var gdb = {
|
|
||||||
SIGNAL: "signal",
|
|
||||||
}
|
|
||||||
var lex = {
|
var lex = {
|
||||||
SPLIT: "split", PREFIX: "prefix",
|
SPLIT: "split", PREFIX: "prefix",
|
||||||
}
|
}
|
||||||
var ssh = {
|
var gdb = {
|
||||||
|
SIGNAL: "signal",
|
||||||
|
}
|
||||||
|
var log = {
|
||||||
|
INFO: "info", WARN: "warn", ERROR: "error", DEBUG: "debug", TRACE: "trace",
|
||||||
}
|
}
|
||||||
|
|
||||||
var code = {
|
var code = {
|
||||||
XTERM: "xterm", VIMER: "vimer", INNER: "inner", FAVOR: "favor",
|
FAVOR: "favor", XTERM: "xterm", INNER: "inner", VIMER: "vimer",
|
||||||
AUTOGEN: "autogen", COMPILE: "compile", BINPACK: "binpack", WEBPACK: "webpack", PUBLISH: "publish",
|
WEBPACK: "webpack", BINPACK: "binpack", AUTOGEN: "autogen", COMPILE: "compile", PUBLISH: "publish",
|
||||||
KEYWORD: "keyword",
|
COMMENT: "comment", KEYWORD: "keyword", CONSTANT: "constant", DATATYPE: "datatype", FUNCTION: "function",
|
||||||
|
TEMPLATE: "template", COMPLETE: "complete", NAVIGATE: "navigate",
|
||||||
COMMENT: "comment",
|
|
||||||
KEYWORD: "keyword",
|
|
||||||
CONSTANT: "constant",
|
|
||||||
DATATYPE: "datatype",
|
|
||||||
FUNCTION: "function",
|
|
||||||
|
|
||||||
TEMPLATE: "template",
|
|
||||||
COMPLETE: "complete",
|
|
||||||
NAVIGATE: "navigate",
|
|
||||||
}
|
}
|
||||||
var wiki = {
|
var wiki = {
|
||||||
TITLE: "title", BRIEF: "brief", REFER: "refer", SPARK: "spark",
|
TITLE: "title", BRIEF: "brief", REFER: "refer", SPARK: "spark",
|
||||||
ORDER: "order", TABLE: "table", CHART: "chart", IMAGE: "image", VIDEO: "video",
|
ORDER: "order", TABLE: "table", CHART: "chart", IMAGE: "image", VIDEO: "video",
|
||||||
FIELD: "field", SHELL: "shell", LOCAL: "local", PARSE: "parse",
|
FIELD: "field", SHELL: "shell", LOCAL: "local", PARSE: "parse",
|
||||||
CONTENT: "content",
|
NAVMENU: "navmenu", PREMENU: "premenu", CONTENT: "content",
|
||||||
|
STORY_ITEM: ".story", H2: "h2.story", H3: "h3.story",
|
||||||
NAVMENU: "navmenu", PREMENU: "premenu",
|
|
||||||
|
|
||||||
ITEM: ".story",
|
|
||||||
H2: "h2.story",
|
|
||||||
H3: "h3.story",
|
|
||||||
DIV_PAGE: "div.page",
|
|
||||||
}
|
}
|
||||||
var chat = {
|
var chat = {
|
||||||
LIB: "lib", PAGE: "page", PANEL: "panel", PLUGIN: "plugin", OUTPUT: "output", STORY: "story", FLOAT: "float",
|
LIB: "lib", PAGE: "page", PANEL: "panel", PLUGIN: "plugin", OUTPUT: "output", STORY: "story",
|
||||||
TOAST: "toast", CARTE: "carte", INPUT: "input", UPLOAD: "upload", CONTEXTS: "contexts",
|
TOAST: "toast", CARTE: "carte", INPUT: "input", UPLOAD: "upload", CONTEXTS: "contexts",
|
||||||
LAYOUT: "layout", PROJECT: "project", CONTENT: "content", DISPLAY: "display", PROFILE: "profile",
|
LAYOUT: "layout", PROJECT: "project", CONTENT: "content", DISPLAY: "display", PROFILE: "profile",
|
||||||
|
|
||||||
TITLE: "title", TOPIC: "topic", BLACK: "black", WHITE: "white", PRINT: "print",
|
TITLE: "title", TOPIC: "topic", BLACK: "black", WHITE: "white", PRINT: "print",
|
||||||
SHARE: "share", RIVER: "river", STORM: "storm", FIELD: "field",
|
SHARE: "share", RIVER: "river", STORM: "storm", FIELD: "field", TOOL: "tool",
|
||||||
PUBLIC: "public", PROTECTED: "protected", PRIVATE: "private",
|
STATE: "state", MENUS: "menus", SSO: "sso", LOCATION: "location",
|
||||||
USER: "user", TOOL: "tool", NODES: "nodes",
|
SIMPLE: "simple", FLOAT: "float", FULL: "full", CMD: "cmd",
|
||||||
|
|
||||||
AGENT: "agent", CHECK: "check", GRANT: "grant",
|
|
||||||
STATE: "state", MENUS: "menus", TRANS: "trans",
|
|
||||||
SSO: "sso", WEBSITE: "website",
|
|
||||||
LOCATION: "location",
|
|
||||||
|
|
||||||
libs: ["/lib/base.js", "/lib/core.js", "/lib/misc.js", "/lib/page.js", "/lib/user.js"],
|
libs: ["/lib/base.js", "/lib/core.js", "/lib/misc.js", "/lib/page.js", "/lib/user.js"],
|
||||||
panel_list: [
|
panel_list: [
|
||||||
@ -213,28 +167,18 @@ var chat = {
|
|||||||
"/plugin/local/team/plan.js",
|
"/plugin/local/team/plan.js",
|
||||||
"/plugin/local/mall/goods.js",
|
"/plugin/local/mall/goods.js",
|
||||||
],
|
],
|
||||||
PLUGIN_STATE_JS: "/plugin/state.js",
|
PLUGIN_STATE_JS: "/plugin/state.js", PLUGIN_INPUT_JS: "/plugin/input.js", PLUGIN_TABLE_JS: "/plugin/table.js",
|
||||||
PLUGIN_INPUT_JS: "/plugin/input.js",
|
|
||||||
PLUGIN_TABLE_JS: "/plugin/table.js",
|
|
||||||
|
|
||||||
ONENGINE: "onengine", ONDAEMON: "ondaemon", ONAPPEND: "onappend", ONLAYOUT: "onlayout", ONMOTION: "onmotion", ONKEYMAP: "onkeymap",
|
ONENGINE: "onengine", ONDAEMON: "ondaemon", ONAPPEND: "onappend", ONLAYOUT: "onlayout", ONMOTION: "onmotion", ONKEYMAP: "onkeymap",
|
||||||
ONIMPORT: "onimport", ONSYNTAX: "onsyntax", ONACTION: "onaction", ONDETAIL: "ondetail", ONFIGURE: "onfigure", ONEXPORT: "onexport",
|
ONIMPORT: "onimport", ONSYNTAX: "onsyntax", ONFIGURE: "onfigure", ONACTION: "onaction", ONDETAIL: "ondetail", ONEXPORT: "onexport", ONPLUGIN: "onplugin",
|
||||||
ONPLUGIN: "onplugin",
|
|
||||||
|
|
||||||
ONMAIN: "onmain", ONLOGIN: "onlogin", ONSEARCH: "onsearch",
|
ONMAIN: "onmain", ONLOGIN: "onlogin", ONSEARCH: "onsearch", ONREMOTE: "onremote",
|
||||||
ONSIZE: "onsize", ONTOAST: "ontoast", ONREMOTE: "onremote",
|
ONSIZE: "onsize", ONTOAST: "ontoast", ONSHARE: "onshare", ONPRINT: "onprint",
|
||||||
ONSHARE: "onshare",
|
ONRESIZE: "onresize", ONKEYUP: "onkeyup", ONKEYDOWN: "onkeydown", ONMOUSEENTER: "onmouseenter", ORIENTATIONCHANGE: "orientationchange",
|
||||||
ONKEYUP: "onkeyup",
|
ONSTORM_SELECT: "onstorm_select", ONACTION_NOTOOL: "onaction_notool", ONACTION_TOUCH: "onaction_touch", ONACTION_CMD: "onaction_cmd",
|
||||||
ONRESIZE: "onresize",
|
|
||||||
ONKEYDOWN: "onkeydown", ONMOUSEENTER: "onmouseenter", ORIENTATIONCHANGE: "orientationchange",
|
|
||||||
ONSTORM_SELECT: "onstorm_select", ONACTION_TOUCH: "onaction_touch", ONACTION_NOTOOL: "onaction_notool", ONACTION_CMD: "onaction_cmd",
|
|
||||||
ONOPENSEARCH: "onopensearch", ONSEARCH_FOCUS: "onsearch_focus", ONCOMMAND_FOCUS: "oncommand_focus",
|
ONOPENSEARCH: "onopensearch", ONSEARCH_FOCUS: "onsearch_focus", ONCOMMAND_FOCUS: "oncommand_focus",
|
||||||
ONPRINT: "onprint",
|
|
||||||
|
|
||||||
_INIT: "_init", _ENGINE: "_engine", _SEARCH: "_search", _OUTPUTS_CURRENT: "_outputs.-1",
|
_INIT: "_init", _ENGINE: "_engine", _SEARCH: "_search", _OUTPUTS_CURRENT: "_outputs.-1",
|
||||||
_NAMES: "_names", _TOAST: "_toast",
|
_NAMES: "_names", _TOAST: "_toast",
|
||||||
|
|
||||||
FLOAT: "float", FULL: "full", CMD: "cmd",
|
|
||||||
}
|
}
|
||||||
var team = {
|
var team = {
|
||||||
TASK: "task", PLAN: "plan",
|
TASK: "task", PLAN: "plan",
|
||||||
@ -254,15 +198,10 @@ var svg = {
|
|||||||
var html = {
|
var html = {
|
||||||
// FIELDSET
|
// FIELDSET
|
||||||
FIELDSET: "fieldset", LEGEND: "legend", OPTION: "option", ACTION: "action", OUTPUT: "output", STATUS: "status",
|
FIELDSET: "fieldset", LEGEND: "legend", OPTION: "option", ACTION: "action", OUTPUT: "output", STATUS: "status",
|
||||||
FORM_OPTION: "form.option", DIV_ACTION: "div.action", DIV_OUTPUT: "div.output", DIV_STATUS: "div.status",
|
FORM_OPTION: "form.option", DIV_ACTION: "div.action", DIV_OUTPUT: "div.output", DIV_STATUS: "div.status", DIV_CONTENT: "div.content",
|
||||||
DIV_CONTENT: "div.content",
|
FIELDSET_PANEL: "fieldset.panel", FIELDSET_PLUGIN: "fieldset.plugin", FIELDSET_STORY: "fieldset.story", FIELDSET_FLOAT: "fieldset.float",
|
||||||
FIELDSET_PANEL: "fieldset.panel", FIELDSET_PLUGIN: "fieldset.plugin", FIELDSET_STORY: "fieldset.story",
|
FIELDSET_HEAD: "fieldset.head", FIELDSET_FOOT: "fieldset.foot", FIELDSET_LEFT: "fieldset.left", FIELDSET_MAIN: "fieldset.main",
|
||||||
FIELDSET_HEAD: "fieldset.head", FIELDSET_FOOT: "fieldset.foot",
|
OPTION_ARGS: "select.args,input.args,textarea.args", INPUT_ARGS: "input.args,textarea.args", INPUT_BUTTON: "input[type=button]", INPUT_FILE: "input[type=file]",
|
||||||
FIELDSET_LEFT: "fieldset.left", FIELDSET_MAIN: "fieldset.main",
|
|
||||||
FIELDSET_AUTO: "fieldset.auto", FIELDSET_FLOAT: "fieldset.float",
|
|
||||||
OPTION_ARGS: "select.args,input.args,textarea.args",
|
|
||||||
INPUT_ARGS: "input.args,textarea.args",
|
|
||||||
INPUT_BUTTON: "input[type=button]", INPUT_FILE: "input[type=file]",
|
|
||||||
|
|
||||||
// HTML
|
// HTML
|
||||||
UPLOAD: "upload", USERNAME: "username", PASSWORD: "password",
|
UPLOAD: "upload", USERNAME: "username", PASSWORD: "password",
|
||||||
@ -275,18 +214,19 @@ var html = {
|
|||||||
WSS: "wss", SVG: "svg", CANVAS: "canvas", IFRAME: "iframe", CHROME: "chrome",
|
WSS: "wss", SVG: "svg", CANVAS: "canvas", IFRAME: "iframe", CHROME: "chrome",
|
||||||
|
|
||||||
// CSS
|
// CSS
|
||||||
CLASS: "class", FLOAT: "float", CLEAR: "clear", BOTH: "both",
|
CLASS: "class", DISPLAY: "display", BLOCK: "block", NONE: "none",
|
||||||
BACKGROUND: "background", SELECT: "select", HIDDEN: "hidden",
|
HEIGHT: "height", WIDTH: "width", PADDING: "padding", MARGIN: "margin", LEFT: "left", TOP: "top", RIGHT: "right", BOTTOM: "bottom",
|
||||||
DISPLAY: "display", BLOCK: "block", NONE: "none", FIXED: "fixed",
|
|
||||||
OPACITY: "opacity",
|
|
||||||
OVERFLOW: "overflow",
|
|
||||||
STROKE_WIDTH: "stroke-width", STROKE: "stroke", FILL: "fill", FONT_SIZE: "font-size", FONT_FAMILY: "font-family", MONOSPACE: "monospace",
|
|
||||||
SCROLL: "scroll", HEIGHT: "height", WIDTH: "width", LEFT: "left", TOP: "top", RIGHT: "right", BOTTOM: "bottom",
|
|
||||||
SPEED: "speed", PADDING: "padding", MARGIN: "margin",
|
|
||||||
MIN_HEIGHT: "min-height", MAX_HEIGHT: "max-height", MAX_WIDTH: "max-width", MIN_WIDTH: "min-width", MARGIN_TOP: "margin-top", MARGIN_X: "margin-x", MARGIN_Y: "margin-y",
|
MIN_HEIGHT: "min-height", MAX_HEIGHT: "max-height", MAX_WIDTH: "max-width", MIN_WIDTH: "min-width", MARGIN_TOP: "margin-top", MARGIN_X: "margin-x", MARGIN_Y: "margin-y",
|
||||||
|
STROKE_WIDTH: "stroke-width", STROKE: "stroke", FILL: "fill", FONT_SIZE: "font-size", FONT_FAMILY: "font-family", MONOSPACE: "monospace", TEXT_ANCHOR: "text-anchor",
|
||||||
|
SELECT: "select", HIDDEN: "hidden", TOGGLE: "toggle",
|
||||||
|
FLOAT: "float", CLEAR: "clear", BOTH: "both",
|
||||||
|
BACKGROUND: "background",
|
||||||
|
OVERFLOW: "overflow",
|
||||||
|
OPACITY: "opacity",
|
||||||
|
SCROLL: "scroll",
|
||||||
|
SPEED: "speed",
|
||||||
|
FIXED: "fixed",
|
||||||
PLUGIN_MARGIN: 10, ACTION_HEIGHT: 31, ACTION_MARGIN: 200,
|
PLUGIN_MARGIN: 10, ACTION_HEIGHT: 31, ACTION_MARGIN: 200,
|
||||||
TEXT_ANCHOR: "text-anchor",
|
|
||||||
TOGGLE: "toggle",
|
|
||||||
|
|
||||||
PAGE: "page", TABS: "tabs",
|
PAGE: "page", TABS: "tabs",
|
||||||
MENU: "menu", NODE: "node",
|
MENU: "menu", NODE: "node",
|
||||||
@ -324,91 +264,57 @@ var lang = {
|
|||||||
PS: "/",
|
PS: "/",
|
||||||
}
|
}
|
||||||
|
|
||||||
function shy(help, meta, list, cb) { var index = 0, args = arguments
|
function shy(help, meta, list, cb) { var args = arguments, i = 0
|
||||||
function next(type) { if (index < args.length && (!type || type == typeof args[index])) { return args[index++] } }
|
function next(type) { if (i < args.length && (!type || type == typeof args[i])) { return args[i++] } }
|
||||||
return cb = typeof args[args.length-1] == lang.FUNCTION?args[args.length-1]:function() {}, cb.help = next(lang.STRING)||"", cb.meta = next(lang.OBJECT)||{}, cb.list = next(lang.OBJECT)||[], cb
|
return cb = typeof args[args.length-1] == lang.FUNCTION? args[args.length-1]: function() {}, cb.help = next(lang.STRING)||"", cb.meta = next(lang.OBJECT)||{}, cb.list = next(lang.OBJECT)||[], cb
|
||||||
}; var _can_name = "", _can_path = ""
|
}; var _can_name = "", _can_path = ""
|
||||||
var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", pack: {}, cache: {}}, function(name, can, libs, cb) {
|
var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", cache: {}, pack: {}}, function(name, can, libs, cb) {
|
||||||
var meta = arguments.callee.meta, list = arguments.callee.list
|
var meta = arguments.callee.meta, list = arguments.callee.list
|
||||||
if (typeof name == lang.OBJECT) { var Config = name, panels = Config.panels||chat.panel_list
|
if (typeof name == lang.OBJECT) {
|
||||||
meta.libs = Config.libs||chat.libs, meta.iceberg = Config.iceberg||meta.iceberg
|
if (name.length > 0) { return Volcanos({panels: [
|
||||||
|
{name: "Header", help: "标题栏", pos: html.HIDE, state: [aaa.USERNICK]},
|
||||||
// 预加载
|
{name: "Action", help: "工作台", pos: html.MAIN, tool: name},
|
||||||
libs = []; for (var i = 0; i < panels.length; i++) { var p = panels[i]
|
{name: "Search", help: "搜索框", pos: html.AUTO},
|
||||||
p && (libs = libs.concat(p.list = p.list||["/panel/"+p.name+html._CSS, "/panel/"+p.name+html._JS]))
|
]}) }
|
||||||
}; libs = libs.concat(Config.plugin||chat.plugin_list)
|
var Config = name; name = Config.name||ice.CAN, kit.proto(meta, Config), _can_name = ""
|
||||||
|
meta.iceberg = Config.iceberg||meta.iceberg, meta.libs = Config.libs||chat.libs, panels = Config.panels||chat.panel_list
|
||||||
// 根模块
|
libs = [], panels.forEach(function(p) { p && (libs = libs.concat(p.list = p.list||["/panel/"+p.name+html._CSS, "/panel/"+p.name+html._JS])) })
|
||||||
_can_name = "", name = Config.name||ice.CAN, cb = can||function(can) {
|
libs = libs.concat(Config.plugin||chat.plugin_list)
|
||||||
can.onengine._init(can, can.Conf(Config), panels, Config._init, can._target)
|
cb = can||function(can) { can.onengine._init(can, can.Conf(Config), panels, Config._init, can._target) }
|
||||||
}, can = {_follow: name, _target: Config.target||meta.target, _height: Config.height||meta._height, _width: Config.width||meta._width}
|
can = {_follow: name, _target: Config.target||meta.target, _height: Config.height||meta._height, _width: Config.width||meta._width}
|
||||||
for (var k in Config) { can[k] = Config[k] }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
var proto = {_path: _can_path, _name: name, _load: function(name, each) {
|
var proto = {_path: _can_path, _name: name, _load: function(name, cbs) { var cache = meta.cache[name]||[]
|
||||||
// 加载缓存
|
for (list.reverse(); list.length > 0; list) { var sub = list.pop(); sub != can && cache.push(sub) } meta.cache[name] = cache
|
||||||
var cache = meta.cache[name]||[]; for (list.reverse(); list.length > 0; list) {
|
cache.forEach(function(sub) { var name = sub._name; if (typeof cbs == lang.FUNCTION && cbs(can, name, sub)) { return }
|
||||||
var sub = list.pop(); sub != can && cache.push(sub)
|
can[name] = can[name]||{}; for (var k in sub) { can[name].hasOwnProperty(k) || sub.hasOwnProperty(k) && (can[name][k] = sub[k]) }
|
||||||
}; meta.cache[name] = cache
|
})
|
||||||
|
|
||||||
// 加载模块
|
|
||||||
for (var i = 0; i < cache.length; i++) { var sub = cache[i], name = sub._name
|
|
||||||
if (typeof each == lang.FUNCTION && each(can, name, sub)) { continue }
|
|
||||||
!can[name] && (can[name] = {}); for (var k in sub) {
|
|
||||||
if (name == "onimport" && k == "_init") { can[name]["_last_init"] = sub[k] }
|
|
||||||
can[name].hasOwnProperty(k) || !sub.hasOwnProperty(k) || (can[name][k] = sub[k])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
requireModules: function(libs, cb, each) {
|
requireModules: function(libs, cb, cbs) {
|
||||||
for (var i = 0; i < libs.length; i++) {
|
for (var i = 0; i < libs.length; i++) { if (libs[i].indexOf(ice.HTTP) == 0 || libs[i].indexOf(ice.PS) == 0) { continue }
|
||||||
if (libs[i].indexOf("http") == 0) { continue }
|
if (libs[i].indexOf(html._CSS) == -1 && libs[i].indexOf(html._JS) == -1) { libs[i] = libs[i]+"/lib/"+libs[i]+html._JS }
|
||||||
if (libs[i].indexOf("/") == 0) { continue }
|
|
||||||
if (libs[i].indexOf(".css") == -1 && libs[i].indexOf(".js") == -1) { libs[i] = libs[i]+"/lib/"+libs[i]+".js" }
|
|
||||||
libs[i] = "/require/node_modules/"+libs[i]
|
libs[i] = "/require/node_modules/"+libs[i]
|
||||||
}
|
} can.require(libs, cb, cbs)
|
||||||
can.require(libs, cb, each)
|
|
||||||
},
|
},
|
||||||
require: function(libs, cb, each) { if (!libs || libs.length == 0) {
|
require: function(libs, cb, cbs) {
|
||||||
typeof cb == lang.FUNCTION && setTimeout(function() { cb(can) }, 10)
|
if (!libs || libs.length == 0) { return typeof cb == lang.FUNCTION && setTimeout(function() { cb(can) }, 10) }
|
||||||
return // 加载完成
|
if (libs[0] == undefined) { return can.require(libs.slice(1), cb, cbs) }
|
||||||
}
|
if (libs[0] == "") { libs[0] = can._name.replace(html._JS, html._CSS) }
|
||||||
|
if (libs[0][0] != ice.PS && libs[0].indexOf(ice.HTTP) != 0) { libs[0] = can._name.slice(0, can._name.lastIndexOf(ice.PS)+1)+libs[0] }
|
||||||
// 无效地址
|
var name = (libs[0].indexOf(ice.HTTP) == 0? libs[0]: libs[0].split("?")[0]).toLowerCase()
|
||||||
if (libs[0] == undefined) { return can.require(libs.slice(1), cb, each) }
|
function next() { can._load(name, cbs), can.require(libs.slice(1), cb, cbs) }
|
||||||
|
|
||||||
if (libs[0] == "") {
|
|
||||||
// 样式地址
|
|
||||||
libs[0] = can._name.replace(html._JS, html._CSS)
|
|
||||||
} else if (libs[0][0] != ice.PS && libs[0].indexOf(ice.HTTP) != 0) {
|
|
||||||
// 相对地址
|
|
||||||
libs[0] = can._name.slice(0, can._name.lastIndexOf(ice.PS)+1)+libs[0]
|
|
||||||
}
|
|
||||||
|
|
||||||
// 加载模块
|
|
||||||
libs[0] = libs[0].toLowerCase()
|
|
||||||
var name = libs[0].indexOf("http") == 0? libs[0]: libs[0].split("?")[0]
|
|
||||||
function next() { can._load(name, each), can.require(libs.slice(1), cb, each) }
|
|
||||||
meta.cache[name]? next(): (_can_path = libs[0], meta._load(name, next))
|
meta.cache[name]? next(): (_can_path = libs[0], meta._load(name, next))
|
||||||
},
|
},
|
||||||
request: function(event) { event = event||{}, event = event._event||event
|
request: function(event) { event = event||{}, event = event._event||event
|
||||||
var msg = event._msg||can.misc.Message(event, can); event._msg = msg
|
var msg = event._msg||can.misc.Message(event, can); event._msg = msg
|
||||||
function set(key, value) {
|
function set(key, value) { value == "" || msg.Option(key) || msg.Option(key, value) }
|
||||||
value == "" || msg.Option(key) || msg.Option(key, value)
|
can.core.List(arguments, function(item, index) { if (!item || index == 0) { return }
|
||||||
// typeof value == lang.FUNCTION || typeof value == lang.OBJECT || value == "" || msg.Option(key) || msg.Option(key, value)
|
can.base.isFunc(item.Option)? can.core.List(item.Option(), function(key) {
|
||||||
}
|
key.indexOf("_") == 0 || key.indexOf("user.") == 0 || set(key, item.Option(key))
|
||||||
|
}): can.core.Item(can.base.isFunc(item)? item(): item, set)
|
||||||
// 添加参数
|
|
||||||
can.core.List(arguments, function(option, index) { if (!option || index == 0) { return }
|
|
||||||
can.base.isFunc(option.Option)? can.core.List(option.Option(), function(key) {
|
|
||||||
if (key.indexOf("user.") == 0) { return }
|
|
||||||
if (key.indexOf("_") == 0) { return }
|
|
||||||
set(key, option.Option(key))
|
|
||||||
}): can.core.Item(can.base.isFunc(option)? option(): option, set)
|
|
||||||
}); return msg
|
}); return msg
|
||||||
},
|
},
|
||||||
|
|
||||||
actions: function(event, button) { can.runAction(event, button, []) },
|
|
||||||
runActionCommand: function(event, index, args, cb) { can.runAction(event, ice.RUN, can.misc.concat(can, [index], args), cb) },
|
runActionCommand: function(event, index, args, cb) { can.runAction(event, ice.RUN, can.misc.concat(can, [index], args), cb) },
|
||||||
runAction: function(event, action, args, cb) { can.request(event, {_handle: ice.TRUE}, can.Option())
|
runAction: function(event, action, args, cb) { can.request(event, {_handle: ice.TRUE}, can.Option())
|
||||||
can.run(event, can.misc.concat(can, [ctx.ACTION].concat(action), args), cb||function(msg) {
|
can.run(event, can.misc.concat(can, [ctx.ACTION].concat(action), args), cb||function(msg) {
|
||||||
@ -419,21 +325,13 @@ var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", pack:
|
|||||||
},
|
},
|
||||||
|
|
||||||
search: function(event, cmds, cb) {
|
search: function(event, cmds, cb) {
|
||||||
if (cmds && typeof cmds == lang.OBJECT && cmds.length > 0 && typeof cmds[0] == lang.OBJECT && cmds[0].length > 0 ) {
|
if (cmds && typeof cmds == lang.OBJECT && cmds.length > 0 && typeof cmds[0] == lang.OBJECT && cmds[0].length > 0 ) { cmds[0] = cmds[0].join(ice.PT) }
|
||||||
cmds[0] = cmds[0].join(ice.PT)
|
|
||||||
}
|
|
||||||
return can.run && can.run(event, [chat._SEARCH].concat(cmds), cb, true)
|
return can.run && can.run(event, [chat._SEARCH].concat(cmds), cb, true)
|
||||||
},
|
},
|
||||||
get: function(name, key, cb) { var value
|
get: function(name, key, cb) { var value; can.search({}, [can.core.Keys(name, chat.ONEXPORT, key)], cb||function(msg) { value = msg.Result() }); return value },
|
||||||
var res = can.search({}, [can.core.Keys(name, chat.ONEXPORT, key)], cb||function(msg) { value = msg.Result() })
|
set: function(name, key, value) { var msg = can.request(); msg.Option(key, value); return can.search(msg, [[name, chat.ONIMPORT, key]]) },
|
||||||
return value||res
|
|
||||||
},
|
|
||||||
set: function(name, key, value) { var msg = can.request({}); msg.Option(key, value)
|
|
||||||
return can.search(msg, [[name, chat.ONIMPORT, key]])
|
|
||||||
},
|
|
||||||
setHeaderMenu: function(list, cb) { can._menu && can.page.Remove(can, can._menu)
|
setHeaderMenu: function(list, cb) { can._menu && can.page.Remove(can, can._menu)
|
||||||
var msg = can.request({}, {trans: can.onaction._trans})
|
return can._menu = can.search(can.request({}, {trans: can.onaction._trans}), [["Header", chat.ONIMPORT, "menu"], can._name].concat(list), cb)
|
||||||
return can._menu = can.search(msg, [["Header", chat.ONIMPORT, "menu"], can._name].concat(list), cb)
|
|
||||||
},
|
},
|
||||||
setHeader: function(key, value) { return can.set("Header", key, value) },
|
setHeader: function(key, value) { return can.set("Header", key, value) },
|
||||||
getHeader: function(key, cb) { return can.get("Header", key, cb) },
|
getHeader: function(key, cb) { return can.get("Header", key, cb) },
|
||||||
@ -443,10 +341,10 @@ var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", pack:
|
|||||||
getActionSize: function(cb) { return can.get("Action", "size", cb) },
|
getActionSize: function(cb) { return can.get("Action", "size", cb) },
|
||||||
|
|
||||||
isPlugType: function(value) { return can.page.ClassList.has(can, can._fields, "plug") },
|
isPlugType: function(value) { return can.page.ClassList.has(can, can._fields, "plug") },
|
||||||
isSimpleMode: function(value) { return can.Mode() == "simple" },
|
isSimpleMode: function(value) { return can.Mode() == chat.SIMPLE },
|
||||||
isFloatMode: function(value) { return can.Mode() == "float" },
|
isFloatMode: function(value) { return can.Mode() == chat.FLOAT },
|
||||||
isFullMode: function(value) { return can.Mode() == "full" },
|
isFullMode: function(value) { return can.Mode() == chat.FULL },
|
||||||
isCmdMode: function(value) { return can.Mode() == "cmd" },
|
isCmdMode: function(value) { return can.Mode() == chat.CMD },
|
||||||
isAutoMode: function(value) { return can.Mode() == "" },
|
isAutoMode: function(value) { return can.Mode() == "" },
|
||||||
Mode: function(value) { return can.Conf(ice.MODE, value) },
|
Mode: function(value) { return can.Conf(ice.MODE, value) },
|
||||||
ConfDefault: function(value) { can.core.Item(value, function(k, v) { can.Conf(k) || can.Conf(k, v) }) },
|
ConfDefault: function(value) { can.core.Item(value, function(k, v) { can.Conf(k) || can.Conf(k, v) }) },
|
||||||
@ -454,71 +352,33 @@ var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", pack:
|
|||||||
ConfWidth: function(value) { return can.Conf(html.WIDTH, value) },
|
ConfWidth: function(value) { return can.Conf(html.WIDTH, value) },
|
||||||
Conf: function(key, value) { var res = can._conf
|
Conf: function(key, value) { var res = can._conf
|
||||||
for (var i = 0; i < arguments.length; i += 2) {
|
for (var i = 0; i < arguments.length; i += 2) {
|
||||||
if (typeof key == lang.OBJECT) {
|
if (typeof key == lang.OBJECT) { res = can.core.Value(can._conf, arguments[i]), i--; continue }
|
||||||
res = can.core.Value(can._conf, arguments[i]), i--
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
res = can.core.Value(can._conf, arguments[i], arguments[i+1])
|
res = can.core.Value(can._conf, arguments[i], arguments[i+1])
|
||||||
}
|
} return res == undefined && key.indexOf(ctx.FEATURE+ice.PT) == -1? can.Conf(can.core.Keys(ctx.FEATURE, key)): res
|
||||||
if (res == undefined && key.indexOf(ctx.FEATURE+ice.PT) == -1) {
|
|
||||||
return can.Conf(can.core.Keys(ctx.FEATURE, key))
|
|
||||||
}
|
|
||||||
return res
|
|
||||||
}, _conf: {},
|
}, _conf: {},
|
||||||
}; can = can||{}, kit.proto(can, proto), kit.proto(proto, meta)
|
}; can = can||{}, kit.proto(can, proto), kit.proto(proto, meta)
|
||||||
|
|
||||||
if (_can_name) { // 加入缓存
|
if (_can_name) { meta.cache[_can_name] = meta.cache[_can_name]||[], meta.cache[_can_name].push(can) } else { list.push(can) }
|
||||||
meta.cache[_can_name] = meta.cache[_can_name]||[], meta.cache[_can_name].push(can)
|
|
||||||
} else { // 加入队列
|
|
||||||
list.push(can)
|
|
||||||
}
|
|
||||||
_can_path = _can_name||_can_path
|
_can_path = _can_name||_can_path
|
||||||
|
if (libs && libs.length > 0) { for (var i = 0; i < libs.length; i++) { if (libs[i] == undefined) { continue }
|
||||||
if (can._follow) { libs = libs.concat(meta.libs, meta.volcano) }
|
if (libs[i] == "") { libs[i] = _can_path.replace(html._JS, html._CSS) }
|
||||||
if (libs && libs.length > 0) { // 解析参数
|
if (libs[i][0] != ice.PS && libs[i].indexOf(ice.HTTP) != 0) { libs[i] = _can_path.slice(0, _can_path.lastIndexOf(ice.PS)+1)+libs[i] }
|
||||||
for (var i = 0; i < libs.length; i++) {
|
} } if (can._follow) { libs = libs.concat(meta.libs, meta.volcano) }
|
||||||
if (libs[i] == undefined) {
|
|
||||||
|
|
||||||
} else if (libs[i] == "") {
|
|
||||||
libs[i] = _can_path.replace(html._JS, html._CSS)
|
|
||||||
} else if (libs[i][0] != ice.PS && libs[i].indexOf(ice.HTTP) != 0) {
|
|
||||||
libs[i] = _can_path.slice(0, _can_path.lastIndexOf(ice.PS)+1)+libs[i]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return can.require(libs, cb), can
|
return can.require(libs, cb), can
|
||||||
})
|
})
|
||||||
function can(tool) {
|
|
||||||
Volcanos({panels: [
|
|
||||||
{name: "Header", help: "标题栏", pos: html.HIDE, state: [aaa.USERNICK]},
|
|
||||||
{name: "Action", help: "工作台", pos: html.MAIN, tool: tool},
|
|
||||||
{name: "Search", help: "搜索框", pos: html.AUTO},
|
|
||||||
]})
|
|
||||||
}
|
|
||||||
|
|
||||||
try { if (typeof(window) == lang.OBJECT) { // nodejs
|
try { if (typeof(window) == lang.OBJECT) { // chrome
|
||||||
Volcanos.meta.target = document.body
|
Volcanos.meta.target = document.body, Volcanos.meta._height = window.innerHeight, Volcanos.meta._width = window.innerWidth
|
||||||
Volcanos.meta._width = window.innerWidth
|
Volcanos.meta._load = function(url, cb) { switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
||||||
Volcanos.meta._height = window.innerHeight
|
case nfs.CSS: var item = document.createElement(mdb.LINK); item.rel = "stylesheet", item.href = url, item.onload = cb, document.head.appendChild(item); break
|
||||||
Volcanos.meta._load = function(url, cb) {
|
default: var item = document.createElement(nfs.SCRIPT); item.src = url, item.onerror = cb, item.onload = cb, document.body.appendChild(item)
|
||||||
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
} }
|
||||||
case nfs.CSS:
|
|
||||||
var item = document.createElement(mdb.LINK)
|
|
||||||
item.rel = "stylesheet", item.type = "text/css"
|
|
||||||
item.href = url, item.onload = cb
|
|
||||||
return document.head.appendChild(item), item
|
|
||||||
case nfs.JS:
|
|
||||||
default:
|
|
||||||
var item = document.createElement(nfs.SCRIPT)
|
|
||||||
item.src = url, item.onload = cb, item.onerror = cb
|
|
||||||
return document.body.appendChild(item), item
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else { // nodejs
|
} else { // nodejs
|
||||||
global.kit = kit, global.ice = ice
|
global.kit = kit, global.ice = ice
|
||||||
global.ctx = ctx, global.cli = cli, global.web = web, global.aaa = aaa
|
global.ctx = ctx, global.cli = cli, global.aaa = aaa, global.web = web
|
||||||
global.mdb = mdb, global.ssh = ssh, global.nfs = nfs, global.tcp = tcp
|
global.mdb = mdb, global.ssh = ssh, global.nfs = nfs, global.tcp = tcp
|
||||||
global.code = code, global.wiki = wiki, global.chat = chat, global.team = team, global.mall = mall
|
global.code = code, global.wiki = wiki, global.chat = chat, global.team = team, global.mall = mall
|
||||||
global.svg = svg, global.html = html, global.lang = lang
|
global.svg = svg, global.html = html, global.lang = lang
|
||||||
global.shy = shy, global.Volcanos = Volcanos, global.can = can
|
global.shy = shy, global.Volcanos = Volcanos
|
||||||
} } catch (e) { console.log(e) }
|
} } catch (e) { console.log(e) }
|
||||||
|
Loading…
x
Reference in New Issue
Block a user