mirror of
https://shylinux.com/x/volcanos
synced 2025-04-25 08:48:06 +08:00
opt vimer.js
This commit is contained in:
parent
44983d30b6
commit
4a064c121b
10
frame.js
10
frame.js
@ -304,7 +304,7 @@ Volcanos(chat.ONAPPEND, {help: "渲染引擎", _init: function(can, meta, list,
|
|||||||
can.core.List(can.base.Obj(list, can.core.Value(can, [chat.ONEXPORT, mdb.LIST])), function(item) { item = can.base.isObject(item)? item: {name: item}
|
can.core.List(can.base.Obj(list, can.core.Value(can, [chat.ONEXPORT, mdb.LIST])), function(item) { item = can.base.isObject(item)? item: {name: item}
|
||||||
can.page.Append(can, status, [{view: can.base.join([html.ITEM, item.name]), title: item.name, list: [
|
can.page.Append(can, status, [{view: can.base.join([html.ITEM, item.name]), title: item.name, list: [
|
||||||
{text: [item.name, html.LABEL]}, {text: [": ", html.LABEL]}, {text: [(item.value||"")+"", html.SPAN, item.name]},
|
{text: [item.name, html.LABEL]}, {text: [": ", html.LABEL]}, {text: [(item.value||"")+"", html.SPAN, item.name]},
|
||||||
], }])
|
], onclick: function(event) { can.user.copy(event, can, item.value) }}])
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -482,9 +482,9 @@ Volcanos(chat.ONLAYOUT, {help: "页面布局", _init: function(can, target) { ta
|
|||||||
figure: function(event, can, target, right) { if (!event || !event.target) { return {} } target = target||can._fields||can._target
|
figure: function(event, can, target, right) { if (!event || !event.target) { return {} } target = target||can._fields||can._target
|
||||||
var rect = event.target == document.body? {left: window.innerWidth/2, top: 200, right: window.innerWidth/2, bottom: 200}: event.target.getBoundingClientRect()
|
var rect = event.target == document.body? {left: window.innerWidth/2, top: 200, right: window.innerWidth/2, bottom: 200}: event.target.getBoundingClientRect()
|
||||||
var layout = right? {left: rect.right, top: rect.top}: {left: rect.left, top: rect.bottom}
|
var layout = right? {left: rect.right, top: rect.top}: {left: rect.left, top: rect.bottom}
|
||||||
can.getActionSize(function(left, top, width, height) {
|
can.getActionSize(function(left, top, width, height) { left = left||0, top = top||0
|
||||||
if (layout.top+target.offsetHeight > top+height) {
|
if (layout.top+target.offsetHeight > window.innerHeight) {
|
||||||
layout.top = "", layout.bottom = right? html.ACTION_HEIGHT: top+height+html.ACTION_HEIGHT-rect.top
|
layout.top = "", layout.bottom = right? html.ACTION_HEIGHT: window.innerHeight-rect.top
|
||||||
}
|
}
|
||||||
if (layout.left+target.offsetWidth > left+width) {
|
if (layout.left+target.offsetWidth > left+width) {
|
||||||
layout.left = "", layout.right = 0
|
layout.left = "", layout.right = 0
|
||||||
@ -788,7 +788,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can,
|
|||||||
}
|
}
|
||||||
if (can.page.tagis(["input", "select", "textarea"], event.target)) { return }
|
if (can.page.tagis(["input", "select", "textarea"], event.target)) { return }
|
||||||
can.page.Select(can, document.body, can.page.Keys("fieldset.input.key.float"), function(item) {
|
can.page.Select(can, document.body, can.page.Keys("fieldset.input.key.float"), function(item) {
|
||||||
can.page.Remove(can, item)
|
// can.page.Remove(can, item)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
can.onkeymap._build(can), document.body.onkeydown = function(event) {
|
can.onkeymap._build(can), document.body.onkeydown = function(event) {
|
||||||
|
@ -185,7 +185,7 @@ body.simple fieldset.Action>div.output>fieldset.plugin.inner { box-shadow:none;
|
|||||||
body.simple fieldset.Action>div.output>fieldset.plugin.inner>legend { display:none; }
|
body.simple fieldset.Action>div.output>fieldset.plugin.inner>legend { display:none; }
|
||||||
body.simple fieldset.Action>div.output>fieldset.plugin.inner>form.option { display:none; }
|
body.simple fieldset.Action>div.output>fieldset.plugin.inner>form.option { display:none; }
|
||||||
body.simple fieldset.Action>div.output>fieldset.plugin.inner>div.action { display:none; }
|
body.simple fieldset.Action>div.output>fieldset.plugin.inner>div.action { display:none; }
|
||||||
body.simple fieldset.Action>div.output>fieldset.plugin.inner>div.status { display:none; }
|
/* body.simple fieldset.Action>div.output>fieldset.plugin.inner>div.status { display:none; } */
|
||||||
|
|
||||||
body.simple div.output.card div.item { min-width:240px; border-radius:5px; box-shadow:2px 2px 6px 1px gray; }
|
body.simple div.output.card div.item { min-width:240px; border-radius:5px; box-shadow:2px 2px 6px 1px gray; }
|
||||||
body.simple div.output.card div.item:hover { background-color:white; box-shadow:5px 5px 10px 5px gray; }
|
body.simple div.output.card div.item:hover { background-color:white; box-shadow:5px 5px 10px 5px gray; }
|
||||||
@ -301,7 +301,7 @@ body.black a { color:yellow; }
|
|||||||
div.action>div.item { float:left; clear:none; }
|
div.action>div.item { float:left; clear:none; }
|
||||||
|
|
||||||
div.project div.zone>div.name { background-color:cornflowerblue; color:white; font-family:monospace; font-size:1.1rem; text-align:center; padding:5px; clear:both; }
|
div.project div.zone>div.name { background-color:cornflowerblue; color:white; font-family:monospace; font-size:1.1rem; text-align:center; padding:5px; clear:both; }
|
||||||
div.project div.item>div.name { padding:0 16px; }
|
div.project div.item>div.name { padding-left:16px; }
|
||||||
div.project div.zone>div.action>div.item { float:right; clear:none; padding:0; margin:0; }
|
div.project div.zone>div.action>div.item { float:right; clear:none; padding:0; margin:0; }
|
||||||
div.project div.zone>div.action>div.item input[type=text] { background-color:#ff000000; padding-left:10px; color:white; border:none; }
|
div.project div.zone>div.action>div.item input[type=text] { background-color:#ff000000; padding-left:10px; color:white; border:none; }
|
||||||
body.white.simple fieldset.plugin div.output.json div.item span { color:black; }
|
body.white.simple fieldset.plugin div.output.json div.item span { color:black; }
|
||||||
|
@ -106,7 +106,7 @@ Volcanos(chat.ONPLUGIN, {help: "注册插件",
|
|||||||
msg.Push("value", 300)
|
msg.Push("value", 300)
|
||||||
msg.Push("value", 400)
|
msg.Push("value", 400)
|
||||||
}),
|
}),
|
||||||
"can.code.inner.plugin": shy("插件", {}, [{type: "button", name: "list", action: "auto"}, "back"], function(can, msg, cmds) {}),
|
"can.code.inner._plugin": shy("插件", {}, [{type: "button", name: "list", action: "auto"}, "back"], function(can, msg, cmds) {}),
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can, target) {
|
Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can, target) {
|
||||||
can.onkeymap._build(can), can.onengine.listen(can, chat.ONKEYDOWN, function(msg, model) {
|
can.onkeymap._build(can), can.onengine.listen(can, chat.ONKEYDOWN, function(msg, model) {
|
||||||
|
@ -4,13 +4,11 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
can.tabview = can.tabview||{}, can.history = can.history||[], can.toolkit = {}, can.extentions = {}
|
can.tabview = can.tabview||{}, can.history = can.history||[], can.toolkit = {}, can.extentions = {}
|
||||||
can.profile_size = {}, can.display_size = {}
|
can.profile_size = {}, can.display_size = {}
|
||||||
|
|
||||||
can.onengine.plugin(can, can.onplugin)
|
|
||||||
can.onmotion.clear(can), can.onlayout.profile(can)
|
can.onmotion.clear(can), can.onlayout.profile(can)
|
||||||
can.page.styleWidth(can, can.ui.project, 240)
|
can.page.styleWidth(can, can.ui.project, 240)
|
||||||
can.onimport._project(can, can.ui.project)
|
can.onimport._project(can, can.ui.project)
|
||||||
can.onimport._profile(can, can.ui.profile)
|
can.onimport._profile(can, can.ui.profile)
|
||||||
can.onimport._display(can, can.ui.display)
|
can.onimport._display(can, can.ui.display)
|
||||||
can.base.isFunc(cb) && cb(msg)
|
|
||||||
can.ui._content = can.ui.content
|
can.ui._content = can.ui.content
|
||||||
|
|
||||||
switch (can.Mode()) {
|
switch (can.Mode()) {
|
||||||
@ -32,6 +30,8 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
} else { can.isCmdMode() || (can.tabview[can.onexport.keys(can)] = msg)
|
} else { can.isCmdMode() || (can.tabview[can.onexport.keys(can)] = msg)
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE))
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE))
|
||||||
}
|
}
|
||||||
|
can.onengine.plugin(can, can.onplugin)
|
||||||
|
can.base.isFunc(cb) && cb(msg)
|
||||||
},
|
},
|
||||||
_project: function(can, target) {
|
_project: function(can, target) {
|
||||||
target._toggle = function(event) { can.onmotion.toggle(can, target), can.onimport.layout(can) }
|
target._toggle = function(event) { can.onmotion.toggle(can, target), can.onimport.layout(can) }
|
||||||
@ -107,9 +107,9 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
|
|
||||||
if (can.isCmdMode()) {
|
if (can.isCmdMode()) {
|
||||||
var rest = can.ui.display.offsetHeight+can.ui._tabs.offsetHeight+can.ui._path.offsetHeight+4
|
var rest = can.ui.display.offsetHeight+can.ui._tabs.offsetHeight+can.ui._path.offsetHeight+4
|
||||||
can.page.styleHeight(can, can.ui.content, height+2*html.ACTION_HEIGHT-rest)
|
can.page.styleHeight(can, can.ui.content, height+html.ACTION_HEIGHT-rest)
|
||||||
can.page.styleHeight(can, can.ui.profile_output, height+html.ACTION_HEIGHT-can.ui.display.offsetHeight)
|
can.page.styleHeight(can, can.ui.profile_output, height-can.ui.display.offsetHeight)
|
||||||
can.page.styleHeight(can, can.ui.project, height+2*html.ACTION_HEIGHT)
|
can.page.styleHeight(can, can.ui.project, height+html.ACTION_HEIGHT)
|
||||||
} else { var rest = can.ui.display.offsetHeight; if (height < 320) { height = 320 }
|
} else { var rest = can.ui.display.offsetHeight; if (height < 320) { height = 320 }
|
||||||
if (!can.isFullMode()) {
|
if (!can.isFullMode()) {
|
||||||
can._min_height = can._min_height||height, height >= can._min_height && (can._min_height = height)
|
can._min_height = can._min_height||height, height >= can._min_height && (can._min_height = height)
|
||||||
@ -132,14 +132,14 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
project: function(can, path) {
|
project: function(can, path) {
|
||||||
can.onimport.zone(can, [
|
can.onimport.zone(can, [
|
||||||
{name: "source", _init: function(target) { var total = 0
|
{name: "source", _init: function(target) { var total = 0
|
||||||
function show(target) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
function show(path, target) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
||||||
can.core.List(list, function(item) { if (can.Option(nfs.FILE).indexOf(item.path) == 0) { item.expand = true } })
|
can.core.List(list, function(item) { if (can.Option(nfs.FILE).indexOf(item.path) == 0) { item.expand = true } })
|
||||||
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) {
|
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) {
|
||||||
can.onimport.tabview(can, path, item.path) // 显示文件
|
can.onimport.tabview(can, path, item.path) // 显示文件
|
||||||
}, target), can.Status("文件数", total += msg.Length())
|
}, target), can.Status("文件数", total += msg.Length())
|
||||||
}, true) } if (path.length == 1) { return show(target) }
|
}, true) } if (path.length == 1) { return show(path[0], target) }
|
||||||
|
|
||||||
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(target) }} }), target)
|
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(path, target) }} }), target)
|
||||||
can.onmotion.delay(can, function() { target.previousSibling.innerHTML = "" })
|
can.onmotion.delay(can, function() { target.previousSibling.innerHTML = "" })
|
||||||
}},
|
}},
|
||||||
{name: "plugin", _init: function(target) {
|
{name: "plugin", _init: function(target) {
|
||||||
@ -147,47 +147,6 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys("can", item.index), ctx.INDEX) // 显示插件
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys("can", item.index), ctx.INDEX) // 显示插件
|
||||||
}, target)
|
}, target)
|
||||||
}},
|
}},
|
||||||
{name: "module", _init: function(target) {
|
|
||||||
can.runAction(can.request({}, {fields: ctx.INDEX}), ctx.COMMAND, [mdb.SEARCH, ctx.COMMAND], function(msg) {
|
|
||||||
can.onimport.tree(can, msg.Table(), ctx.INDEX, ice.PT, function(event, item) {
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), item.index, ctx.INDEX) // 显示模块
|
|
||||||
}, target)
|
|
||||||
})
|
|
||||||
}},
|
|
||||||
{name: "dreams", _init: function(target) { var call = arguments.callee
|
|
||||||
can.runAction({}, ice.RUN, [web.DREAM], function(msg) {
|
|
||||||
msg.Table(function(item) {
|
|
||||||
function carte(event) {
|
|
||||||
var list = []; switch (item.status) {
|
|
||||||
case "start": list = ["open", "stop"]; break
|
|
||||||
case "stop": list = ["start", "trash"]; break
|
|
||||||
}
|
|
||||||
can.user.carteRight(event, can, {}, list, function(event, action) {
|
|
||||||
can.runAction(can.request({}, item), ice.RUN, [web.DREAM, ctx.ACTION, action], function(msg) {
|
|
||||||
can.onmotion.clear(can, target), call(target)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
var color = item.status == "start"? "": "gray"
|
|
||||||
can.page.Append(can, target, [{view: html.ITEM, list: [{text: [item.name, html.DIV], style: {color: color}, onmouseenter: carte}], onclick: function() {
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), item.name, web.DREAM) // 显示空间
|
|
||||||
}}])
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}, _menu: shy("", {
|
|
||||||
"create": function(event, zone) {
|
|
||||||
can.user.input(event, can, [mdb.NAME], function(list) {
|
|
||||||
can.runAction({}, ice.RUN, [web.DREAM, cli.START, list[0]], function(msg) {
|
|
||||||
can.onmotion.clear(can, zone._target), zone._init(zone._target), can.user.toastSuccess(can)
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(mdb.NAME), web.DREAM) // 显示空间
|
|
||||||
})
|
|
||||||
})
|
|
||||||
},
|
|
||||||
"refresh": function(event, zone) {
|
|
||||||
can.onmotion.clear(can, zone._target), zone._init(zone._target)
|
|
||||||
},
|
|
||||||
}, ["create", "refresh"], function() {})},
|
|
||||||
], can.ui.project)
|
], can.ui.project)
|
||||||
},
|
},
|
||||||
history: function(can, push) {
|
history: function(can, push) {
|
||||||
@ -257,7 +216,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
if (meta.msg == true) { meta.msg = false, sub.Update() }
|
if (meta.msg == true) { meta.msg = false, sub.Update() }
|
||||||
}, sub.select = function() { return sub._legend.click(), sub }
|
}, sub.select = function() { return sub._legend.click(), sub }
|
||||||
sub.onaction.close = function() { sub.select() }
|
sub.onaction.close = function() { sub.select() }
|
||||||
sub._legend.onmouseenter = null
|
// sub._legend.onmouseenter = null
|
||||||
can.base.isFunc(cb) && cb(sub)
|
can.base.isFunc(cb) && cb(sub)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
@ -290,7 +249,7 @@ Volcanos(chat.ONPLUGIN, {help: "注册插件",
|
|||||||
msg.Push("key", "func")
|
msg.Push("key", "func")
|
||||||
msg.Push("value", func.toString())
|
msg.Push("value", func.toString())
|
||||||
} else if (!cmds[0] || !cmds[1]) {
|
} else if (!cmds[0] || !cmds[1]) {
|
||||||
func.help && msg.Push(kit.Dict("mode", mode, "key", key, "help", func.help))
|
msg.Push(kit.Dict("mode", mode, "key", key, "help", func.help||func.toString()))
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
}), msg.StatusTimeCount()
|
}), msg.StatusTimeCount()
|
||||||
@ -388,32 +347,22 @@ Volcanos(chat.ONSYNTAX, {help: "语法高亮", list: ["keyword", "prefix", "line
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONKEYMAP, {help: "导入数据",
|
Volcanos(chat.ONKEYMAP, {help: "导入数据",
|
||||||
_plugin: function(event, can) {},
|
|
||||||
_normal: function(event, can) {},
|
|
||||||
_insert: function(event, can) {},
|
|
||||||
_mode: {
|
_mode: {
|
||||||
plugin: {
|
plugin: {
|
||||||
Escape: shy(cli.CLEAR, function(event, can) { can.onaction.clear(event, can) }),
|
Escape: shy("切换模式", function(event, can) { can.onaction.clear(event, can) }),
|
||||||
g: shy("搜索", function(event, can) { can.onaction["搜索"](event, can) }),
|
g: shy("搜索", function(event, can) { can.onaction["搜索"](event, can) }),
|
||||||
f: shy("打开文件", function(event, can) { can.onaction["打开"](event, can) }),
|
f: shy("打开文件", function(event, can) { can.onaction["打开"](event, can) }),
|
||||||
t: shy("添加命令", function(event, can) { can.onaction["添加"](event, can) }),
|
|
||||||
p: shy("添加插件", function(event, can) { can.onaction["插件"](event, can) }),
|
|
||||||
e: shy("添加扩展", function(event, can) { can.onaction["扩展"](event, can) }),
|
|
||||||
r: shy("执行命令", function(event, can) { can.onaction[cli.EXEC](event, can) }),
|
r: shy("执行命令", function(event, can) { can.onaction[cli.EXEC](event, can) }),
|
||||||
v: shy("渲染界面", function(event, can) { can.onaction[cli.SHOW](event, can) }),
|
v: shy("渲染界面", function(event, can) { can.onaction[cli.SHOW](event, can) }),
|
||||||
|
|
||||||
j: function(event, can) { can.current.scroll(1) },
|
j: shy("向下滚动", function(event, can) { can.current.scroll(1) }),
|
||||||
k: function(event, can) { can.current.scroll(-1) },
|
k: shy("向上滚动", function(event, can) { can.current.scroll(-1) }),
|
||||||
J: function(event, can) { can.current.scroll(can.current.window()-3) },
|
J: shy("向下滚屏", function(event, can) { can.current.scroll(can.current.window()-3) }),
|
||||||
K: function(event, can) { can.current.scroll(-can.current.window()+3) },
|
K: shy("向上滚屏", function(event, can) { can.current.scroll(-can.current.window()+3) }),
|
||||||
|
|
||||||
i: function(event, can) { can.onkeymap._insert(event, can) },
|
|
||||||
n: function(event, can) { can.onkeymap._normal(event, can) },
|
|
||||||
":": function(event, can) { can.onimport.toolkit(can, {index: "cli.system"}, function(sub) { can.toolkit["cli.system"] = sub.select() }) },
|
|
||||||
},
|
},
|
||||||
}, _engine: {},
|
}, _engine: {},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONACTION, {help: "控件交互", list: ["搜索", "打开", "添加", "插件", "扩展"],
|
Volcanos(chat.ONACTION, {help: "控件交互", list: ["搜索", "打开"],
|
||||||
_trans: {load: "加载", link: "链接", width: "宽度", height: "高度", website: "网页"},
|
_trans: {load: "加载", link: "链接", width: "宽度", height: "高度", website: "网页"},
|
||||||
"搜索": function(event, can) {
|
"搜索": function(event, can) {
|
||||||
can.user.input(event, can, [mdb.NAME, [ctx.ACTION, nfs.TAGS, nfs.GREP, cli.MAKE]], function(data) {
|
can.user.input(event, can, [mdb.NAME, [ctx.ACTION, nfs.TAGS, nfs.GREP, cli.MAKE]], function(data) {
|
||||||
@ -421,19 +370,6 @@ Volcanos(chat.ONACTION, {help: "控件交互", list: ["搜索", "打开", "添
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
"打开": function(event, can) { can.user.input(event, can, [nfs.FILE], function(list) { can.onimport.tabview(can, can.Option(nfs.PATH), list[0]) }) },
|
"打开": function(event, can) { can.user.input(event, can, [nfs.FILE], function(list) { can.onimport.tabview(can, can.Option(nfs.PATH), list[0]) }) },
|
||||||
"添加": function(event, can) { can.user.input(event, can, [ctx.INDEX], function(list) { can.onimport.tabview(can, can.Option(nfs.PATH), list[0], ctx.INDEX) }) },
|
|
||||||
"插件": function(event, can) {
|
|
||||||
can.user.input(event, can, [ctx.INDEX], function(list) {
|
|
||||||
var sub = can.toolkit[list[0]]; if (sub) { sub.select(); return }
|
|
||||||
can.onimport.toolkit(can, {index: list[0]}, function(sub) { can.toolkit[list[0]] = sub.select() })
|
|
||||||
})
|
|
||||||
},
|
|
||||||
"扩展": function(event, can) {
|
|
||||||
can.user.input(event, can, ["url"], function(list) {
|
|
||||||
var sub = can.extentions[list[0]]; if (sub) { sub.select(); return }
|
|
||||||
can.onimport.exts(can, list[0], function(sub) { can.extentions[list[0]] = sub.select() })
|
|
||||||
})
|
|
||||||
},
|
|
||||||
sess: function(event, can) { can.onexport.sess(can), can.user.toastSuccess(can) },
|
sess: function(event, can) { can.onexport.sess(can), can.user.toastSuccess(can) },
|
||||||
load: function(event, can) {
|
load: function(event, can) {
|
||||||
var file = can.base.Path("/require/", can.Option(nfs.PATH), can.Option(nfs.FILE))
|
var file = can.base.Path("/require/", can.Option(nfs.PATH), can.Option(nfs.FILE))
|
||||||
@ -456,14 +392,9 @@ Volcanos(chat.ONACTION, {help: "控件交互", list: ["搜索", "打开", "添
|
|||||||
if (can.page.Select(can, can._root._target, ".input.float", function(item) { return can.page.Remove(can, item) }).length > 0) { return }
|
if (can.page.Select(can, can._root._target, ".input.float", function(item) { return can.page.Remove(can, item) }).length > 0) { return }
|
||||||
if (can.page.Select(can, can._status, "legend.select", function(item) { return item.click(), item }).length > 0) { return }
|
if (can.page.Select(can, can._status, "legend.select", function(item) { return item.click(), item }).length > 0) { return }
|
||||||
|
|
||||||
if (can.ui.profile.style.display == "") {
|
if (can.ui.display.style.display == "") { return can.onmotion.hidden(can, can.ui.display), can.onimport.layout(can) }
|
||||||
can.onmotion.hidden(can, can.ui.profile)
|
if (can.ui.profile.style.display == "") { return can.onmotion.hidden(can, can.ui.profile), can.onimport.layout(can) }
|
||||||
} else if (can.ui.display.style.display == "") {
|
can.onmotion.toggle(can, can.ui.project), can.onimport.layout(can)
|
||||||
can.onmotion.hidden(can, can.ui.display)
|
|
||||||
} else {
|
|
||||||
can.onmotion.toggle(can, can.ui.project)
|
|
||||||
}
|
|
||||||
can.onimport.layout(can)
|
|
||||||
},
|
},
|
||||||
back: function(event, can) { can.history.pop(); var last = can.history.pop()
|
back: function(event, can) { can.history.pop(); var last = can.history.pop()
|
||||||
last && can.onimport.tabview(can, last.path, last.file, last.line)
|
last && can.onimport.tabview(can, last.path, last.file, last.line)
|
||||||
@ -543,14 +474,7 @@ Volcanos(chat.ONACTION, {help: "控件交互", list: ["搜索", "打开", "添
|
|||||||
searchLine: function(event, can, value) { if (!can.ui.search) { return }
|
searchLine: function(event, can, value) { if (!can.ui.search) { return }
|
||||||
can.ui.search.Update(event, [ctx.ACTION, nfs.TAGS, value.trim()])
|
can.ui.search.Update(event, [ctx.ACTION, nfs.TAGS, value.trim()])
|
||||||
},
|
},
|
||||||
favorLine: function(can, value) {
|
favorLine: function(event, can) { },
|
||||||
can.user.input(event, can, [{name: "zone", value: "hi"}, {name: "name", value: "hello"}], function(data) {
|
|
||||||
can.runAction(event, code.FAVOR, [ctx.ACTION, mdb.INSERT, mdb.ZONE, data.zone||"",
|
|
||||||
mdb.TYPE, can.parse, mdb.NAME, data.name||"", mdb.TEXT, (value||"").trimRight(),
|
|
||||||
nfs.PATH, can.Option(nfs.PATH), nfs.FILE, can.Option(nfs.FILE), nfs.LINE, can.Option(nfs.LINE),
|
|
||||||
])
|
|
||||||
})
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONEXPORT, {help: "导出数据", list: ["文件数", "解析器", "文件名", "当前行", "跳转数", "标签数"],
|
Volcanos(chat.ONEXPORT, {help: "导出数据", list: ["文件数", "解析器", "文件名", "当前行", "跳转数", "标签数"],
|
||||||
sess: function(can) { can.user.localStorage(can, "web.code.inner.sess", {"plug": can.onexport.plug(can), "exts": can.onexport.exts(can), "tabs": can.onexport.tabs(can)}) },
|
sess: function(can) { can.user.localStorage(can, "web.code.inner.sess", {"plug": can.onexport.plug(can), "exts": can.onexport.exts(can), "tabs": can.onexport.tabs(can)}) },
|
||||||
|
@ -7,7 +7,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, args, cb) {
|
|||||||
},
|
},
|
||||||
))) { return }
|
))) { return }
|
||||||
|
|
||||||
can.runAction(event, code.FAVOR, cmds, function(msg) { var sub = msg._can
|
can.runAction(event, code.FAVOR, cmds, function(msg) {
|
||||||
sub.onmotion.clear(sub), sub.onappend.table(sub, msg, function(value, key, index, line) {
|
sub.onmotion.clear(sub), sub.onappend.table(sub, msg, function(value, key, index, line) {
|
||||||
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 }
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, target) {
|
Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, target) {
|
||||||
can.require(["inner.js"], function(can) { can.onimport.inner_init(can, msg, function() { can.undo = [], can.redo = []
|
can.require(["inner.js"], function(can) { can.onimport.inner_init(can, msg, function() { can.undo = [], can.redo = []
|
||||||
can.onimport._input(can), can.onkeymap._build(can), can.onkeymap._plugin({}, can), can.base.isFunc(cb) && cb(msg)
|
can.onimport._input(can), can.onkeymap._build(can), can.onkeymap._plugin({}, can)
|
||||||
|
can.onengine.plugin(can, can.onplugin)
|
||||||
|
can.base.isFunc(cb) && cb(msg)
|
||||||
|
|
||||||
}, target) }, function(can, name, sub) { name == chat.ONIMPORT && (can.onimport.inner_init = sub._init)
|
}, target) }, function(can, name, sub) { name == chat.ONIMPORT && (can.onimport.inner_init = sub._init)
|
||||||
if (name == chat.ONACTION) { can._trans = can.base.Copy(can._trans||{}, sub._trans) }
|
if (name == chat.ONACTION) { can._trans = can.base.Copy(can._trans||{}, sub._trans) }
|
||||||
if (name == chat.ONKEYMAP) { can.base.Copy(can.onkeymap._mode, sub._mode)
|
|
||||||
can.core.Item(can.onkeymap._mode.normal, function(k, v) { sub._mode.plugin[k] || (sub._mode.plugin[k] = v) })
|
|
||||||
can.core.Item(sub._mode.plugin, function(k, v) { can.onkeymap._mode.normal[k] || (can.onkeymap._mode.normal[k] = v) })
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
_input: function(can) {
|
_input: function(can) {
|
||||||
@ -15,7 +13,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
{view: ["current", html.INPUT], spellcheck: false, onkeydown: function(event) { if (event.metaKey) { return }
|
{view: ["current", html.INPUT], spellcheck: false, onkeydown: function(event) { if (event.metaKey) { return }
|
||||||
if (event.ctrlKey && can.onaction._complete(event, can)) { return }
|
if (event.ctrlKey && can.onaction._complete(event, can)) { return }
|
||||||
can._keylist = can.onkeymap._parse(event, can, can.mode+(event.ctrlKey? "_ctrl": ""), can._keylist, can.ui.current)
|
can._keylist = can.onkeymap._parse(event, can, can.mode+(event.ctrlKey? "_ctrl": ""), can._keylist, can.ui.current)
|
||||||
can.mode == "insert" && can.core.Timer(10, function() { can.current.text(can.ui.current.value) })
|
can.mode == "insert" && can.onmotion.delay(can, function() { can.current.text(can.ui.current.value) }, 10)
|
||||||
can.mode == "normal" && can.Status("按键", can._keylist.join(""))
|
can.mode == "normal" && can.Status("按键", can._keylist.join(""))
|
||||||
can.mode == "normal" && can.onkeymap.prevent(event)
|
can.mode == "normal" && can.onkeymap.prevent(event)
|
||||||
}, onkeyup: function(event) { can.onaction._complete(event, can)
|
}, onkeyup: function(event) { can.onaction._complete(event, can)
|
||||||
@ -25,6 +23,81 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
}}, {view: ["complete"]},
|
}}, {view: ["complete"]},
|
||||||
]); can.ui.current = ui.current, can.ui.complete = ui.complete
|
]); can.ui.current = ui.current, can.ui.complete = ui.complete
|
||||||
},
|
},
|
||||||
|
project: function(can, path) {
|
||||||
|
can.onimport.zone(can, [
|
||||||
|
{name: "source", _init: function(target) { var total = 0
|
||||||
|
function show(path, target) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [ice.PWD], function(msg) { var list = msg.Table()
|
||||||
|
can.core.List(list, function(item) {
|
||||||
|
item._init = function(target) {
|
||||||
|
target.onmouseenter = function(event) {
|
||||||
|
can.user.carteRight(event, can, {"删除": function() {
|
||||||
|
can.runAction(event, nfs.TRASH, [can.base.Path(path, item.path)], function() {
|
||||||
|
can.ui.source.refresh()
|
||||||
|
})
|
||||||
|
}}, ["删除"])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (can.Option(nfs.FILE).indexOf(item.path) == 0) { item.expand = true }
|
||||||
|
})
|
||||||
|
can.onimport.tree(can, list, nfs.PATH, ice.PS, function(event, item) {
|
||||||
|
can.onimport.tabview(can, path, item.path) // 显示文件
|
||||||
|
}, target), can.Status("文件数", total += msg.Length())
|
||||||
|
}, true) } if (path.length == 1) { return show(path[0], target) }
|
||||||
|
|
||||||
|
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(path, target) }} }), target)
|
||||||
|
can.onmotion.delay(can, function() { target.previousSibling.innerHTML = "" })
|
||||||
|
}},
|
||||||
|
{name: "plugin", _init: function(target) {
|
||||||
|
can.onimport.tree(can, can.core.Item(can.onengine.plugin.meta, function(key) { return {index: can.base.trimPrefix(key, "can.")} }), ctx.INDEX, ice.PT, function(event, item) {
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys("can", item.index), ctx.INDEX) // 显示插件
|
||||||
|
}, target)
|
||||||
|
}},
|
||||||
|
{name: "module", _init: function(target) {
|
||||||
|
can.runAction(can.request({}, {fields: ctx.INDEX}), ctx.COMMAND, [mdb.SEARCH, ctx.COMMAND], function(msg) {
|
||||||
|
can.onimport.tree(can, msg.Table(), ctx.INDEX, ice.PT, function(event, item) {
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), item.index, ctx.INDEX) // 显示模块
|
||||||
|
}, target)
|
||||||
|
})
|
||||||
|
}},
|
||||||
|
{name: "dreams", _init: function(target) { var call = arguments.callee
|
||||||
|
can.runAction({}, ice.RUN, [web.DREAM], function(msg) {
|
||||||
|
msg.Table(function(item) {
|
||||||
|
function carte(event) {
|
||||||
|
var list = []; switch (item.status) {
|
||||||
|
case "start": list = ["open", "stop"]; break
|
||||||
|
case "stop": list = ["start", "trash"]; break
|
||||||
|
}
|
||||||
|
can.user.carteRight(event, can, {}, list, function(event, action) {
|
||||||
|
can.runAction(can.request({}, item), ice.RUN, [web.DREAM, ctx.ACTION, action], function(msg) {
|
||||||
|
can.onmotion.clear(can, target), call(target)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
var color = item.status == "start"? "": "gray"
|
||||||
|
can.page.Append(can, target, [{view: html.ITEM, list: [{text: [item.name, html.DIV], style: {color: color}, onmouseenter: carte}], onclick: function() {
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), item.name, web.DREAM) // 显示空间
|
||||||
|
}}])
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}, _menu: shy("", {
|
||||||
|
"create": function(event, zone) {
|
||||||
|
can.user.input(event, can, [mdb.NAME], function(list) {
|
||||||
|
can.runAction({}, ice.RUN, [web.DREAM, cli.START, list[0]], function(msg) {
|
||||||
|
can.onmotion.clear(can, zone._target), zone._init(zone._target), can.user.toastSuccess(can)
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(mdb.NAME), web.DREAM) // 显示空间
|
||||||
|
})
|
||||||
|
})
|
||||||
|
},
|
||||||
|
"refresh": function(event, zone) {
|
||||||
|
can.onmotion.clear(can, zone._target), zone._init(zone._target)
|
||||||
|
},
|
||||||
|
"publish": function(event, zone) { button = "publish"
|
||||||
|
can.runAction(event, button, [], function(msg) { can.user.toastConfirm(can, msg.Result(), button) })
|
||||||
|
},
|
||||||
|
}, ["create", "refresh", "publish"], function() {})},
|
||||||
|
], can.ui.project)
|
||||||
|
},
|
||||||
}, [""])
|
}, [""])
|
||||||
Volcanos(chat.ONKEYMAP, {help: "键盘交互",
|
Volcanos(chat.ONKEYMAP, {help: "键盘交互",
|
||||||
_model: function(can, value) { can.Status("模式", can.mode = value)
|
_model: function(can, value) { can.Status("模式", can.mode = value)
|
||||||
@ -44,110 +117,108 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互",
|
|||||||
},
|
},
|
||||||
|
|
||||||
_mode: {
|
_mode: {
|
||||||
|
plugin: {
|
||||||
|
Escape: shy("切换模式", function(event, can) { can.onaction.clear(event, can) }),
|
||||||
|
g: shy("搜索", function(event, can) { can.onaction["搜索"](event, can) }),
|
||||||
|
f: shy("打开文件", function(event, can) { can.onaction["打开"](event, can) }),
|
||||||
|
t: shy("添加命令", function(event, can) { can.onaction["添加"](event, can) }),
|
||||||
|
p: shy("添加插件", function(event, can) { can.onaction["插件"](event, can) }),
|
||||||
|
e: shy("添加扩展", function(event, can) { can.onaction["扩展"](event, can) }),
|
||||||
|
r: shy("执行命令", function(event, can) { can.onaction[cli.EXEC](event, can) }),
|
||||||
|
v: shy("渲染界面", function(event, can) { can.onaction[cli.SHOW](event, can) }),
|
||||||
|
|
||||||
|
j: shy("向下滚动", function(event, can) { can.current.scroll(1) }),
|
||||||
|
k: shy("向上滚动", function(event, can) { can.current.scroll(-1) }),
|
||||||
|
J: shy("向下滚屏", function(event, can) { can.current.scroll(can.current.window()-3) }),
|
||||||
|
K: shy("向上滚屏", function(event, can) { can.current.scroll(-can.current.window()+3) }),
|
||||||
|
|
||||||
|
i: shy("插入模式", function(event, can) { can.onkeymap._insert(event, can) }),
|
||||||
|
n: shy("命令模式", function(event, can) { can.onkeymap._normal(event, can) }),
|
||||||
|
":": shy("底行模式", function(event, can) { can.onimport.toolkit(can, {index: "cli.system"}, function(sub) { can.toolkit["cli.system"] = sub.select() }) }),
|
||||||
|
},
|
||||||
normal_ctrl: {
|
normal_ctrl: {
|
||||||
f: function(event, can, target, count) {
|
f: shy("向下翻页", function(event, can, target, count) {
|
||||||
var line = can.onaction.selectLine(event, can)+can.current.window()-3-can.current.scroll()
|
var line = can.onaction.selectLine(event, can)+can.current.window()-3-can.current.scroll()
|
||||||
return can.current.scroll(line), can.onaction.selectLine(event, can, line), true
|
return can.current.scroll(line), can.onaction.selectLine(event, can, line), true
|
||||||
},
|
}),
|
||||||
b: function(event, can, target, count) {
|
b: shy("向上翻页", function(event, can, target, count) {
|
||||||
var line = can.onaction.selectLine(event, can)-can.current.window()+3
|
var line = can.onaction.selectLine(event, can)-can.current.window()+3
|
||||||
return can.current.scroll(line), can.onaction.selectLine(event, can, line), true
|
return can.current.scroll(line), can.onaction.selectLine(event, can, line), true
|
||||||
},
|
}),
|
||||||
},
|
},
|
||||||
normal: {
|
normal: {
|
||||||
Escape: function(event, can) { can.onkeymap._plugin(event, can) },
|
Escape: shy("切换模式", function(event, can) { can.onkeymap._plugin(event, can) }),
|
||||||
ArrowLeft: function(event, can, target) { can.onkeymap.cursorMove(can, target, -1) },
|
ArrowLeft: shy("光标左移", function(event, can, target) { can.onkeymap.cursorMove(can, target, -1) }),
|
||||||
ArrowRight: function(event, can, target) { can.onkeymap.cursorMove(can, target, 1) },
|
ArrowRight: shy("光标右移", function(event, can, target) { can.onkeymap.cursorMove(can, target, 1) }),
|
||||||
ArrowDown: function(event, can) { can.onaction.selectLine(event, can, can.current.next()) },
|
ArrowDown: shy("光标下移", function(event, can) { can.onaction.selectLine(event, can, can.current.next()) }),
|
||||||
ArrowUp: function(event, can) { can.onaction.selectLine(event, can, can.current.prev()) },
|
ArrowUp: shy("光标上移", function(event, can) { can.onaction.selectLine(event, can, can.current.prev()) }),
|
||||||
|
|
||||||
".": function(event, can, target) { var cb = can.redo.pop(); cb && cb() },
|
".": shy("重复操作", function(event, can, target) { var cb = can.redo.pop(); cb && cb() }),
|
||||||
u: function(event, can, target) { var cb = can.undo.pop(); cb && cb() },
|
u: shy("撤销操作", function(event, can, target) { var cb = can.undo.pop(); cb && cb() }),
|
||||||
J: function(event, can, target) {
|
J: shy("合并两行", function(event, can, target) {
|
||||||
var next = can.current.next(); if (!next) { return }
|
var next = can.current.next(); if (!next) { return }
|
||||||
var line = can.current.line, text = can.current.text()
|
var line = can.current.line, text = can.current.text()
|
||||||
var rest = can.page.Select(can, next, "td.text")[0].innerText
|
var rest = can.page.Select(can, next, "td.text")[0].innerText
|
||||||
can.current.text(text.trimRight()+ice.SP+rest.trimLeft()), can.onaction.deleteLine(can, next)
|
can.current.text(text.trimRight()+ice.SP+rest.trimLeft()), can.onaction.deleteLine(can, next)
|
||||||
can.undo.push(function() { can.onaction.modifyLine(can, line, text), can.onaction.insertLine(can, rest, line.nextSibling) })
|
can.undo.push(function() { can.onaction.modifyLine(can, line, text), can.onaction.insertLine(can, rest, line.nextSibling) })
|
||||||
},
|
}),
|
||||||
H: function(event, can, target) { can.onkeymap.cursorMove(can, target, 0, 0) },
|
|
||||||
h: function(event, can, target) { can.onkeymap.cursorMove(can, target, -1) },
|
|
||||||
l: function(event, can, target) { can.onkeymap.cursorMove(can, target, 1) },
|
|
||||||
L: function(event, can, target) { can.onkeymap.cursorMove(can, target, 0, -1) },
|
|
||||||
j: function(event, can) { can.onaction.selectLine(event, can, can.current.next()) },
|
|
||||||
k: function(event, can) { can.onaction.selectLine(event, can, can.current.prev()) },
|
|
||||||
|
|
||||||
gg: function(event, can, target, count) { return can.onaction.selectLine(event, can, count), true },
|
H: shy("跳到行首", function(event, can, target) { can.onkeymap.cursorMove(can, target, 0, 0) }),
|
||||||
G: function(event, can, target, count) { return can.onaction.selectLine(event, can, count = count>1? count: can.max), true },
|
h: shy("光标左移", function(event, can, target) { can.onkeymap.cursorMove(can, target, -1) }),
|
||||||
zt: function(event, can, target, count) { return can.current.scroll(can.current.scroll()-(count>1? count: 3)), true },
|
l: shy("光标右移", function(event, can, target) { can.onkeymap.cursorMove(can, target, 1) }),
|
||||||
zz: function(event, can, target, count) { return can.current.scroll(can.current.scroll()-(count = count>1? count: can.current.window()/2)), true },
|
L: shy("跳到行尾", function(event, can, target) { can.onkeymap.cursorMove(can, target, 0, -1) }),
|
||||||
zb: function(event, can, target, count) { return can.current.scroll(can.current.scroll()-can.current.window()+(count>1? count: 5)), true },
|
j: shy("光标下移", function(event, can) { can.onaction.selectLine(event, can, can.current.next()) }),
|
||||||
|
k: shy("光标上移", function(event, can) { can.onaction.selectLine(event, can, can.current.prev()) }),
|
||||||
|
|
||||||
i: function(event, can) { can.onkeymap._insert(event, can) },
|
gg: shy("跳到某行", function(event, can, target, count) { return can.onaction.selectLine(event, can, count), true }),
|
||||||
I: function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 0, 0) },
|
G: shy("跳到某行", function(event, can, target, count) { return can.onaction.selectLine(event, can, count = count>1? count: can.max), true }),
|
||||||
a: function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 1) },
|
zt: shy("将当前行拉到屏幕最上", function(event, can, target, count) { return can.current.scroll(can.current.scroll()-(count>1? count: 3)), true }),
|
||||||
A: function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 0, -1) },
|
zz: shy("将当前行拉到屏幕中间", function(event, can, target, count) { return can.current.scroll(can.current.scroll()-(count = count>1? count: can.current.window()/2)), true }),
|
||||||
o: function(event, can) { var text = can.current.text()
|
zb: shy("将当前行拉到屏幕最下", function(event, can, target, count) { return can.current.scroll(can.current.scroll()-can.current.window()+(count>1? count: 5)), true }),
|
||||||
|
|
||||||
|
i: shy("插入模式", function(event, can) { can.onkeymap._insert(event, can) }),
|
||||||
|
I: shy("插入行首", function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 0, 0) }),
|
||||||
|
a: shy("插入模式", function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 1) }),
|
||||||
|
A: shy("插入行尾", function(event, can, target) { can.onkeymap._insert(event, can), can.onkeymap.cursorMove(can, target, 0, -1) }),
|
||||||
|
o: shy("插入下一行", function(event, can) { var text = can.current.text()
|
||||||
text = text.substr(0, text.indexOf(text.trimLeft()))+(text.endsWith("{")?"\t":"")
|
text = text.substr(0, text.indexOf(text.trimLeft()))+(text.endsWith("{")?"\t":"")
|
||||||
can.onkeymap._insert(event, can), can.onaction.selectLine(event, can, can.onaction.insertLine(can, text, can.current.next()))
|
can.onkeymap._insert(event, can), can.onaction.selectLine(event, can, can.onaction.insertLine(can, text, can.current.next()))
|
||||||
can.onkeymap.cursorMove(can, can.ui.current, 1000)
|
can.onkeymap.cursorMove(can, can.ui.current, 1000)
|
||||||
},
|
}),
|
||||||
O: function(event, can) { var text = can.current.text()
|
O: shy("插入上一行", function(event, can) { var text = can.current.text()
|
||||||
text = text.substr(0, text.indexOf(text.trimLeft()))+(text.endsWith("}")?"\t":"")
|
text = text.substr(0, text.indexOf(text.trimLeft()))+(text.endsWith("}")?"\t":"")
|
||||||
can.onkeymap._insert(event, can), can.onaction.selectLine(event, can, can.onaction.insertLine(can, text, can.current.line))
|
can.onkeymap._insert(event, can), can.onaction.selectLine(event, can, can.onaction.insertLine(can, text, can.current.line))
|
||||||
can.onkeymap.cursorMove(can, can.ui.current, 1000)
|
can.onkeymap.cursorMove(can, can.ui.current, 1000)
|
||||||
},
|
}),
|
||||||
|
|
||||||
yy: function(event, can, target, count) { can._last_text = can.current.text() },
|
yy: shy("复制当前行", function(event, can, target, count) { can._last_text = can.current.text() }),
|
||||||
dd: function(event, can, target, count) { var text = can.current.text(), line = can.onaction._getLineno(can, can.current.line)
|
dd: shy("剪切当前行", function(event, can, target, count) { var text = can.current.text(), line = can.onaction._getLineno(can, can.current.line)
|
||||||
can._last_text = can.current.text(), can.onaction.selectLine(event, can, can.onaction.deleteLine(can, can.current.line))
|
can._last_text = can.current.text(), can.onaction.selectLine(event, can, can.onaction.deleteLine(can, can.current.line))
|
||||||
can.undo.push(function() { can.onaction.insertLine(can, text, line), can.onaction.selectLine(event, can, line) })
|
can.undo.push(function() { can.onaction.insertLine(can, text, line), can.onaction.selectLine(event, can, line) })
|
||||||
var callee = arguments.callee
|
var callee = arguments.callee
|
||||||
can.redo.push(function() { callee(event, can, target, count) })
|
can.redo.push(function() { callee(event, can, target, count) })
|
||||||
},
|
}),
|
||||||
p: function(event, can) {
|
p: shy("粘贴", function(event, can) {
|
||||||
var line = can.onaction.insertLine(can, can._last_text, can.current.next())
|
var line = can.onaction.insertLine(can, can._last_text, can.current.next())
|
||||||
can.undo.push(function() { can.onaction.deleteLine(can, line), can.onaction.selectLine(event, can, line-1) })
|
can.undo.push(function() { can.onaction.deleteLine(can, line), can.onaction.selectLine(event, can, line-1) })
|
||||||
},
|
}),
|
||||||
P: function(event, can) {
|
P: shy("粘贴", function(event, can) {
|
||||||
var line = can.onaction.insertLine(can, can._last_text, can.current.line)
|
var line = can.onaction.insertLine(can, can._last_text, can.current.line)
|
||||||
can.undo.push(function() { can.onaction.deleteLine(can, line), can.onaction.selectLine(event, can, line+1) })
|
can.undo.push(function() { can.onaction.deleteLine(can, line), can.onaction.selectLine(event, can, line+1) })
|
||||||
},
|
}),
|
||||||
|
|
||||||
s: function(event, can) { can.onaction.save(event, can) },
|
s: shy("保存文件", function(event, can) { can.onaction.save(event, can) }),
|
||||||
m: function(event, can) { can.onaction.autogen(event, can, "autogen") },
|
m: shy("添加模块", function(event, can) { can.onaction.autogen(event, can, "autogen") }),
|
||||||
c: function(event, can) { can.onaction.compile(event, can, "compile") },
|
c: shy("编译项目", function(event, can) { can.onaction.compile(event, can, "compile") }),
|
||||||
},
|
},
|
||||||
insert: {
|
insert: {
|
||||||
jk: function(event, can, target) { can.onkeymap._normal(event, can)
|
Escape: shy("退出编辑", function(event, can) { if (event.key != "Escape") { return }
|
||||||
can.onkeymap.deleteText(target, target.selectionStart-1, 1)
|
|
||||||
can.current.text(can.ui.current.value)
|
|
||||||
},
|
|
||||||
Escape: function(event, can) {
|
|
||||||
if (event.key != "Escape") { return }
|
|
||||||
can.onkeymap._normal(event, can)
|
can.onkeymap._normal(event, can)
|
||||||
},
|
}),
|
||||||
Tab: function(event, can) {
|
Tab: shy("缩进", function(event, can) { if (event.key != "Tab") { return }
|
||||||
if (event.key != "Tab") { return }
|
can.onkeymap.insertText(can.ui.current, ice.TB), can.onkeymap.prevent(event)
|
||||||
can.onkeymap.insertText(can.ui.current, "\t")
|
}),
|
||||||
can.onkeymap.prevent(event)
|
Backspace: shy("删除", function(event, can, target) { if (event.key != "Backspace") { return }
|
||||||
},
|
|
||||||
|
|
||||||
Enter: function(event, can, target) {
|
|
||||||
if (event.key != "Enter") { return }
|
|
||||||
var rest = can.onkeymap.deleteText(target, target.selectionEnd), text = can.ui.current.value
|
|
||||||
var left = text.substr(0, text.indexOf(text.trimLeft()))||(text.trimRight() == ""? text: "")
|
|
||||||
if (text.endsWith("{")) { can.onaction.insertLine(can, left+"}", can.current.next()), left += "\t" }
|
|
||||||
if (text.endsWith("[")) { can.onaction.insertLine(can, left+"]", can.current.next()), left += "\t" }
|
|
||||||
if (text.endsWith("(")) { can.onaction.insertLine(can, left+")", can.current.next()), left += "\t" }
|
|
||||||
if (text.endsWith("`") && can.base.count(text, "`")%2==1) { can.onaction.insertLine(can, left+"`", can.current.next()) }
|
|
||||||
|
|
||||||
var line = can.onaction.insertLine(can, left+rest.trimLeft(), can.current.next())
|
|
||||||
can.current.text(text.trimRight()||text), can.onaction.selectLine(event, can, line)
|
|
||||||
can.onkeymap.cursorMove(can, can.ui.current, left.length, 0)
|
|
||||||
},
|
|
||||||
Backspace: function(event, can, target) {
|
|
||||||
if (event.key != "Backspace") { return }
|
|
||||||
if (target.selectionStart > 0) { return }
|
if (target.selectionStart > 0) { return }
|
||||||
if (!can.current.prev()) { return }
|
if (!can.current.prev()) { return }
|
||||||
can.onkeymap.prevent(event)
|
can.onkeymap.prevent(event)
|
||||||
@ -159,33 +230,50 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互",
|
|||||||
|
|
||||||
can.ui.current.value = can.current.text()+rest
|
can.ui.current.value = can.current.text()+rest
|
||||||
can.onkeymap.cursorMove(can, can.ui.current, 0, pos)
|
can.onkeymap.cursorMove(can, can.ui.current, 0, pos)
|
||||||
},
|
}),
|
||||||
ArrowUp: function(event, can) {
|
Enter: shy("换行", function(event, can, target) { if (event.key != "Enter") { return }
|
||||||
if (event.key != "ArrowUp") { return }
|
var rest = can.onkeymap.deleteText(target, target.selectionEnd), text = can.ui.current.value
|
||||||
|
var left = text.substr(0, text.indexOf(text.trimLeft()))||(text.trimRight() == ""? text: "")
|
||||||
|
if (text.endsWith("{")) { can.onaction.insertLine(can, left+"}", can.current.next()), left += ice.TB }
|
||||||
|
if (text.endsWith("[")) { can.onaction.insertLine(can, left+"]", can.current.next()), left += ice.TB }
|
||||||
|
if (text.endsWith("(")) { can.onaction.insertLine(can, left+")", can.current.next()), left += ice.TB }
|
||||||
|
if (text.endsWith("`") && can.base.count(text, "`")%2==1) { can.onaction.insertLine(can, left+"`", can.current.next()) }
|
||||||
|
|
||||||
|
var line = can.onaction.insertLine(can, left+rest.trimLeft(), can.current.next())
|
||||||
|
can.current.text(text.trimRight()||text), can.onaction.selectLine(event, can, line)
|
||||||
|
can.onkeymap.cursorMove(can, can.ui.current, left.length, 0)
|
||||||
|
}),
|
||||||
|
ArrowUp: shy("光标上移", function(event, can) { if (event.key != "ArrowUp") { return }
|
||||||
can.onaction.selectLine(event, can, can.current.prev())
|
can.onaction.selectLine(event, can, can.current.prev())
|
||||||
},
|
}),
|
||||||
ArrowDown: function(event, can) {
|
ArrowDown: shy("光标下移", function(event, can) { if (event.key != "ArrowDown") { return }
|
||||||
if (event.key != "ArrowDown") { return }
|
|
||||||
can.onaction.selectLine(event, can, can.current.next())
|
can.onaction.selectLine(event, can, can.current.next())
|
||||||
},
|
}),
|
||||||
},
|
},
|
||||||
}, _engine: {},
|
}, _engine: {},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONACTION, {help: "控件交互", list: [nfs.SAVE, code.AUTOGEN, code.COMPILE, nfs.SCRIPT, chat.WEBSITE, web.DREAM, code.PUBLISH],
|
Volcanos(chat.ONACTION, {help: "控件交互", list: [nfs.SAVE, code.COMPILE, code.AUTOGEN, nfs.SCRIPT, chat.WEBSITE],
|
||||||
_run: function(event, can, button, args, cb) {
|
_run: function(event, can, button, args, cb) {
|
||||||
can.runAction(event, button, args, cb||function(msg) {
|
can.runAction(event, button, args, cb||function(msg) {
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(nfs.FILE)), can.ui.source.refresh()
|
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(nfs.FILE)), can.ui.source.refresh()
|
||||||
|
can.user.toastSuccess(can, button)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
_runs: function(event, can, button) { var meta = can.Conf(); can.request(event, {action: button})
|
_runs: function(event, can, button, cb) { var meta = can.Conf(); can.request(event, {action: button})
|
||||||
can.user.input(event, can, meta.feature[button], function(args) {
|
can.user.input(event, can, meta.feature[button], function(args) {
|
||||||
can.onaction._run(event, can, button, args)
|
can.onaction._run(event, can, button, args, cb)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
save: function(event, can, button) { can.request(event, {file: can.Option(nfs.FILE), content: can.onexport.content(can)})
|
save: function(event, can, button) { can.request(event, {file: can.Option(nfs.FILE), content: can.onexport.content(can)})
|
||||||
can.onaction._run(event, can, button, [can.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)])
|
can.onaction._run(event, can, button, [can.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)])
|
||||||
},
|
},
|
||||||
autogen: function(event, can, button) { can.onaction._runs(event, can, button) },
|
autogen: function(event, can, button) { can.onaction._runs(event, can, button, function(msg) {
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(cli.MAIN), "", function() {
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), msg.Option(nfs.FILE), "", function() {
|
||||||
|
can.ui.source.refresh()
|
||||||
|
})
|
||||||
|
}, true)
|
||||||
|
}) },
|
||||||
compile: function(event, can, button) { var toast = can.user.toastProcess(can, "编译中...")
|
compile: function(event, can, button) { var toast = can.user.toastProcess(can, "编译中...")
|
||||||
can.runAction(can.request(event), button, [], function(msg) { toast.close()
|
can.runAction(can.request(event), button, [], function(msg) { toast.close()
|
||||||
if (msg.Length() == 0) { var toast1 = can.user.toastProcess(can, "重启中...")
|
if (msg.Length() == 0) { var toast1 = can.user.toastProcess(can, "重启中...")
|
||||||
@ -195,13 +283,23 @@ Volcanos(chat.ONACTION, {help: "控件交互", list: [nfs.SAVE, code.AUTOGEN, co
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
script: function(event, can, button) {
|
script: function(event, can, button) {
|
||||||
can.onaction._runs(can.request(event, {file: "hi/hi.js"}), can, button)
|
can.onaction._runs(can.request(event, {file: can.base.trimSuffix(can.Option(nfs.FILE), can.base.Ext(can.Option(nfs.FILE)))+nfs.JS}), can, button)
|
||||||
},
|
},
|
||||||
website: function(event, can, button) {
|
website: function(event, can, button) {
|
||||||
can.onaction._runs(can.request(event, {file: "hi.zml"}), can, button)
|
can.onaction._runs(can.request(event, {file: "hi.zml"}), can, button)
|
||||||
},
|
},
|
||||||
publish: function(event, can, button) {
|
"添加": function(event, can) { can.user.input(event, can, [ctx.INDEX], function(list) { can.onimport.tabview(can, can.Option(nfs.PATH), list[0], ctx.INDEX) }) },
|
||||||
can.runAction(event, button, [], function(msg) { can.user.toastConfirm(can, msg.Result(), button) })
|
"插件": function(event, can) {
|
||||||
|
can.user.input(event, can, [ctx.INDEX], function(list) {
|
||||||
|
var sub = can.toolkit[list[0]]; if (sub) { sub.select(); return }
|
||||||
|
can.onimport.toolkit(can, {index: list[0]}, function(sub) { can.toolkit[list[0]] = sub.select() })
|
||||||
|
})
|
||||||
|
},
|
||||||
|
"扩展": function(event, can) {
|
||||||
|
can.user.input(event, can, ["url"], function(list) {
|
||||||
|
var sub = can.extentions[list[0]]; if (sub) { sub.select(); return }
|
||||||
|
can.onimport.exts(can, list[0], function(sub) { can.extentions[list[0]] = sub.select() })
|
||||||
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
listTags: function(event, can, button) { var list = []
|
listTags: function(event, can, button) { var list = []
|
||||||
@ -323,9 +421,17 @@ Volcanos(chat.ONACTION, {help: "控件交互", list: [nfs.SAVE, code.AUTOGEN, co
|
|||||||
can.page.Select(can, can.ui.content, html.TR, function(item, index) {
|
can.page.Select(can, can.ui.content, html.TR, function(item, index) {
|
||||||
if (item != line && index+1 != line) { return }
|
if (item != line && index+1 != line) { return }
|
||||||
can.page.Select(can, item, "td.text", function(item) {
|
can.page.Select(can, item, "td.text", function(item) {
|
||||||
can.page.Appends(can, item, [can.onsyntax._parse(can, value)])
|
item.innerHTML = can.onsyntax._parse(can, value)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
favorLine: function(can, value) {
|
||||||
|
can.user.input(event, can, [{name: "zone", value: "hi"}, {name: "name", value: "hello"}], function(data) {
|
||||||
|
can.runAction(event, code.FAVOR, [ctx.ACTION, mdb.INSERT, mdb.ZONE, data.zone||"",
|
||||||
|
mdb.TYPE, can.parse, mdb.NAME, data.name||"", mdb.TEXT, (value||"").trimRight(),
|
||||||
|
nfs.PATH, can.Option(nfs.PATH), nfs.FILE, can.Option(nfs.FILE), nfs.LINE, can.Option(nfs.LINE),
|
||||||
|
])
|
||||||
|
})
|
||||||
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONEXPORT, {help: "导出数据", list: ["文件数", "模式", "按键", "解析器", "文件名", "当前行", "跳转数"]})
|
Volcanos(chat.ONEXPORT, {help: "导出数据", list: ["文件数", "模式", "按键", "解析器", "文件名", "当前行", "跳转数"]})
|
||||||
|
@ -88,7 +88,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
|
|||||||
item[field] && can.core.List(item[field].split(split), function(value, index, array) { if (!value) { return }
|
item[field] && can.core.List(item[field].split(split), function(value, index, array) { if (!value) { return }
|
||||||
var last = array.slice(0, index).join(split), name = array.slice(0, index+1).join(split)
|
var last = array.slice(0, index).join(split), name = array.slice(0, index+1).join(split)
|
||||||
if (node[name]) { return }
|
if (node[name]) { return }
|
||||||
var ui = can.page.Append(can, node[last], [{view: "item", list: [{view: ["switch", "div", (index==array.length-1?"":"⌃")]}, {view: ["name", html.DIV, value+(index==array.length-1?"":"")]}], onclick: function(event) {
|
var ui = can.page.Append(can, node[last], [{view: "item", list: [{view: ["switch", "div", (index==array.length-1?"":"⌃")]}, {view: ["name", html.DIV, value+(index==array.length-1?"":"")], _init: item._init}], onclick: function(event) {
|
||||||
index < array.length - 1? can.onmotion.toggle(can, node[name], function() {
|
index < array.length - 1? can.onmotion.toggle(can, node[name], function() {
|
||||||
can.page.ClassList.add(can, ui["switch"], "open")
|
can.page.ClassList.add(can, ui["switch"], "open")
|
||||||
}, function() {
|
}, function() {
|
||||||
|
41
proto.js
41
proto.js
@ -117,6 +117,8 @@ var gdb = {
|
|||||||
var lex = {
|
var lex = {
|
||||||
SPLIT: "split", PREFIX: "prefix",
|
SPLIT: "split", PREFIX: "prefix",
|
||||||
}
|
}
|
||||||
|
var ssh = {
|
||||||
|
}
|
||||||
|
|
||||||
var code = {
|
var code = {
|
||||||
VIMER: "vimer", INNER: "inner", FAVOR: "favor",
|
VIMER: "vimer", INNER: "inner", FAVOR: "favor",
|
||||||
@ -290,7 +292,7 @@ var Volcanos = shy("火山架", {iceberg: "/chat/", volcano: "/frame.js", pack:
|
|||||||
// 根模块
|
// 根模块
|
||||||
_can_name = "", name = Config.name||ice.CAN, cb = can||function(can) {
|
_can_name = "", name = Config.name||ice.CAN, cb = can||function(can) {
|
||||||
can.onengine._init(can, can.Conf(Config), panels, Config._init, can._target)
|
can.onengine._init(can, can.Conf(Config), panels, Config._init, can._target)
|
||||||
}, can = {_follow: name, _target: Config.target||meta.target, _height: Config.height||window.innerHeight, _width: Config.width||window.innerWidth}
|
}, 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] }
|
for (var k in Config) { can[k] = Config[k] }
|
||||||
can._root = can
|
can._root = can
|
||||||
}
|
}
|
||||||
@ -427,34 +429,10 @@ function can(tool) {
|
|||||||
]})
|
]})
|
||||||
}
|
}
|
||||||
|
|
||||||
try { if (typeof(global) == lang.OBJECT) { // nodejs
|
try { if (typeof(window) == lang.OBJECT) { // nodejs
|
||||||
global.kit = kit, global.ice = ice
|
|
||||||
global.ctx = ctx, global.cli = cli, global.web = web, global.aaa = aaa
|
|
||||||
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.svg = svg, global.html = html, global.lang = lang
|
|
||||||
global.shy = shy, global.Volcanos = Volcanos
|
|
||||||
|
|
||||||
Volcanos.meta._load = function(url, cb) {
|
|
||||||
setTimeout(function() { if (Volcanos.meta.cache[url]) { return cb(Volcanos.meta.cache[url]) }
|
|
||||||
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
|
||||||
case nfs.JS: require(_can_name = url), cb(Volcanos.meta.cache[url]); break
|
|
||||||
}
|
|
||||||
}, 100)
|
|
||||||
}
|
|
||||||
|
|
||||||
Volcanos.meta._load(global.plugin, function(cache) {
|
|
||||||
Volcanos.meta.volcano = "./frame.js", Volcanos({libs: [
|
|
||||||
"./lib/base.js", "./lib/core.js", "./lib/misc.js", "./lib/page.js", // "./lib/user.js",
|
|
||||||
], panels: [], plugin: []}, function(can) { can.core.List(cache, function(item) { can[item._name] = item })
|
|
||||||
Volcanos.meta._load("./publish/client/nodejs/proto.js", function(cache) {
|
|
||||||
can.core.List(cache, function(item) { can.base.Copy(can[item._name]||{}, item) })
|
|
||||||
can.onimport._init(can, can.request(), function(msg) { console.log(ice.NL) }, null)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
} else { // browser
|
|
||||||
Volcanos.meta.target = document.body
|
Volcanos.meta.target = document.body
|
||||||
|
Volcanos.meta._width = window.innerWidth
|
||||||
|
Volcanos.meta._height = window.innerHeight
|
||||||
Volcanos.meta._load = function(url, cb) {
|
Volcanos.meta._load = function(url, cb) {
|
||||||
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
||||||
case nfs.CSS:
|
case nfs.CSS:
|
||||||
@ -468,4 +446,11 @@ try { if (typeof(global) == lang.OBJECT) { // nodejs
|
|||||||
return document.body.appendChild(item), item
|
return document.body.appendChild(item), item
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else { // nodejs
|
||||||
|
global.kit = kit, global.ice = ice
|
||||||
|
global.ctx = ctx, global.cli = cli, global.web = web, global.aaa = aaa
|
||||||
|
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.svg = svg, global.html = html, global.lang = lang
|
||||||
|
global.shy = shy, global.Volcanos = Volcanos, global.can = can
|
||||||
} } catch (e) { console.log(e) }
|
} } catch (e) { console.log(e) }
|
||||||
|
@ -1,3 +1,28 @@
|
|||||||
|
try { if (typeof(global) == lang.OBJECT) { // nodejs
|
||||||
|
Volcanos.meta._load = function(url, cb) { if (!url) { return }
|
||||||
|
setTimeout(function() { if (Volcanos.meta.cache[url]) { return cb(Volcanos.meta.cache[url]) }
|
||||||
|
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
||||||
|
case nfs.JS:
|
||||||
|
require(path.isAbsolute(url)? url: path.join(process.cwd(), "usr/volcanos", url))
|
||||||
|
cb(Volcanos.meta.cache[url])
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}, 100)
|
||||||
|
}
|
||||||
|
|
||||||
|
Volcanos.meta._load(global.plugin, function(cache) {
|
||||||
|
Volcanos.meta.volcano = "./frame.js", Volcanos({libs: [
|
||||||
|
"./lib/base.js", "./lib/core.js", "./lib/misc.js", "./lib/page.js", // "./lib/user.js",
|
||||||
|
], panels: [], plugin: []}, function(can) { can.core.List(cache, function(item) { can[item._name] = item })
|
||||||
|
Volcanos.meta._load("./publish/client/nodejs/proto.js", function(cache) {
|
||||||
|
can.core.List(cache, function(item) { can.base.Copy(can[item._name]||{}, item) })
|
||||||
|
can.onimport._init(can, can.request(), function(msg) { console.log(ice.NL) }, null)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
})
|
||||||
|
} } catch (e) { console.log(e) }
|
||||||
|
|
||||||
|
_can_name = "./frame.js"
|
||||||
Volcanos("onappend", {help: "渲染引擎",
|
Volcanos("onappend", {help: "渲染引擎",
|
||||||
table: function(can, msg) {
|
table: function(can, msg) {
|
||||||
var max = {}; msg.Table(function(value, index, array) {
|
var max = {}; msg.Table(function(value, index, array) {
|
||||||
@ -32,32 +57,3 @@ Volcanos("onappend", {help: "渲染引擎",
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
|
|
||||||
try { if (typeof(global) == lang.OBJECT) {
|
|
||||||
global.kit = kit, global.ice = ice
|
|
||||||
global.ctx = ctx, global.cli = cli, global.web = web, global.aaa = aaa
|
|
||||||
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.svg = svg, global.html = html, global.lang = lang
|
|
||||||
global.shy = shy, global.Volcanos = Volcanos
|
|
||||||
|
|
||||||
Volcanos.meta._load = function(url, cb) {
|
|
||||||
setTimeout(function() { if (Volcanos.meta.cache[url]) { return cb(Volcanos.meta.cache[url]) }
|
|
||||||
switch (url.split("?")[0].split(ice.PT).pop().toLowerCase()) {
|
|
||||||
case nfs.JS: require(_can_name = url), cb(Volcanos.meta.cache[url]); break
|
|
||||||
}
|
|
||||||
}, 100)
|
|
||||||
}
|
|
||||||
|
|
||||||
Volcanos.meta._load(global.plugin, function(cache) {
|
|
||||||
Volcanos.meta.volcano = "./frame.js", Volcanos({libs: [
|
|
||||||
"./lib/base.js", "./lib/core.js", "./lib/misc.js", "./lib/page.js", // "./lib/user.js",
|
|
||||||
], panels: [], plugin: []}, function(can) { can.core.List(cache, function(item) { can[item._name] = item })
|
|
||||||
Volcanos.meta._load("./publish/client/nodejs/proto.js", function(cache) {
|
|
||||||
can.core.List(cache, function(item) { can.base.Copy(can[item._name]||{}, item) })
|
|
||||||
can.onimport._init(can, can.request(), function(msg) { console.log(ice.NL) }, null)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
Volcanos.meta.target = document.body
|
|
||||||
} } catch (e) { console.log(e) }
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user