diff --git a/frame.js b/frame.js
index 0c41e971..e278d703 100644
--- a/frame.js
+++ b/frame.js
@@ -372,7 +372,7 @@ Volcanos(chat.ONAPPEND, {help: "渲染引擎", _init: function(can, meta, list,
}
return {text: [value, html.TD], onclick: function(event) { var target = event.target
- if (can.page.tagis(html.INPUT, target) && target.type == html.BUTTON) { return run([ctx.ACTION, target.name]) }
+ if (can.page.tagis(target, html.INPUT) && target.type == html.BUTTON) { return run([ctx.ACTION, target.name]) }
if (key == mdb.HASH && can.user.mod.isDiv) { return can.user.jumps("/chat/div/"+value) }
if (can.sup.onaction.change(event, can.sup, key, event.target.innerText).length == 0) {
can.sup && can.sup._item_click && can.sup._item_click(value, key)
@@ -581,7 +581,7 @@ Volcanos(chat.ONMOTION, {help: "动态特效", _init: function(can, target) {
var list = can.core.List(arguments).slice(2)
if (list.length == 0) { list = [chat.CARTE, chat.INPUT] }
can.page.Modify(can, target, {onmouseover: function(event) {
- if (can.page.tagis(html.IMG, event.target)) { return }
+ if (can.page.tagis(event.target, html.IMG)) { return }
can.core.List(list, function(key, index) { that.del(can, key) })
}})
},
@@ -812,7 +812,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can,
if (window.webview) {
if (event.target.tagName == "A") { can.user.open(event.target.href) }
}
- if (can.page.tagis([html.SELECT, html.INPUT, html.TEXTAREA], event.target)) { return }
+ if (can.page.tagis( event.target, html.SELECT, html.INPUT, html.TEXTAREA)) { return }
can.page.Select(can, document.body, can.page.Keys("fieldset.input.key.float"), function(item) {
can.page.Remove(can, item)
})
@@ -829,7 +829,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can,
}
} return }
- if (can.page.tagis([html.SELECT, html.INPUT, html.TEXTAREA], event.target)) { return }
+ if (can.page.tagis(event.target, html.SELECT, html.INPUT, html.TEXTAREA)) { return }
var msg = can.request(event, {"model": "normal"}); if (msg.Option(ice.MSG_HANDLE) == ice.TRUE) { return }
can.onengine.signal(can, chat.ONKEYDOWN, msg); if (msg.Option(ice.MSG_HANDLE) == ice.TRUE) { return }
can._keylist = can.onkeymap._parse(event, can, msg.Option("model"), can._keylist, can._output)
@@ -869,7 +869,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", _focus: [], _init: function(can,
Escape: function(event, can, target) { target.blur() },
Enter: function(event, can, target) { var his = target._history||[]
his.push(target.value), target._history = his, target._current = his.length
- can.page.tagis(html.INPUT, event.target) && can.onmotion.focus(can, target)
+ can.page.tagis(event.target, html.INPUT) && can.onmotion.focus(can, target)
},
},
insert_ctrl: {
diff --git a/lib/misc.js b/lib/misc.js
index 9d52c92a..6da25b0f 100644
--- a/lib/misc.js
+++ b/lib/misc.js
@@ -232,6 +232,11 @@ Volcanos("misc", {help: "通信协议", Message: function(event, can) { var msg
var search = can.core.Item(args, function(key, value) { return key+"="+encodeURIComponent(value) }).join("&")
return search? location.search = search: location.href = location.pathname
}),
+ MergePodCmd: shy("地址链接", function(can, objs) {
+ objs.pod = can.core.Keys(can.misc.Search(can, "pod"), objs.pod)
+ objs.topic = can.misc.Search(can, "topic")
+ return can.misc.MergeURL(can, objs, true)
+ }),
MergeURL: shy("地址链接", function(can, objs, clear) {
var path = location.pathname; objs._path && (path = objs._path), delete(objs._path)
objs.pod && (path = "/chat/pod/"+objs.pod), delete(objs.pod)
diff --git a/lib/page.js b/lib/page.js
index 895dc1d2..89e2f346 100644
--- a/lib/page.js
+++ b/lib/page.js
@@ -309,6 +309,7 @@ Volcanos("page", {help: "用户界面", ClassList: {
switch (type) {
case html.A: return ""+(args[2]||args[1])+""
case html.IMG: return args[2]? "
": "
"
+ case html.SPAN: return args[2]? ""+args[1]+"": args[1]
}
},
replace: function(can, text, key, value) {
@@ -443,8 +444,11 @@ Volcanos("page", {help: "用户界面", ClassList: {
styleSheet.type = "text/css", styleSheet.innerText = text
document.head.appendChild(styleSheet)
},
- tagis: function(type, target) { type = typeof type == lang.OBJECT? type: [type]
- if (type.indexOf(target.tagName.toLowerCase()) > -1) { return true }
+ tagis: function(target) {
+ var type = target.tagName.toLowerCase()
+ for (var i = 1; i < arguments.length; i++) {
+ if (type == arguments[i]) { return true }
+ }
},
offsetTop: function(item) { var res = 0
while (item) { res += item.offsetTop||0, item = item.parentNode }
diff --git a/page/index.css b/page/index.css
index 30c0b694..ca008fa6 100644
--- a/page/index.css
+++ b/page/index.css
@@ -46,7 +46,7 @@ div.output div.project div.item { padding:2px 10px; }
div.output div.project div.list { margin-left:10px; }
div.output div.project div.switch { width:12px; float:left; transform: rotate(90deg) translate(1px, 0px); }
div.output div.project div.switch.open { transform: rotate(180deg) translate(-4px, 4px); }
-div.output div.project div.zone>div.name { background-color:steelblue; color:white; text-align:center; padding:5px; clear:both; }
+div.output div.project div.zone>div.name { background-color:steelblue; color:white; text-align:center; padding:3px; clear:both; }
div.output div.project div.item>div.name { padding-left:20px; }
div.output div.project div.zone>div.action>div.item { float:right; clear:none; padding:0; margin:0; }
div.output div.project div.zone>div.action>div.item input[type=text] { background-color:#ff000000; padding-left:10px; color:white; }
@@ -59,10 +59,8 @@ fieldset.story>legend { margin:10px 0; }
fieldset.plug>legend { float:left; margin-right:5px; }
fieldset.float>legend { float:left; margin-right:5px; }
fieldset.full>legend { float:left; margin:0; margin-right:5px; }
-fieldset.float input[type=button][name=close]{ display:block; }
-fieldset.plug>form.option input[type=button][name=close]{ display:block; }
-fieldset.full input[type=button][name=close]{ display:block; }
fieldset.plugin>form.option input[type=button][name=close]{ display:none; }
+fieldset.word>div.output>fieldset.story>form.option input[type=button][name=close]{ display:none; }
fieldset.plugin div.status { border-top:1px solid darkcyan; }
fieldset.story div.status { border-top:1px solid darkcyan; }
fieldset.output>form.option { display:none; }
@@ -315,6 +313,7 @@ body.simple fieldset.feel.float { top:0; }
div.output div.row div.col { float:left; border:solid 1px green; }
body.white.simple div.profile { background-color:whitesmoke; }
+body.white.simple div.profile { color:black; }
body.white.simple div.display { background-color:whitesmoke; }
body.white.simple div.code { background-color:white; color:black; border:none; }
body.white.simple fieldset.plugin div.status { border-top:1px solid lightgray; }
diff --git a/panel/footer.js b/panel/footer.js
index 675fa9af..c02f0469 100644
--- a/panel/footer.js
+++ b/panel/footer.js
@@ -72,7 +72,7 @@ Volcanos(chat.ONEXPORT, {help: "导出数据",
can.onappend._action(can, [cli.CLOSE, cli.REFRESH, {input: html.TEXT, placeholder: "filter", _init: function(input) {
can.onengine.signal(can, "keymap.focus", can.request({}, {cb: function(event) {
- if (can.page.tagis(html.INPUT, event.target)) { return }
+ if (can.page.tagis(event.target, html.INPUT)) { return }
if (event.key == lang.ESCAPE) { ui.close(); return }
if (event.key == ice.SP) { input.focus(), can.onkeymap.prevent(event) }
}}))
diff --git a/panel/header.js b/panel/header.js
index f9498660..650522d3 100644
--- a/panel/header.js
+++ b/panel/header.js
@@ -41,7 +41,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
_search: function(can, msg, target) {
var ui = can.onappend.input(can, {type: html.TEXT, name: mdb.SEARCH, onkeydown: function(event) {
can.onkeymap.input(event, can); switch (event.key) {
- case lang.ENTER: can.onengine.signal(can, chat.ONOPENSEARCH, can.request(event, {type: "command,space,text"||mdb.FOREACH, word: event.target.value}))
+ case lang.ENTER: can.onengine.signal(can, chat.ONOPENSEARCH, can.request(event, {type: "command,space,word,text"||mdb.FOREACH, word: event.target.value}))
}
}}, "", target, "title search")
can.onimport.menu(can, mdb.SEARCH, function() {
diff --git a/panel/search.js b/panel/search.js
index dbbc49ac..cc2acdfb 100644
--- a/panel/search.js
+++ b/panel/search.js
@@ -1,6 +1,6 @@
Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, list, cb, target) {
can._foreach = "*"
- can._foreach = "command,space,text"
+ can._foreach = "command,space,word,text"
can.list = msg.Table(), can.onmotion.clear(can, can.ui.content)
var table = can.onappend.table(can, msg, function(value, key, index, line, array) { can.Status(mdb.TOTAL, index+1)
return {text: [key == mdb.TEXT && can.base.isFunc(line.text) && line.text.help || value, html.TD], onclick: function(event) {
@@ -109,13 +109,12 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [cli.CLOSE, cli.CLEAR, cli.
}}]), can.Status("selected", can.page.Select(can, can.ui.display, html.TR).length-1)
},
- plugin: function(event, can, index) { var line = can.list[index]
+ plugin: function(event, can, index) { var line = can.list[index], args = []
if (can.base.isFunc(line.text)) { return can.onmotion.hide(can), line.text(event) }
- if (line.ctx == "web.wiki" && line.cmd == "word") { return }
- if (can.page.tagis(html.A, event.target)) { return }
+ if (can.page.tagis(event.target, html.A)) { return }
var cmd = line.cmd == ctx.COMMAND? can.core.Keys(line.type, line.name.split(ice.SP)[0]): can.core.Keys(line.ctx, line.cmd)
- can.onappend.plugin(can, {type: "plug", index: cmd||msg.Option(mdb.INDEX)}, function(sub, meta) {
+ can.onappend.plugin(can, {type: "story", index: cmd||msg.Option(mdb.INDEX), args: cmd == "web.wiki.word"? [line.name]: args}, function(sub, meta) {
sub.run = function(event, cmds, cb) { can.runActionCommand(event, meta.index, cmds, cb) }
can.page.style(can, sub._output, html.MAX_WIDTH, sub.ConfWidth(can.ConfWidth()))
sub.ConfHeight(can.ConfHeight()-2*html.ACTION_HEIGHT-117)
diff --git a/plugin/local/code/inner.css b/plugin/local/code/inner.css
index 459d5335..340b8d0b 100644
--- a/plugin/local/code/inner.css
+++ b/plugin/local/code/inner.css
@@ -30,9 +30,12 @@ fieldset.inner>div.output td.profile iframe { border:0; }
fieldset.inner>div.output td.content>div.tabs { display:none; }
fieldset.inner>div.output td.content>div.path { display:none; }
-fieldset.inner div.output fieldset.toolkit { position:absolute; bottom:0px; right:0px; }
+fieldset.inner div.output fieldset.toolkit { position:relative; bottom:0px; right:0px; }
fieldset.inner>div.output fieldset.toolkit>div.output>fieldset { display:none; }
fieldset.inner>div.output fieldset.toolkit>div.output>fieldset.select { background-color:#0e3369b3; color:white; display:block; z-index:10; }
+fieldset.inner>div.output fieldset.toolkit>div.output fieldset { display:none; }
+fieldset.inner>div.output fieldset.toolkit>div.output fieldset.select { background-color:#0e3369b3; color:white; display:block; z-index:10; }
+fieldset.inner div.output fieldset.toolkit>div.output { position:unset; }
fieldset>div.output>fieldset.plug { position:absolute; bottom:0px; right:0px; }
fieldset>div.output>fieldset.plug { display:none; }
@@ -40,7 +43,12 @@ fieldset>div.output>fieldset.plug.select { background-color:#0e3369b3; color:whi
fieldset>div.status legend { float:right; height:30px; }
fieldset>div.status legend.select { background-color:green; }
fieldset>div.status legend:hover { background-color:green; }
-fieldset>div.status { height:31px; overflow:auto; }
+fieldset.inner>div.status { height:31px; overflow:auto; }
+fieldset.panel>div.status { display:none; overflow:auto; }
+fieldset.inner.simple>legend { display:none; }
+fieldset.inner.simple>form.option { display:none; }
+fieldset.inner.simple>div.status { display:none; }
+fieldset.inner.simple div.toggle { display:none; }
fieldset.Action>div.status { display:none; }
@@ -50,8 +58,8 @@ body.black fieldset.inner.float>div.output div.content { color:white; }
/* body.white fieldset.inner.float>div.output div.profile { color:black; } */
-body.simple fieldset.inner>div.output td.content>div.tabs { background-color:gray; padding:0px; height:31px; overflow:auto; display:block; }
-body.simple fieldset.inner>div.output td.content>div.tabs div.tabs { background-color:gray; font-family:monospace; padding:7px 20px; height:17px; float:left; }
+body.simple fieldset.inner>div.output td.content>div.tabs { background-color:slategrey; padding:0px; height:31px; overflow:auto; display:block; }
+body.simple fieldset.inner>div.output td.content>div.tabs div.tabs { background-color:teal; font-family:monospace; padding:7px 20px; height:17px; float:left; }
body.simple fieldset.inner>div.output td.content>div.tabs div.tabs.select { background-color:#1d3349; }
body.simple fieldset.inner>div.output td.content>div.tabs div.tabs:hover { background-color:#1d3349; }
body.simple fieldset.inner>div.output td.content>div.path { background-color:#1d3349; padding:4px 10px; margin-bottom:4px; display:block; clear:both; }
diff --git a/plugin/local/code/inner.js b/plugin/local/code/inner.js
index 81e23942..a1f9ae7e 100644
--- a/plugin/local/code/inner.js
+++ b/plugin/local/code/inner.js
@@ -1,71 +1,238 @@
-Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, target) {
- if (msg.Result() == "" && msg.Length() == 0) { can.onmotion.hidden(can, can._output); return }
- can.onmotion.toggle(can, can._output, true)
+Volcanos(chat.ONIMPORT, {help: "导入数据",
+ _tabs: function(can) {
+ can.ui._tabs = can.page.insertBefore(can, ["tabs"], can.ui._content)
+ can.ui._path = can.page.insertBefore(can, ["path"], can.ui._content)
+ },
- if (msg.Option(nfs.FILE)) {
- msg.Option(nfs.PATH) && can.Option(nfs.PATH, msg.Option(nfs.PATH))
- can.Option(nfs.FILE, msg.Option(nfs.FILE))
- msg.Option(nfs.LINE) && can.Option(nfs.LINE, msg.Option(nfs.LINE))
+ project: function(can, path) {
+ can.onimport.zone(can, can.core.Item(can.onfigure, function(name, cb) {
+ return can.base.isFunc(cb)? {name: name, _init: function(target, zone) { return cb(can, target, zone, path) }}: undefined
+ }), can.ui.project), can.user.isMobile && !can.user.isLandscape() && can.onmotion.hidden(can, can.ui.project)
+ },
+ tabview: function(can, path, file, line, cb) { var key = can.onexport.keys(can, path, file)
+ function isCommand() { return path == ctx.COMMAND || line == ctx.INDEX }
+ function isDream() { return line == web.DREAM }
+
+ function show() { if (can.isCmdMode()) { can.onimport._title(can, path+file) }
+ can._msg && can._msg.Option(nfs.LINE, can.Option(nfs.LINE)), can._msg = can.tabview[key]
+ can.Option(can.onimport.history(can, {path: path, file: file, line: line||can._msg.Option(nfs.LINE)||1}))
+ can.onsyntax._init(can, can._msg, function(content) { var msg = can._msg
+ can.ui._path && (can.ui._path.innerHTML = isDream()? can.page.Format(html.A, can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)})):
+ isCommand()? can.Option(nfs.FILE): can.base.Path(can.Option(nfs.PATH), can.Option(nfs.FILE)))
+ can.ui.current && can.onmotion.toggle(can, can.ui.current, !isCommand() && !isDream())
+
+ can.page.Select(can, can.ui._content.parentNode, can.page.Keys(html.DIV_CONTENT, html.IFRAME), function(item) {
+ if (can.onmotion.toggle(can, item, item == msg._content)) { can.ui.content = msg._content }
+ })
+ can.page.Select(can, can.ui._profile_output.parentNode, can.page.Keys(html.DIV_OUTPUT, html.IFRAME), function(item) {
+ if (can.onmotion.toggle(can, item, item == msg._profile_output)) { can.ui.profile_output = msg._profile_output }
+ })
+ can.onexport.hash(can), can.onimport.layout(can), can.base.isFunc(cb) && cb(), cb = null
+ isCommand() && can.onmotion.delay(can, function() {
+ can.onmotion.focus(can, can.page.Select(can, can.ui._content, html.OPTION_ARGS)[0])
+ }), can.onengine.signal(can, "tabview.view.show", msg)
+ })
+ }
+ function load(msg) { can.tabview[key] = msg
+ can.onimport.tabs(can, [{name: file.split(isCommand()? ice.PT: ice.PS).pop(), text: file}], function(event) {
+ can._tab = msg._tab = event.target, show()
+ }, function(item) { delete(can.tabview[key])
+ can.onengine.signal(can, "tabview.view.delete", msg)
+ delete(can._cache_data[can.base.Path(path, file)])
+ delete(can.ui._content._cache[can.base.Path(path, file)])
+ delete(can.ui._profile_output._cache[can.base.Path(path, file)])
+ delete(can.ui.display_output._cache[can.base.Path(path, file)])
+ msg._content != can.ui._content && can.page.Remove(can, msg._content)
+ }, can.ui._tabs)
}
- var paths = can.core.Split(can.Option(nfs.PATH), ice.FS); can.Option(nfs.PATH, paths[0])
- var files = can.core.Split(can.Option(nfs.FILE), ice.FS); can.Option(nfs.FILE, files[0])
- can.core.List(paths.concat(msg.modules||[], can.sup.paths||[]), function(p) { if (paths.indexOf(p) == -1) { paths.push(p) } })
- can.sup.paths = paths
+ if (can.tabview[key]) { return can.isCmdMode() && !can._msg._tab? load(can.tabview[key]): show() }
+ isCommand()||isDream()? load(can.request({}, {index: file, line: line})): can.run({}, [path, file], load, true)
+ },
+ history: function(can, push) {
+ can.base.Eq(push, can.history[can.history.length-1]) || can.history.push(push)
+ return can.Status("跳转数", can.history.length), push
+ },
+}, [""])
+Volcanos(chat.ONFIGURE, {help: "索引导航",
+ source: function(can, target, zone, path) { 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) { 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()), zone._total(total)
+ }, true) }
- can.tabview = can.tabview||{}, can.history = can.history||[], can.toolkit = {}, can.extentions = {}
- can.profile_size = {}, can.display_size = {}
+ if (path.length == 1) { return show(path[0], target) }
+ can.onmotion.delay(can, function() { target.previousSibling.innerHTML = "" })
+ can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target) { show(path, target) }} }), target)
+ },
+ plugin: function(can, target, zone) { var total = 0
+ can.onimport.tree(can, can.core.Item(can.onengine.plugin.meta, function(key) { return total++, {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), zone._total(total)
+ },
+})
+Volcanos(chat.ONSYNTAX, {help: "语法高亮", _init: function(can, msg, cb) {
+ if (can.onmotion.cache(can, function(cache_data) {
+ can.file && (cache_data[can.file] = {current: can.current, max: can.max,
+ profile_display: can.ui.profile.style.display, display_display: can.ui.display.style.display,
+ })
+ can.file = can.base.Path(can.Option(nfs.PATH), can.Option(nfs.FILE))
+ var p = cache_data[can.file]; p && (can.current = p.current, can.max = p.max)
+ can.page.style(can, can.ui.profile, {display: p? p.profile_display: html.NONE})
+ can.page.style(can, can.ui.display, {display: p? p.display_display: html.NONE})
+ can.parse = can.base.Ext(can.file), can.Status("模式", "plugin")
+ can.onengine.signal(can, "tabview.data.load", msg)
+ return can.file
- can.page.ClassList.add(can, can._fields, code.INNER)
- can.onmotion.clear(can), can.onlayout.profile(can)
- can.onimport._project(can, can.ui.project)
- can.onimport._profile(can, can.ui.profile)
- can.onimport._display(can, can.ui.display)
-
- can.onimport._input(can)
- can.require(["inner/syntax.js"], function() { can.base.isFunc(cb) && cb(msg) })
- can.ui._content = can.ui.content
- can.ui._profile_output = can.ui.profile_output
- can.onengine.plugin(can, can.onplugin)
-
- switch (can.Mode()) {
- case "simple": can.onimport._simple(can); break
- case "float": break
- case "cmd": can.onimport._tabs(can), can.onmotion.hidden(can, can._status) // no break
- case "full": // no break
- default: can.onimport.project(can, paths)
- can.onimport._toolkit(can, can.ui.toolkit), can.onimport._session(can, msg, function() {
- files.length > 1 && can.onmotion.delay(can, function() { can.core.Next(files.slice(1), function(file, next) {
- can.onimport.tabview(can, can.Option(nfs.PATH), file, can.Option(nfs.LINE), next)
- }, function() { can.onimport.tabview(can, paths[0], files[0], "") }) })
- }), can.onimport._keydown(can)
+ }, can.ui._content, can.ui._profile_output, can.ui.display_output)) {
+ can.onengine.signal(can, "tabview.view.load", msg)
+ return can.onaction.selectLine(null, can, can.Option(nfs.LINE)), can.base.isFunc(cb) && cb(msg._content)
}
- var hash = location.hash; 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), function() {
- if (can.isCmdMode() && hash) { var args = can.core.Split(decodeURIComponent(hash).slice(1))
- can.onmotion.delay(can, function() { can.onimport.tabview(can, can.Option(nfs.PATH), args[0], args[1]) })
+ if (msg.Option(ctx.INDEX)) { return can.onsyntax._index(can, msg, cb) }
+
+ function init(p) {
+ can.max = 0, can.core.List(can.ls = msg.Result().split(ice.NL), function(item) { can.onaction.appendLine(can, item) })
+ can.onaction.selectLine(null, can, can.Option(nfs.LINE)), can.onengine.signal(can, "tabview.view.init", msg)
+ can.base.isFunc(cb) && cb(msg._content = can.ui._content)
+ }
+ can.require(["inner/syntax.js"], function() { can.Conf("plug") && (can.onsyntax[can.parse] = can.Conf("plug"))
+ var p = can.onsyntax[can.parse]; !p? can.runAction({}, mdb.PLUGIN, [can.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)], function(msg) {
+ init(p = can.onsyntax[can.parse] = can.base.Obj(msg.Result()))
+ }): init(p)
+ })
+ },
+ _index: function(can, msg, cb) {
+ if (can.Option(nfs.LINE) == web.DREAM) {
+ return can.base.isFunc(cb) && cb(msg._content = msg._content||can.page.insertBefore(can, [{type: html.IFRAME, src: can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)}), width: can.ui.content.offsetWidth, height: can.ui.content.offsetHeight}], can.ui._content))
+ }
+
+ return can.onimport.plug(can, {index: msg.Option(ctx.INDEX), args: can.Option(nfs.PATH) == ctx.COMMAND && can.Option(nfs.LINE) != ctx.INDEX? [can.Option(nfs.LINE)]: []}, can.ui._content, function(sub) {
+ can.page.style(can, sub._output, html.MAX_HEIGHT, sub.ConfHeight(can.ui._content.offsetHeight-2*html.ACTION_HEIGHT))
+ can.page.style(can, sub._output, html.MAX_WIDTH, sub.ConfWidth(can.ui._content.offsetWidth))
+ can.onmotion.delay(can, function() { sub.Focus() }), can.base.isFunc(cb) && cb(msg._content = can.ui._content)
+
+ sub.onaction.close = function() { can.onaction.back({}, can), msg._tab._close() }
+ sub.onimport._open = function(sub, msg, _arg) { var url = can.base.ParseURL(_arg), ls = url.origin.split("/chat/pod/")
+ if (_arg.indexOf(location.origin) == 0 && ls.length > 1) {
+ return can.onimport.tabview(can, can.Option(nfs.PATH), ls[1].split("/")[0], web.DREAM), sub.Update() // 显示空间
+ }
+ return can.user.open(_arg), sub.Update()
}
})
},
- _input: function(can) {},
- _project: function(can, target) {
- target._toggle = function(event, show) { can.onimport.layout(can) }
+ _parse: function(can, line) { line = can.page.replace(can, line||"")
+ function wrap(type, str) { return can.page.Format(html.SPAN, str, type) }
+ var p = can.onsyntax[can.parse]; if (!p) { return line } p = can.onsyntax[p.link]||p, p.split = p.split||{}
+ p.keyword && (line = can.core.List(can.core.Split(line, p.split.space||"\t ", p.split.operator||"{[(,:;!|<*>)]}", {detail: true}), function(item, index, array) {
+ item = can.base.isObject(item)? item: {text: item}; var text = item.text, type = p.keyword[text]
+ switch (item.type||type) {
+ case html.SPACE: return text
+ case lang.STRING: return wrap(lang.STRING, item.left+text+item.right)
+ case code.COMMENT:
+ case code.KEYWORD:
+ case code.CONSTANT:
+ case code.DATATYPE:
+ case code.FUNCTION: return wrap(type, text)
+ default:
+ var t = can.core.Item(p.regexp, function(reg, type) {
+ var m = text.match(new RegExp(reg)); if (m && m.length > 0 && m[0] == text) { return type}
+ }); if (t && t.length > 0) { return wrap(t[0], text) }
+ return text
+ }
+ }).join(""))
+ p.prefix && can.core.Item(p.prefix, function(pre, type) { if (can.base.beginWith(line, pre)) { line = wrap(type, line) } })
+ p.suffix && can.core.Item(p.suffix, function(end, type) { if (can.base.endWith(line, end)) { line = wrap(type, line) } })
+ return line
},
- _panel: function(can, target, action) {
- var ui = can.page.Append(can, target, [html.ACTION, html.OUTPUT])
- var action = can.onappend._action(can, [], ui.action, kit.Dict(
- cli.CLOSE, function(event) { can.onmotion.hidden(can, target), can.onimport.layout(can) },
- cli.CLEAR, function(event) { can.onmotion.clear(can, ui.output) },
- cli.SHOW, function(event) { can.onaction[cli.SHOW](event, can) },
- action,
- mdb.PLUGIN, function(event) { can.user.input(event, can, [ctx.INDEX, ctx.ARGS], function(data) { can.onimport.plug(can, data, ui.output) }) },
- )); target._toggle = function(event, show) { action[show? cli.SHOW: cli.CLOSE](event) }
- return ui
+})
+Volcanos(chat.ONACTION, {help: "控件交互", list: [],
+ appendLine: function(can, value) {
+ var ui = can.page.Append(can, can.ui._content, [{type: html.TR, list: [
+ {view: ["line unselectable", html.TD, ++can.max], onclick: function(event) {
+ can.onaction.selectLine(event, can, ui.tr)
+ }, ondblclick: function(event) {
+ can.onaction.favorLine(can, ui.text.innerText)
+ }},
+
+ {view: [html.TEXT, html.TD], inner: can.onsyntax._parse(can, value), onclick: function(event) {
+ can.onaction.selectLine(event, can, ui.tr)
+
+ }, ondblclick: function(event) {
+ var s = document.getSelection().toString(), str = ui.text.innerText
+ var begin = str.indexOf(s), end = begin+s.length
+ for (var i = begin; i >= 0; i--) { if (str[i].match(/[a-zA-Z0-9_.]/)) { s = str.slice(i, end) } else { break } }
+ can.onaction.searchLine(event, can, s)
+ }}
+ ]}]); return ui.tr
},
+ selectLine: function(event, can, line) { if (!line) { return parseInt(can.core.Value(can.page.Select(can, can.ui._content, [[[html.TR, html.SELECT], [html.TD, "line"]]])[0], "innerText")) }
+ can.page.Select(can, can.ui._content, html.TR, function(item, index, array) {
+ if (!can.page.ClassList.set(can, item, html.SELECT, item == line || index+1 == line)) { return }
+ var ls = can.file.split(ice.PS); if (ls.length > 4) { ls = [ls.slice(0, 2).join(ice.PS)+"/.../"+ls.slice(-2).join(ice.PS)] }
+ line = item, can.Status(kit.Dict("文件名", ls.join(ice.PS), "解析器", can.parse, "当前行", can.onexport.position(can, can.Option(nfs.LINE, index+1))))
+ })
+ ; if (!can.base.isObject(line)) { return 1 }
+
+ can.page.Select(can, line, "td.text", function(item) {
+ can.current = {
+ window: function() { return parseInt(can.ui._content.offsetHeight/can.current.line.offsetHeight) },
+ scroll: function(count) { if (count) { can.ui._content.scrollTop += count*can.current.line.offsetHeight }
+ return parseInt((can.current.line.offsetTop-can.ui._content.scrollTop)/can.current.line.offsetHeight)
+ },
+ line: line, text: function(text) { return text != undefined && can.onaction.modifyLine(can, line, text), item.innerText },
+ prev: function() { return line.previousSibling }, next: function() { return line.nextSibling },
+ }
+
+ var scroll = can.current.scroll(); if (scroll < 3) { can.current.scroll(scroll-3) } else {
+ var window = can.current.window(); if (scroll > window-4) { can.current.scroll(scroll-window+4) }
+ }
+
+ can.onimport.history(can, {path: can.Option(nfs.PATH), file: can.Option(nfs.FILE), line: can.Option(nfs.LINE)})
+ can.onexport.hash(can), can.onengine.signal(can, "tabview.line.select", can.request(event))
+ }); return parseInt(can.page.Select(can, line, "td.line")[0].innerText)
+ },
+ searchLine: function(event, can, value) {
+ can.runAction(can.request(event, {name: value, text: can.current.text()}, can.Option()), NAVIGATE, [], function(msg) {
+ msg.Append(nfs.FILE)? can.onimport.tabview(can, msg.Append(nfs.PATH), msg.Append(nfs.FILE), msg.Append(nfs.LINE)):
+ can.user.toast(can, "not found")
+ })
+ },
+ 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),
+ ], function() { can.user.toast(can, ice.SUCCESS) })
+ })
+ },
+
+ back: function(event, can) { can.history.pop(); var last = can.history.pop()
+ last && can.onimport.tabview(can, last.path, last.file, last.line)
+ can.Status("跳转数", can.history.length)
+ },
+})
+Volcanos(chat.ONENGINE, {help: "搜索引擎",
+ listen: shy("监听事件", function(can, name, cb) { arguments.callee.meta[name] = (arguments.callee.meta[name]||[]).concat(cb) }),
+})
+Volcanos(chat.ONEXPORT, {help: "导出数据", list: ["文件数", "解析器", "文件名", "当前行", "跳转数", "标签数"],
+ keys: function(can, path, file, line) {
+ return [path||can.Option(nfs.PATH), file||can.Option(nfs.FILE)].join(ice.DF)
+ },
+ hash: function(can) { if (!can.isCmdMode()) { return }
+ var list = []; if (can.Option(nfs.PATH) != can.misc.Search(can, nfs.PATH)) { list.push(can.Option(nfs.PATH)) }
+ if (list.length > 0 || can.Option(nfs.FILE) != can.misc.Search(can, nfs.FILE)) { list.push(can.Option(nfs.FILE)) }
+ if (list.length > 0 || can.Option(nfs.LINE) != can.misc.Search(can, nfs.LINE)) { list.push(can.Option(nfs.LINE)||1) }
+ location.hash = list.join(ice.FS)
+ },
+ content: function(can) { return can.page.Select(can, can.ui.content, "td.text", function(item) { return item.innerText }).join(ice.NL) },
+ position: function(can, index, total) { total = total||can.max; return (parseInt(index))+ice.PS+parseInt(total)+" = "+parseInt((index)*100/total)+"%" },
+})
+
+Volcanos(chat.ONIMPORT, {help: "导入数据",
_profile: function(can, target) {
var ui = can.onimport._panel(can, target, kit.Dict(
- nfs.LOAD, function(event) { can.onaction[nfs.LOAD](event, can) },
mdb.LINK, function(event) {
if ([nfs.ZML, nfs.IML].indexOf(can.base.Ext(can.Option(nfs.FILE))) > -1) {
can.user.open(can.misc.MergeURL(can, {
@@ -88,7 +255,6 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
_display: function(can, target) {
var ui = can.onimport._panel(can, target, kit.Dict(
cli.SHOW, function(event) { can.onaction[cli.EXEC](event, can) },
- mdb.PLUGIN, function(event) { can.user.input(event, can, [ctx.INDEX, ctx.ARGS], function(data) { can.onimport.plug(can, data, ui.output) }) },
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.display_size[can.onexport.keys(can)] = can.ConfHeight()*parseInt(list[0])/100
@@ -97,116 +263,21 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", _init: function(can, msg, cb, tar
}
)); can.ui.display_output = ui.output, can.ui.display_status = ui.status
},
- _toolkit: function(can, target) {
- can.ui.toolkit = can.onappend.field(can, "toolkit", {}, can._output)
- },
- _session: function(can, msg) {
- can.onimport.sess(can, "", function() { can.onimport.sess(can, {
- exts: can.core.Split(msg.OptionOrSearch("exts")).reverse(),
- plug: can.core.Split(msg.OptionOrSearch("plug")).reverse(),
- tabs: can.core.Split(msg.OptionOrSearch("tabs")),
- }) })
- },
- _keydown: function(can) { can.onkeymap._build(can)
- can.isCmdMode() && can.onengine.listen(can, chat.ONKEYDOWN, function(event) {
- can._key_list = can.onkeymap._parse(event, can, mdb.PLUGIN, can._key_list, can.ui.content)
- })
- },
- _simple: function(can) {
- can.tabview[can.onexport.keys(can)] = can._msg
- can.ConfHeight(""), can.onmotion.hidden(can, can.ui.project)
- can.page.ClassList.add(can, can._fields, html.OUTPUT)
- can.page.ClassList.add(can, can._fields, "simple")
- },
- _tabs: function(can) {
- can.ui._tabs = can.page.insertBefore(can, [{view: "tabs"}], can.ui.content)
- can.ui._path = can.page.insertBefore(can, [{view: "path"}], can.ui.content)
- },
-
- layout: function(can) { if (can.isSimpleMode()) { return }
- if (can.isFloatMode()) { can.onmotion.hidden(can, can._action), can.onmotion.hidden(can, can.ui.project) }
-
- var width = can.ConfWidth()+(can.user.isMobile && can.isCmdMode() && can.user.isLandscape()? 16: 0)-(can.user.isWindows && !can.isCmdMode()? 20: 0)
- can.page.styleWidth(can, can.ui.profile_output, can.profile_size[can.onexport.keys(can)]||(width-can.ui.project.offsetWidth)/3)
- can.page.styleWidth(can, can.ui.content, width-can.ui.project.offsetWidth-can.ui.profile.offsetWidth)
- can.page.styleWidth(can, can.ui.display, width-can.ui.project.offsetWidth)
-
- var height = can.ConfHeight()
- if (can.user.isMobile && can.isFloatMode()) { height = can._root._height-2*html.ACTION_HEIGHT }
-
- if (can.isCmdMode()) {
- if (can.ui.display.display != html.NONE) {
- if (can.ui.display.offsetHeight > can.base.Min(can.ConfHeight() / 2, 200)) {
- can.page.style(can, can.ui.display_output, html.MAX_HEIGHT, can.base.Min(can.ConfHeight() / 2, 200))
- }
- }
- if (can._status.style.display == html.NONE) { height += html.ACTION_HEIGHT }
- var rest = can.ui.display.offsetHeight+can.ui._tabs.offsetHeight+can.ui._path.offsetHeight+4
- can.page.styleHeight(can, can.ui.content, height+html.ACTION_HEIGHT-rest)
- can.page.styleHeight(can, can.ui.profile_output, height-can.ui.display.offsetHeight)
- can.page.styleHeight(can, can.ui.project, height+html.ACTION_HEIGHT)
- } else { var rest = can.ui.display.offsetHeight; if (height < 320) { height = 320 }
- if (!can.isFullMode()) {
- can._min_height = can._min_height||height, height >= can._min_height && (can._min_height = height)
- can.page.style(can, can.ui.content, html.MIN_HEIGHT, can._min_height)
- }
- can.page.style(can, can.ui.content, can.user.isMobile? html.HEIGHT: html.MAX_HEIGHT, height-rest)
- can.page.styleHeight(can, can.ui.profile_output, can.ui.content.offsetHeight-html.ACTION_HEIGHT)
- can.page.styleHeight(can, can.ui.project, can.ui.content.offsetHeight+rest)
- }
- can.page.Select(can, can.ui.profile, html.IFRAME, function(iframe) {
- can.page.Modify(can, iframe, {height: can.ui.profile.offsetHeight-html.ACTION_HEIGHT-4, width: can.ui.profile.offsetWidth})
- })
- },
- project: function(can, path) {
- if (can.ConfHeight() < 320) { can.ConfHeight(320) }
- can.user.isMobile && !can.user.isLandscape() && can.onmotion.hidden(can, can.ui.project)
- can.onimport.zone(can, can.core.Item(can.onfigure, function(name, cb) {
- return can.base.isFunc(cb)? {name: name, _init: function(target, zone) { cb(can, target, zone, path) }}: undefined
- }), can.ui.project)
- },
- history: function(can, push) {
- can.base.Eq(push, can.history[can.history.length-1]) || can.history.push(push)
- return can.Status("跳转数", can.history.length), push
- },
- tabview: function(can, path, file, line, cb, skip, skip2) { var key = can.onexport.keys(can, file, path)
- if (can.isCmdMode()) { (location.hash = location.pathname.indexOf(file) > -1? "": file+ice.FS+(line||1)) }
-
- if (!skip && can.tabview[key]) { if (can.isCmdMode()) { can.onimport._title(can, path+file) }
- can._msg && can._msg.Option(nfs.LINE, can.Option(nfs.LINE)), can._msg = can.tabview[key]
- can.Option({path: path, file: file, line: line||can._msg.Option(nfs.LINE)||1})
- return can._msg.Option(can.Option()), can.onsyntax._init(can, can._msg, cb, skip2)
- }
-
- function show(msg) { var skip2 = skip; can.tabview[key] = msg
- can.onimport.tabs(can, [{name: file.split(line == ctx.INDEX? ice.PT: ice.PS).pop(), text: file}], function(event, meta) {
- can._tab = msg._tab = event.target, can.onimport.tabview(can, path, file, msg.Option(nfs.LINE)||line, cb, false, skip2), cb = null, skip2 = false
- }, function(item) { // 关闭文件
- delete(can.tabview[key])
- delete(can._cache_data[can.base.Path(path, file)])
- delete(can.ui._content._cache[can.base.Path(path, file)])
- delete(can.ui._profile_output._cache[can.base.Path(path, file)])
- delete(can.ui.display_output._cache[can.base.Path(path, file)])
- msg._content != can.ui._content && can.page.Remove(can, msg._content)
- }, can.ui._tabs, function(item) {})
- }
-
- can.Option(can.onimport.history(can, {path: path, file: file, line: line}))
- path == ctx.COMMAND || line == ctx.INDEX? /* 命令 */ show(can.request({}, {index: file, line: line})):
- line == web.DREAM? /* 空间 */ show(can.request({}, {index: file, line: line})):
- /* 文件 */ can.run({}, [path, file], show, true)
- },
profile: function(can, msg) {
- var width = can.profile_size[can.onexport.keys(can)]||(can.ConfWidth()-can.ui.project.offsetWidth)/2
if (msg) {
var sup = can.tabview[can.onexport.keys(can)]
can.onmotion.toggle(can, can.ui.profile_output, false)
if (msg.Result().indexOf("