forked from x/volcanos
opt inner.js
This commit is contained in:
parent
9230c610a4
commit
2dfd2306da
2
frame.js
2
frame.js
@ -58,7 +58,7 @@ Volcanos(chat.ONENGINE, {_init: function(can, meta, list, cb, target) { can.requ
|
|||||||
listen: shy(function(can, name, cb) { arguments.callee.meta[name] = (arguments.callee.meta[name]||[]).concat(cb) }),
|
listen: shy(function(can, name, cb) { arguments.callee.meta[name] = (arguments.callee.meta[name]||[]).concat(cb) }),
|
||||||
signal: function(can, name, msg) { msg = msg||can.request(); var _msg = name == chat.ONREMOTE? msg.Option("_msg"): msg
|
signal: function(can, name, msg) { msg = msg||can.request(); var _msg = name == chat.ONREMOTE? msg.Option("_msg"): msg
|
||||||
_msg.Option(ice.LOG_DISABLE) == ice.TRUE || can.misc.Log(name, can._name, (msg._cmds||[]).join(ice.SP), name == chat.ONMAIN? can: _msg, _msg._can._target)
|
_msg.Option(ice.LOG_DISABLE) == ice.TRUE || can.misc.Log(name, can._name, (msg._cmds||[]).join(ice.SP), name == chat.ONMAIN? can: _msg, _msg._can._target)
|
||||||
return can.core.List(can.onengine.listen.meta[name], function(cb) { can.core.CallFunc(cb, {event: msg._event, msg: msg}) }).length
|
return can.core.List(can.onengine.listen.meta[name], function(cb) { can.core.CallFunc(cb, {event: msg._event, msg: msg}) }).length, msg
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONDAEMON, {_init: function(can, name) { if (can.user.isLocalFile) { return }
|
Volcanos(chat.ONDAEMON, {_init: function(can, name) { if (can.user.isLocalFile) { return }
|
||||||
|
@ -93,9 +93,11 @@ body>div.toast div.progress { border:green solid 1px; margin-left:0px; height:20
|
|||||||
body>div.toast div.progress div.current { background-color:red; height:18px; }
|
body>div.toast div.progress div.current { background-color:red; height:18px; }
|
||||||
body>div.toast div.action { display:block; }
|
body>div.toast div.action { display:block; }
|
||||||
body>div.carte { padding:0; }
|
body>div.carte { padding:0; }
|
||||||
body>div.carte input[name=filter] { margin:5px; width:calc(100% - 10px); position:sticky; top:0; }
|
body>div.carte input[name=filter] { margin:5px; width:calc(100% - 10px); position:sticky; top:5px; }
|
||||||
body>div.carte div.item { padding:5px 10px; }
|
body>div.carte div.item { padding:5px 10px; }
|
||||||
body>div.input td { padding:5px; }
|
body>div.input td { padding:5px; }
|
||||||
|
body>div.input td span.icon { font-size:14px; margin-left:-25px; margin-right:10px; visibility:hidden; }
|
||||||
|
body>div.input td:hover span.icon { visibility:visible; }
|
||||||
body>div.input select { width:200px; }
|
body>div.input select { width:200px; }
|
||||||
body>div.input textarea { height:120px; width:200px; }
|
body>div.input textarea { height:120px; width:200px; }
|
||||||
body>div.input input:not([type=button]) { width:200px; }
|
body>div.input input:not([type=button]) { width:200px; }
|
||||||
@ -141,6 +143,7 @@ form.option>div.item>span.icon { font-size:20px; position:absolute; top:2px; rig
|
|||||||
form.option>div.item:hover>span.icon { visibility:visible; }
|
form.option>div.item:hover>span.icon { visibility:visible; }
|
||||||
form.option>div.icon { font-size:26px; margin-right:5px; display:none; }
|
form.option>div.icon { font-size:26px; margin-right:5px; display:none; }
|
||||||
form.option>div.icon:hover { background-color:white; }
|
form.option>div.icon:hover { background-color:white; }
|
||||||
|
fieldset.story>form.option>div.icon { display:block; }
|
||||||
fieldset.float>form.option>div.icon { display:block; }
|
fieldset.float>form.option>div.icon { display:block; }
|
||||||
fieldset.full>form.option>div.icon { display:block; }
|
fieldset.full>form.option>div.icon { display:block; }
|
||||||
fieldset.plug>form.option>div.icon { margin-left:5px; }
|
fieldset.plug>form.option>div.icon { margin-left:5px; }
|
||||||
|
@ -129,7 +129,12 @@ Volcanos("user", {info: {}, agent: {
|
|||||||
can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) { item.name && item.value && _msg.Option(item.name, item.value) })
|
can.page.Select(can, ui.table, html.OPTION_ARGS, function(item) { item.name && item.value && _msg.Option(item.name, item.value) })
|
||||||
;(item.run||can.run)(event, cmds, cb, true)
|
;(item.run||can.run)(event, cmds, cb, true)
|
||||||
}, _enter: function(event) { return action.submit(event, can, html.SUBMIT), true }}, item), target)
|
}, _enter: function(event) { return action.submit(event, can, html.SUBMIT), true }}, item), target)
|
||||||
}; return {type: html.TR, list: [{type: html.TD, list: [{text: [item.name||"", html.LABEL]}, {text: item.need == "must"? "*": "", style: {color: cli.RED}}]}, {type: html.TD, list: [can.page.input(can, item)]}]}
|
}; return {type: html.TR, list: [
|
||||||
|
{type: html.TD, list: [{text: [item.name||"", html.LABEL]},
|
||||||
|
{text: item.need == "must"? "*": "", style: {color: cli.RED}}]},
|
||||||
|
{type: html.TD, list: [can.page.input(can, item), item.type == html.TEXT && {view: [html.ICON, html.SPAN, can.page.unicode.delete], onclick: function(event) {
|
||||||
|
event.target.previousSibling.value = ""
|
||||||
|
}}]}]}
|
||||||
})}]}, html.ACTION,
|
})}]}, html.ACTION,
|
||||||
]}])
|
]}])
|
||||||
var action = can.onappend._action(can, button||[html.SUBMIT, html.CANCEL], ui.action, {
|
var action = can.onappend._action(can, button||[html.SUBMIT, html.CANCEL], ui.action, {
|
||||||
|
@ -26,8 +26,8 @@ fieldset.inner.cmd>div.output>div.layout.flow>div.tabs.hide { display:none; }
|
|||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div { padding:10px; height:38px; float:left; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div { padding:10px; height:38px; float:left; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div>span { font-style:italic; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div>span { font-style:italic; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div>span.icon { padding:0 5px; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs>div>span.icon { padding:0 5px; }
|
||||||
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.website.icon { font-size:18px; line-height:32px; padding:2px 5px; margin-top:2px; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.avatar { padding:0; height:38px; float:right; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.avatar { padding:0; height:38px; float:right; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.create.icon { font-size:18px; line-height:32px; padding:2px 5px; margin-top:2px; }
|
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.avatar>img { height:38px; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.avatar>img { height:38px; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.time { float:right; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.tabs div.time { float:right; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.path { font-style:italic; padding:5px; display:block; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.path { font-style:italic; padding:5px; display:block; }
|
||||||
@ -35,7 +35,10 @@ fieldset.inner.cmd>div.output>div.layout.flow>div.path.hide { display:none; }
|
|||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.path span.func { margin-left:20px; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.path span.func { margin-left:20px; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.path span.view { font-size:22px; line-height:12px; padding:0 4px; float:right; cursor:pointer; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.path span.view { font-size:22px; line-height:12px; padding:0 4px; float:right; cursor:pointer; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.plug { height:31px; clear:both; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.plug { height:31px; clear:both; }
|
||||||
fieldset.inner.cmd>div.output>div.layout.flow>div.plug>legend { float:right; }
|
fieldset.inner.cmd>div.output>div.layout.flow>div.plug>legend { font-size:1rem; padding:0 10px; float:right; }
|
||||||
|
div.vimer.find.float div.item>span.icon { margin-left:-20px; margin-right:10px; visibility:hidden; }
|
||||||
|
div.vimer.find.float div.item:hover>span.icon { visibility:visible; }
|
||||||
|
div.vimer.open.float td:first-child { display:none; }
|
||||||
|
|
||||||
body.black fieldset.inner>div.output div.content td.text span.comment { background-color:blue; color:cyan; }
|
body.black fieldset.inner>div.output div.content td.text span.comment { background-color:blue; color:cyan; }
|
||||||
body.white fieldset.inner.cmd>div.output { background-color:aliceblue; }
|
body.white fieldset.inner.cmd>div.output { background-color:aliceblue; }
|
||||||
|
@ -6,28 +6,26 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
var files = can.core.Split(can.Option(nfs.FILE), ice.FS); can.Option(nfs.FILE, files[0])
|
var files = can.core.Split(can.Option(nfs.FILE), ice.FS); can.Option(nfs.FILE, files[0])
|
||||||
var paths = can.core.Split(can.Option(nfs.PATH), ice.FS); can.Option(nfs.PATH, paths[0])
|
var paths = can.core.Split(can.Option(nfs.PATH), ice.FS); can.Option(nfs.PATH, paths[0])
|
||||||
can.core.List(paths.concat(can.core.Split(msg.Option(nfs.REPOS))), function(p) { if (p && paths.indexOf(p) == -1 && p[0] != ice.PS) { paths.push(p) } })
|
can.core.List(paths.concat(can.core.Split(msg.Option(nfs.REPOS))), function(p) { if (p && paths.indexOf(p) == -1 && p[0] != ice.PS) { paths.push(p) } })
|
||||||
can.db = {paths: paths, tabview: {}, history: [], profile_size: {}, display_size: {}, toolkit: {}, extentions: {}}, can.onengine.plugin(can, can.onplugin)
|
can.db = {paths: paths, tabview: {}, history: [], profile_size: {}, display_size: {}, toolkit: {}}, can.onengine.plugin(can, can.onplugin)
|
||||||
can.ui = can.onappend.layout(can, can._output, "", [html.PROJECT, [html.TABS, nfs.PATH, [html.CONTENT, html.PROFILE], html.DISPLAY, html.PLUG]])
|
can.ui = can.onappend.layout(can, can._output, "", [html.PROJECT, [html.TABS, nfs.PATH, [html.CONTENT, html.PROFILE], html.DISPLAY, html.PLUG]])
|
||||||
can.ui._content = can.ui.content, can.ui._profile = can.ui.profile, can.ui._display = can.ui.display, can.onmotion.hidden(can, can.ui.plug)
|
can.ui._content = can.ui.content, can.ui._profile = can.ui.profile, can.ui._display = can.ui.display, can.onmotion.hidden(can, can.ui.plug)
|
||||||
switch (can.Mode()) {
|
switch (can.Mode()) {
|
||||||
case chat.SIMPLE: // no break
|
case chat.SIMPLE: // no break
|
||||||
case chat.FLOAT: can.onmotion.hidden(can, can.ui.project); break
|
case chat.FLOAT: can.onmotion.hidden(can, can.ui.project); break
|
||||||
case chat.CMD: can.onmotion.hidden(can, can._status), can.onimport._keydown(can)
|
case chat.CMD: can.onimport._keydown(can), can.onmotion.hidden(can, can._status)
|
||||||
var plug = can.base.Obj(msg.Option("plug"), []).concat(can.misc.Search(can, log.DEBUG) == ice.TRUE? ["can.debug", "log.debug"]: [])
|
var plug = can.base.Obj(msg.Option(html.PLUG), []).concat(can.misc.Search(can, log.DEBUG) == ice.TRUE? ["can.debug", "log.debug"]: [])
|
||||||
plug.length > 0 && can.run({}, [ctx.ACTION, ctx.COMMAND].concat(plug.reverse()), function(msg) { msg.Table(function(value) { can.onimport.toolkit(can, value) }) })
|
plug.length > 0 && can.run({}, [ctx.ACTION, ctx.COMMAND].concat(plug.reverse()), function(msg) { msg.Table(function(value) { can.onimport.toolkit(can, value) }) })
|
||||||
// no break
|
|
||||||
case chat.FULL: // no break
|
case chat.FULL: // no break
|
||||||
default: can.onimport.project(can, paths), can.onimport._tabs(can)
|
default: can.onimport.project(can, paths), can.onimport._tabs(can)
|
||||||
can.onmotion.delay(can, function() { can.core.Next(files.slice(1), function(file, next) {
|
can.onmotion.delay(can, function() { can.core.Next(files.slice(1), function(file, next) { can.onimport._tabview(can, paths[0], file, "", next) }, function() {
|
||||||
can.onimport._tabview(can, can.Option(nfs.PATH), file, "", next)
|
can.core.List(can.base.Obj(msg.Option(html.TABS)), function(item) { can.onimport.tabview(can, paths[0], item, ctx.INDEX) })
|
||||||
}, function() { files.length > 1 && can.onimport._tabview(can, paths[0], files[0], "")
|
if (can.user.isWebview) { var last = can.misc.localStorage(can, "web.code.inner:currentFile"); if (last) {
|
||||||
if (can.user.isWebview) { var last = can.misc.localStorage(can, "web.code.inner:currentFile"); if (!last) { return } }
|
var ls = can.core.Split(last, ice.DF); ls.length > 0 && can.onimport._tabview(can, ls[0], ls[1], ls[2])
|
||||||
var ls = can.core.Split(last, ice.DF); ls.length > 0 && can.onmotion.delayLong(can, function() { can.onimport._tabview(can, ls[0], ls[1], ls[2]) })
|
} }
|
||||||
can.core.List(can.base.Obj(msg.Option("tabs")), function(item) { can.onimport.tabview(can, can.Option(nfs.PATH), item, ctx.INDEX) })
|
|
||||||
}) })
|
}) })
|
||||||
} var args = can.misc.SearchHash(can); can.db.tabview[can.onexport.keys(can)] = msg
|
} var args = can.misc.SearchHash(can); can.db.tabview[can.onexport.keys(can)] = msg
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE), function() { if (args.length > 0) {
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE), function() { if (!can.user.isWebview || args.length > 0) {
|
||||||
can.onmotion.delayLong(can, function() { can.onimport._tabview(can, args[args.length-3]||can.Option(nfs.PATH), args[args.length-2]||can.Option(nfs.FILE), args[args.length-1]) })
|
can.onimport._tabview(can, args[args.length-3]||can.Option(nfs.PATH), args[args.length-2]||can.Option(nfs.FILE), args[args.length-1])
|
||||||
} }), can.base.isFunc(cb) && cb(msg)
|
} }), can.base.isFunc(cb) && cb(msg)
|
||||||
},
|
},
|
||||||
_keydown: function(can) { can.onkeymap._build(can), can._root.onengine.listen(can, chat.ONKEYDOWN, function(event) {
|
_keydown: function(can) { can.onkeymap._build(can), can._root.onengine.listen(can, chat.ONKEYDOWN, function(event) {
|
||||||
@ -35,102 +33,103 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
can.db._key_list = can.onkeymap._parse(event, can, mdb.PLUGIN, can.db._key_list, can.ui.content)
|
can.db._key_list = can.onkeymap._parse(event, can, mdb.PLUGIN, can.db._key_list, can.ui.content)
|
||||||
}) },
|
}) },
|
||||||
_tabs: function(can) { if (!can.isCmdMode()) { return can.ui.tabs = can._action }
|
_tabs: function(can) { if (!can.isCmdMode()) { return can.ui.tabs = can._action }
|
||||||
can.page.Append(can, can.ui.tabs, [{view: [[html.ICON, mdb.CREATE], html.DIV, can.page.unicode.menu], onclick: function() { can.user.carte(event, can, can.onaction, can.onaction.list) }}])
|
can.core.List([{name: can.page.unicode.menu, onclick: function() { can.user.carte(event, can, can.onaction, can.onaction.list) }},
|
||||||
can.page.Append(can, can.ui.tabs, [{view: [[html.ICON, mdb.CREATE], html.DIV, "\u25C0"], style: {"font-size": "14px", "margin-top": "3px"}, onclick: function() { history.back() }}])
|
{name: "\u25C0", style: {"font-size": "14px", "margin-top": "3px"}, onclick: function() { history.back() }},
|
||||||
can.page.Append(can, can.ui.tabs, [{view: [[html.ICON, mdb.CREATE], html.DIV, "\u21BB"], style: {"font-size": "24px", "margin-top": "0px"}, onclick: function() { location.reload() }}])
|
{name: "\u21BB", style: {"font-size": "24px", "margin-top": "0px"}, onclick: function() { location.reload() }},
|
||||||
can.page.Append(can, can.ui.tabs, [{view: [[html.ICON, mdb.CREATE], html.DIV, "\u25B6"], style: {"font-size": "14px", "margin-top": "3px"}, onclick: function() { history.forward() }}])
|
{name: "\u25B6", style: {"font-size": "14px", "margin-top": "3px"}, onclick: function() { history.forward() }},
|
||||||
can.user.isMobile || can.page.Append(can, can.ui.tabs, [{view: [mdb.TIME], _init: function(target) {
|
], function(item) { can.page.Append(can, can.ui.tabs, [{view: [[html.ICON, web.WEBSITE], html.DIV, item.name], style: item.style, onclick: item.onclick}]) })
|
||||||
|
can.user.isMobile || can.page.Append(can, can.ui.tabs, [{view: mdb.TIME, _init: function(target) {
|
||||||
can.core.Timer({interval: 100}, function() { can.page.Modify(can, target, can.user.time(can, null, "%y-%m-%d %H:%M:%S %w")) })
|
can.core.Timer({interval: 100}, function() { can.page.Modify(can, target, can.user.time(can, null, "%y-%m-%d %H:%M:%S %w")) })
|
||||||
can.onappend.figure(can, {action: "date", _hold: true}, target, function(sub, value) {})
|
can.onappend.figure(can, {action: "date", _hold: true}, target, function(sub, value) {})
|
||||||
}}]), can.user.info.avatar && can.page.Append(can, can.ui.tabs, [{view: [aaa.AVATAR], list: [{img: can.user.info.avatar}]}])
|
}}]), can.user.info.avatar && can.page.Append(can, can.ui.tabs, [{view: aaa.AVATAR, list: [{img: can.user.info.avatar}]}])
|
||||||
},
|
},
|
||||||
_tabInputs: function(can, ps, key, value, cb, target) { can.core.List(can.core.Split(value, ps), function(value, index, array) {
|
_tabPath: function(can, ps, key, value, cb, target) { can.core.List(can.core.Split(value, ps), function(value, index, array) {
|
||||||
can.page.Append(can, target, [{text: [value+(index<array.length-1? ps: ""), html.SPAN, html.ITEM], onclick: function(event) {
|
can.page.Append(can, target, [{text: [value+(index<array.length-1? ps: ""), html.SPAN, html.ITEM], onclick: function(event) {
|
||||||
can.onimport.tabInputs(event, can, ps, key, (array.slice(0, index).join(ps)||ice.PT)+ps, cb)
|
can.onimport.tabPath(event, can, ps, key, (array.slice(0, index).join(ps)||ice.PT)+ps, cb)
|
||||||
}}])
|
}}])
|
||||||
}) },
|
}) },
|
||||||
tabInputs: function(event, can, ps, key, pre, cb, parent) { can.runAction(event, mdb.INPUTS, [key, pre], function(msg) { var _trans = {}
|
tabPath: function(event, can, ps, key, pre, cb, parent) { can.runAction(event, mdb.INPUTS, [key, pre], function(msg) { var _trans = {}
|
||||||
var carte = can.user[parent? "carteRight": "carte"](event, can, {_style: nfs.PATH}, msg.Table(function(value) {
|
var carte = can.user[parent? "carteRight": "carte"](event, can, {_style: nfs.PATH}, msg.Table(function(value) {
|
||||||
var p = can.core.Split(value[key], ps).pop()+(can.base.endWith(value[key], ps)? ps: ""); return _trans[p] = value[key], p
|
var p = can.core.Split(value[key], ps).pop()+(can.base.endWith(value[key], ps)? ps: ""); return _trans[p] = value[key], p
|
||||||
}), function(event, button) {
|
}), function(event, button) {
|
||||||
can.base.endWith(button, ps)? can.onimport.tabInputs(event, can, ps, key, pre+button, cb, carte): cb(can.core.Split(_trans[button], ps))
|
can.base.endWith(button, ps)? can.onimport.tabPath(event, can, ps, key, pre+button, cb, carte): cb(can.core.Split(_trans[button], ps))
|
||||||
}, parent)._target, file = can.core.Split(event.target.innerHTML.trim(), ice.PT)[0]
|
}, parent)._target, file = can.core.Split(event.target.innerHTML.trim(), ice.PT)[0]
|
||||||
can.page.Select(can, carte, html.DIV_ITEM, function(target) { target.innerHTML.trim() != event.target.innerHTML.trim() && can.base.beginWith(target.innerHTML, file+ice.PT) && carte.insertBefore(target, carte.firstChild) })
|
can.page.Select(can, carte, html.DIV_ITEM, function(target) { target.innerHTML.trim() != event.target.innerHTML.trim() && can.base.beginWith(target.innerHTML, file+ice.PT) && carte.insertBefore(target, carte.firstChild) })
|
||||||
function remove(p) { if (p && p._sub) { remove(p._sub), can.page.Remove(can, p._sub), delete(p._sub) } } if (parent) { remove(parent), parent._sub = carte }
|
function remove(p) { if (p && p._sub) { remove(p._sub), can.page.Remove(can, p._sub), delete(p._sub) } } if (parent) { remove(parent), parent._sub = carte }
|
||||||
}) },
|
}) },
|
||||||
_tabFunc: function(can, target) { can.db.tabFunc = can.db.tabFunc||{}
|
_tabFunc: function(can, target) {
|
||||||
var last = can.db.tabFunc[can.Option(nfs.PATH)+can.Option(nfs.FILE)]||{}; can.db.tabFunc[can.Option(nfs.PATH)+can.Option(nfs.FILE)] = last
|
|
||||||
var carte, list = [{input: [html.FILTER, function(event) { if (event.key == lang.ESCAPE) { return can.page.Remove(can, carte._target) } can.onkeymap.selectItems(event, can, carte._target)
|
|
||||||
}], _init: function(target) { can.onmotion.delay(can, function() { target.placeholder = "search in "+list.length+" items", target.focus() }) }}]
|
|
||||||
can.core.Item(last, function(key) { list.push(key) }); var func = can.onexport.func(can); list = list.concat(func.list)
|
|
||||||
!can.user.isMobile && (can.db.parse == nfs.JS || can.db.parse == nfs.GO) && can.page.Append(can, target, [{view: [[html.ITEM, "func"], html.SPAN, (func.current||"function")+" / "+can.db.max+func.percent], onclick: function(event) {
|
|
||||||
carte = can.user.carte(event, can, {_style: nfs.PATH}, list, function(ev, button) { last[button] = true
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.core.Split(button, ice.DF)[1]), carte.close()
|
|
||||||
})
|
|
||||||
}}]), can.ui.path.ondblclick = function(event) { can.onmotion.toggle(can, can.ui.project), can.onmotion.toggle(can, can.ui.tabs), can.onmotion.toggle(can, can.ui.plug), can.onimport.layout(can) }
|
|
||||||
can.page.Append(can, can.ui.path, can.core.Item({
|
can.page.Append(can, can.ui.path, can.core.Item({
|
||||||
"\u25E8 ": function(event) {
|
"\u25E8 ": function(event) {
|
||||||
if (can.page.isDisplay(can.ui.profile)) { return can.onmotion.hidden(can, can.ui.profile), can.onimport.layout(can) }
|
if (can.page.isDisplay(can.ui.profile)) { return can.onmotion.hidden(can, can.ui.profile), can.onimport.layout(can) } can.onaction.show(event, can)
|
||||||
can.onaction.show(event, can)
|
|
||||||
},
|
},
|
||||||
"\u25E8": shy({"font-size": "23px", rotate: "90deg", translate: "1px 1px"}, function(event) {
|
"\u25E8": shy({"font-size": "23px", rotate: "90deg", translate: "1px 1px"}, function(event) {
|
||||||
if (can.page.isDisplay(can.ui.display)) { return can.onmotion.hidden(can, can.ui.display), can.onimport.layout(can) }
|
if (can.page.isDisplay(can.ui.display)) { return can.onmotion.hidden(can, can.ui.display), can.onimport.layout(can) } can.onaction.exec(event, can)
|
||||||
can.onaction.exec(event, can)
|
|
||||||
}),
|
}),
|
||||||
"\u25E7": function(event) { can.onmotion.toggle(can, can.ui.project), can.onimport.layout(can) },
|
"\u25E7": function(event) { can.onmotion.toggle(can, can.ui.project), can.onimport.layout(can) },
|
||||||
"\u2756": !can.user.isMobile && shy({"font-size": "20px", translate: "0 2px"}, function(event) { can.onaction.plug(event, can) }),
|
"\u2756": !can.user.isMobile && shy({"font-size": "20px", translate: "0 2px"}, function(event) { can.onaction.plug(event, can) }),
|
||||||
"\u271A": !can.user.isMobile && shy({"font-size": "20px", translate: "0 2px"}, function(event) { can.onaction.open(event, can) }),
|
"\u271A": !can.user.isMobile && shy({"font-size": "20px", translate: "0 2px"}, function(event) { can.onaction.open(event, can) }),
|
||||||
}, function(text, cb) { return cb && {text: [text, html.SPAN, html.VIEW], style: cb.meta, onclick: cb} }))
|
}, function(text, cb) { return cb && {text: [text, html.SPAN, html.VIEW], style: cb.meta, onclick: cb} }))
|
||||||
|
// if (can.user.isMobile) { return }
|
||||||
|
var func = can.onexport.func(can); if (func.list.length == 0) { return } can.db.tabFunc = can.db.tabFunc||{}
|
||||||
|
var last = can.db.tabFunc[can.Option(nfs.PATH)+can.Option(nfs.FILE)]||{}; can.db.tabFunc[can.Option(nfs.PATH)+can.Option(nfs.FILE)] = last
|
||||||
|
var carte, list = [{input: [html.FILTER, function(event) { if (event.key == lang.ESCAPE) { return carte.close() } can.onkeymap.selectItems(event, can, carte._target)
|
||||||
|
}], _init: function(target) { can.onmotion.delay(can, function() { target.placeholder = "search in "+list.length+" items", target.focus() }) }}]
|
||||||
|
can.core.Item(last, function(key) { list.push(key) }), list = list.concat(func.list)
|
||||||
|
can.page.Append(can, target, [{view: [[html.ITEM, "func"], html.SPAN, (func.current||"func")+" / "+can.db.max+func.percent], onclick: function(event) {
|
||||||
|
carte = can.user.carte(event, can, {_style: nfs.PATH}, list, function(ev, button) { last[button] = true
|
||||||
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.Option(nfs.FILE), can.core.Split(button, ice.DF)[1]), carte.close()
|
||||||
|
})
|
||||||
|
}}]), can.ui.path.ondblclick = function(event) { can.onmotion.toggle(can, can.ui.project), can.onmotion.toggle(can, can.ui.tabs), can.onmotion.toggle(can, can.ui.plug), can.onimport.layout(can) }
|
||||||
},
|
},
|
||||||
_tabview: function(can, path, file, line, cb) { var key = can.onexport.keys(can, path, file)
|
_tabview: function(can, path, file, line, cb) { var key = can.onexport.keys(can, path, file)
|
||||||
|
if (!can.user.isWebview) { return can.onimport.tabview(can, path, file, line, cb) }
|
||||||
if (!can.db.tabview[key]) { return can.onimport.tabview(can, path, file, line, cb), can.db.tabview[key] = true }
|
if (!can.db.tabview[key]) { return can.onimport.tabview(can, path, file, line, cb), can.db.tabview[key] = true }
|
||||||
},
|
},
|
||||||
tabview: function(can, path, file, line, cb) { var key = can.onexport.keys(can, path, file)
|
tabview: function(can, path, file, line, cb) { var key = can.onexport.keys(can, path, file)
|
||||||
function isCommand() { return line == ctx.INDEX || path == ctx.COMMAND }
|
function isIndex() { return line == ctx.INDEX } function isDream() { return line == web.DREAM }
|
||||||
function isDream() { return line == web.DREAM }
|
function show(skip) { can._msg && can._msg.Option(nfs.LINE, can.Option(nfs.LINE)), can._msg = can.db.tabview[key]
|
||||||
function show(skip) { if (can.isCmdMode()) { can.onexport.title(can, path+file) }
|
|
||||||
can._msg && can._msg.Option(nfs.LINE, can.Option(nfs.LINE)), can._msg = can.db.tabview[key]
|
|
||||||
can.Option(can.onimport.history(can, {path: path, file: file, line: line||can.misc.localStorage(can, "web.code.inner:selectLine:"+path+file)||can._msg.Option(nfs.LINE)||1}))
|
can.Option(can.onimport.history(can, {path: path, file: file, line: line||can.misc.localStorage(can, "web.code.inner:selectLine:"+path+file)||can._msg.Option(nfs.LINE)||1}))
|
||||||
can.onsyntax._init(can, can._msg, function(content) { var msg = can._msg
|
can.onsyntax._init(can, can._msg, function(content) { var msg = can._msg; can.onexport.hash(can)
|
||||||
can.onexport.hash(can), can.onmotion.select(can, can.ui.tabs, html.DIV_TABS, msg._tab), msg._tab.scrollIntoView()
|
can.isCmdMode() && can.onexport.title(can, path+file), can.onmotion.select(can, can.ui.tabs, html.DIV_TABS, msg._tab), can.isCmdMode() && msg._tab.scrollIntoView()
|
||||||
if (isCommand()) {
|
if (isIndex()) {
|
||||||
can.ui.path.innerHTML = can.Option(nfs.FILE)
|
can.ui.path.innerHTML = can.Option(nfs.FILE)
|
||||||
} else if (isDream()) {
|
} else if (isDream()) {
|
||||||
can.ui.path.innerHTML = can.page.Format(html.A, can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)}))
|
can.ui.path.innerHTML = can.page.Format(html.A, can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)}))
|
||||||
} else { can.ui.path.innerHTML = ""
|
} else { can.ui.path.innerHTML = ""
|
||||||
can.onimport._tabInputs(can, ice.PS, nfs.PATH, can.base.Path(can.Option(nfs.PATH), can.Option(nfs.FILE)), function(ls) {
|
can.onimport._tabPath(can, ice.PS, nfs.PATH, can.base.Path(can.Option(nfs.PATH), can.Option(nfs.FILE)), function(ls) {
|
||||||
if (ls[0] == ice.SRC) {
|
if (ls[0] == ice.USR && ls.length > 2) {
|
||||||
|
can.onimport.tabview(can, ls.slice(0, 2).join(ice.PS)+ice.PS, ls.slice(2).join(ice.PS))
|
||||||
|
} else if (ls.length > 1) {
|
||||||
can.onimport.tabview(can, ls.slice(0, 1).join(ice.PS)+ice.PS, ls.slice(1).join(ice.PS))
|
can.onimport.tabview(can, ls.slice(0, 1).join(ice.PS)+ice.PS, ls.slice(1).join(ice.PS))
|
||||||
} else {
|
} else {
|
||||||
can.onimport.tabview(can, ls.slice(0, 2).join(ice.PS)+ice.PS, ls.slice(2).join(ice.PS))
|
can.onimport.tabview(can, nfs.PWD, ls[0])
|
||||||
}
|
}
|
||||||
}, can.ui.path), can.onimport._tabFunc(can, can.ui.path)
|
}, can.ui.path), can.onimport._tabFunc(can, can.ui.path)
|
||||||
}
|
}
|
||||||
can.page.SelectChild(can, can.ui._content.parentNode, can.page.Keys(html.DIV_CONTENT, "fieldset.story", [[[html.IFRAME, html.CONTENT]]]), function(item) {
|
can.page.SelectChild(can, can.ui._content.parentNode, can.page.Keys(html.DIV_CONTENT, html.FIELDSET_STORY, [[[html.IFRAME, html.CONTENT]]]), function(target) {
|
||||||
if (can.onmotion.toggle(can, item, item == msg._content)) { can.ui.content = msg._content }
|
if (can.onmotion.toggle(can, target, target == msg._content)) { can.ui.content = msg._content }
|
||||||
}), can.ui.content._plugin = msg._plugin
|
}), can.ui.content._plugin = msg._plugin
|
||||||
can.page.SelectChild(can, can.ui._content.parentNode, can.page.Keys(html.DIV_PROFILE, [[[html.IFRAME, html.PROFILE]]]), function(item) {
|
can.page.SelectChild(can, can.ui._content.parentNode, can.page.Keys(html.DIV_PROFILE, [[[html.IFRAME, html.PROFILE]]]), function(target) {
|
||||||
if (can.onmotion.toggle(can, item, item == msg._profile)) { can.ui.profile = msg._profile }
|
if (can.onmotion.toggle(can, target, target == msg._profile)) { can.ui.profile = msg._profile }
|
||||||
}), can.ui.current && can.onmotion.toggle(can, can.ui.current, !isCommand() && !isDream())
|
}), can.onimport.layout(can), can.ui.current && can.onmotion.toggle(can, can.ui.current, !isIndex() && !isDream())
|
||||||
|
skip || can.onaction.selectLine(can, can.Option(nfs.LINE), true), can.base.isFunc(cb) && cb(), cb = null
|
||||||
var ls = can.db.file.split(ice.PS); if (ls.length > 4) { ls = [ls.slice(0, 2).join(ice.PS)+"/.../"+ls.slice(-2).join(ice.PS)] }
|
var ls = can.db.file.split(ice.PS); if (ls.length > 4) { ls = [ls.slice(0, 2).join(ice.PS)+"/.../"+ls.slice(-2).join(ice.PS)] }
|
||||||
can.Status(kit.Dict("文件", ls.join(ice.PS), "类型", can.db.parse)), can.onimport.layout(can)
|
can.Status(kit.Dict("文件", ls.join(ice.PS), "类型", can.db.parse))
|
||||||
if (!skip) { can.onaction.selectLine(can, can.Option(nfs.LINE), true) }
|
|
||||||
can.base.isFunc(cb) && cb(), cb = null
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
function load(msg) { var skip = false; can.db.tabview[key] = msg
|
function load(msg) { var skip = false; can.db.tabview[key] = msg
|
||||||
can.onimport.tabs(can, [{name: file.split(isCommand()? ice.PT: ice.PS).pop(), text: file, _menu: shy([nfs.SAVE, "compile"], function(event, button, meta) {
|
can.onimport.tabs(can, [{name: file.split(isIndex()? ice.PT: ice.PS).pop(), text: file, _menu: shy([nfs.SAVE, code.COMPILE], function(event, button, meta) {
|
||||||
can.onaction[button](event, can, button)
|
can.onaction[button](event, can, button)
|
||||||
})}], function(event, tabs) {
|
})}], function(event, tabs) {
|
||||||
can._tab = msg._tab = tabs._target, show(skip), skip = true
|
can._tab = msg._tab = tabs._target, show(skip), skip = true
|
||||||
}, function(tabs) { can.onengine.signal(can, "tabview.view.delete", msg)
|
}, function(tabs) { can.onengine.signal(can, "tabview.view.remove", msg)
|
||||||
msg._content != can.ui._content && can.page.Remove(can, msg._content), msg._profile != can.ui._profile && can.page.Remove(can, msg._profile)
|
msg._content != can.ui._content && can.page.Remove(can, msg._content), msg._profile != can.ui._profile && can.page.Remove(can, msg._profile)
|
||||||
delete(can.ui._content._cache[key]), delete(can.ui._profile._cache[key]), delete(can.ui.display._cache[key])
|
delete(can.ui._content._cache[key]), delete(can.ui._profile._cache[key]), delete(can.ui.display._cache[key])
|
||||||
delete(can._cache_data[key]), delete(can.db.tabview[key])
|
delete(can._cache_data[key]), delete(can.db.tabview[key])
|
||||||
}, can.ui.tabs)
|
}, can.ui.tabs)
|
||||||
}
|
}
|
||||||
if (can.db.tabview[key]) { return !can._msg._tab && !can.isSimpleMode()? load(can.db.tabview[key]): show() }
|
if (can.db.tabview[key]) { return !can._msg._tab && !can.isSimpleMode()? load(can.db.tabview[key]): show() }
|
||||||
isCommand()||isDream()? load(can.request({}, {index: file, line: line})): can.run({}, [path, file], load, true)
|
isIndex()||isDream()? load(can.request({}, {index: file, line: line})): can.run({}, [path, file], load, true)
|
||||||
},
|
},
|
||||||
history: function(can, record) { can.base.Eq(record, can.db.history[can.db.history.length-1]) || can.db.history.push(record)
|
history: function(can, record) { can.base.Eq(record, can.db.history[can.db.history.length-1]) || can.db.history.push(record)
|
||||||
return can.Status("跳转", can.db.history.length), record
|
return can.Status("跳转", can.db.history.length), record
|
||||||
@ -140,44 +139,43 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
if (can.base.isFunc(cb)) { return {name: name, _trans: can.onfigure._trans? can.onfigure._trans[name]||"": "", _init: function(target, zone) { return cb(can, target, zone, path) }} }
|
if (can.base.isFunc(cb)) { return {name: name, _trans: can.onfigure._trans? can.onfigure._trans[name]||"": "", _init: function(target, zone) { return cb(can, target, zone, path) }} }
|
||||||
}), can.ui.project), can.user.isMobile && !can.user.isLandscape() && can.onmotion.hidden(can, can.ui.project)
|
}), can.ui.project), can.user.isMobile && !can.user.isLandscape() && can.onmotion.hidden(can, can.ui.project)
|
||||||
},
|
},
|
||||||
profile: function(can, msg) { var sup = can.db.tabview[can.onexport.keys(can)]
|
profile: function(can, msg) { var _msg = can.db.tabview[can.onexport.keys(can)]
|
||||||
if (msg.Result().indexOf("<iframe ") > -1) { if (sup._profile != can.ui._profile) { can.page.Remove(can, sup._profile) }
|
if (msg.Result().indexOf("<iframe src=") > -1) { if (_msg._profile != can.ui._profile) { can.page.Remove(can, _msg._profile) }
|
||||||
var src = can.page.Select(can, can.page.Create(can, html.DIV, msg.Result()), html.IFRAME, function(target) { return target.src })[0]
|
var src = can.page.Select(can, can.page.Create(can, html.DIV, msg.Result()), html.IFRAME, function(target) { return target.src })[0]
|
||||||
can.ui.profile = sup._profile = can.page.Append(can, can.ui._profile.parentNode, [{view: [html.PROFILE, html.IFRAME], src: src}])._target
|
can.ui.profile = _msg._profile = can.page.Append(can, can.ui._profile.parentNode, [{view: [html.PROFILE, html.IFRAME], src: src}])._target
|
||||||
can.db.profile_size[can.onexport.keys(can)] = 0.8
|
can.onmotion.toggle(can, can.ui.profile, true), can.db.profile_size[can.onexport.keys(can)] = 0.8, can.onimport.layout(can)
|
||||||
can.onmotion.toggle(can, can.ui.profile, true), can.onimport.layout(can)
|
} else { can.ui.profile = _msg._profile = can.ui._profile
|
||||||
} else { can.ui.profile = sup._profile = can.ui._profile
|
var height = can.ui.profile.offsetHeight||can.ui.content.offsetHeight
|
||||||
can.onimport.process(can, msg, can.ui.profile, can.ui.profile.offsetHeight||can.ui.content.offsetHeight, can.db.profile_size[can.onexport.keys(can)]||(can.ConfWidth()-can.ui.project.offsetWidth)/2, function(sub) {
|
var width = can.onexport.size(can, can.db.profile_size[can.onexport.keys(can)]||0.5, can.ConfWidth()-can.ui.project.offsetWidth)
|
||||||
can.db.profile_size[can.onexport.keys(can)] = sub.ConfWidth()
|
can.onimport.process(can, msg, can.ui.profile, height, width, function(sub) { var _width = can.base.Max(sub._target.offsetWidth, width)
|
||||||
can.onimport.layout(can)
|
can.db.profile_size[can.onexport.keys(can)] = _width, can.onimport.layout(can), sub.onimport.size(sub, height, _width, true)
|
||||||
})
|
})
|
||||||
can.page.Select(can, can.ui.profile, html.TABLE, function(target) { can.onmotion.delay(can, function() {
|
can.page.Select(can, can.ui.profile, html.TABLE, function(target) { can.onmotion.delay(can, function() {
|
||||||
if (target.offsetWidth < can.ui._profile.offsetWidth) { can.db.profile_size[can.onexport.keys(can)] = target.offsetWidth, can.onimport.layout(can) }
|
if (target.offsetWidth < can.ui._profile.offsetWidth) { can.db.profile_size[can.onexport.keys(can)] = target.offsetWidth, can.onimport.layout(can) }
|
||||||
}) })
|
}) })
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
display: function(can, msg) { var target = can.ui.display
|
display: function(can, msg) { var width = can.ui.content.offsetWidth+can.ui.profile.offsetWidth||can.ConfWidth()-can.ui.project.offsetWidth
|
||||||
can.onimport.process(can, msg, target, can.db.display_size[can.onexport.keys(can)]||can.ConfHeight()/2, target.offsetWidth, function(sub) {
|
var height = can.onexport.size(can, can.db.display_size[can.onexport.keys(can)]||0.5, can.ui.content.offsetHeight||can.ConfHeight())
|
||||||
can.onmotion.delay(can, function() { can.page.style(can, sub._output, html.HEIGHT, "", html.MAX_HEIGHT, "")
|
can.onimport.process(can, msg, can.ui.display, height, width, function(sub) { var _height = can.base.Max(sub._target.offsetHeight, height)
|
||||||
can.db.display_size[can.onexport.keys(can)] = can.base.Max(sub._output.offsetHeight+html.ACTION_HEIGHT+sub.onexport.statusHeight(sub), can.ConfHeight()/2)
|
can.db.display_size[can.onexport.keys(can)] = _height, can.onimport.layout(can), sub.onimport.size(sub, _height, width, true)
|
||||||
can.page.style(can, sub._output, html.MAX_HEIGHT, can.db.display_size[can.onexport.keys(can)]-html.ACTION_HEIGHT-sub.onexport.statusHeight(sub))
|
|
||||||
can.onimport.layout(can)
|
|
||||||
}), sub.onaction.close = function() { can.onmotion.hidden(can, target), can.onimport.layout(can) }
|
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
process: function(can, msg, target, height, width, cb) { can.onmotion.clear(can, target)
|
process: function(can, msg, target, height, width, cb) { can.onmotion.clear(can, target)
|
||||||
if (msg.Option(ice.MSG_PROCESS) == "_field") {
|
if (msg.Option(ice.MSG_PROCESS) == ice.PROCESS_FIELD) {
|
||||||
msg.Table(function(item) { item.display = msg.Option(ice.MSG_DISPLAY), item.height = height-2*html.ACTION_HEIGHT, item.width = width
|
msg.Table(function(item) { item.type = chat.STORY, item.display = msg.Option(ice.MSG_DISPLAY), item.height = height-2*html.ACTION_HEIGHT, item.width = width
|
||||||
item.type = "story"
|
can.onimport.plug(can, item, function(sub) { height && sub.ConfHeight(item.height), width && sub.ConfWidth(item.width)
|
||||||
can.onimport.plug(can, item, function(sub) {
|
|
||||||
can.page.ClassList.del(can, sub._target, html.HIDE)
|
|
||||||
height && sub.ConfHeight(height-2*html.ACTION_HEIGHT), width && sub.ConfWidth(width)
|
|
||||||
sub.onexport.output = function(_sub, _msg) { can.base.isFunc(cb) && cb(_sub, _msg) }
|
|
||||||
sub.onaction.close = function() { can.onmotion.hidden(can, target), can.onimport.layout(can) }
|
sub.onaction.close = function() { can.onmotion.hidden(can, target), can.onimport.layout(can) }
|
||||||
|
sub.onexport.output = function(_sub, _msg) { can.base.isFunc(cb) && cb(_sub, _msg) }
|
||||||
|
sub.run = function(event, cmds, cb) { can.runActionCommand(can.request(event, can.Option()), item.index, cmds, function(msg) {
|
||||||
|
height && sub.ConfHeight(item.height), width && sub.ConfWidth(item.width)
|
||||||
|
can.page.style(can, sub._output, html.MAX_HEIGHT, "", html.MAX_WIDTH, "")
|
||||||
|
can.base.isFunc(cb) && cb(msg)
|
||||||
|
}) }
|
||||||
}, target)
|
}, target)
|
||||||
})
|
})
|
||||||
} else if (msg.Option(ice.MSG_DISPLAY) != "") {
|
} else if (msg.Option(ice.MSG_DISPLAY) != "") {
|
||||||
can.onappend._output(can, msg, msg.Option(ice.MSG_DISPLAY), target, false, function(msg) { can.onmotion.delay(can, function() { can.onimport.layout(can) }) })
|
can.onappend._output(can, msg, msg.Option(ice.MSG_DISPLAY), target, false, function(msg) { can.onimport.layout(can) })
|
||||||
} else if (msg.Length() > 0 || msg.Result() != "") {
|
} else if (msg.Length() > 0 || msg.Result() != "") {
|
||||||
can.onappend.table(can, msg, function(value, key, index, line, array) {
|
can.onappend.table(can, msg, function(value, key, index, line, array) {
|
||||||
return {text: [value, html.TD], onclick: function(event) { if (line.line || line.file) {
|
return {text: [value, html.TD], onclick: function(event) { if (line.line || line.file) {
|
||||||
@ -189,18 +187,12 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
} return can.onmotion.toggle(can, target, true), can.onimport.layout(can), can.user.toastSuccess(can)
|
} return can.onmotion.toggle(can, target, true), can.onimport.layout(can), can.user.toastSuccess(can)
|
||||||
},
|
},
|
||||||
toolkit: function(can, meta, cb) { can.page.isDisplay(can.ui.plug) || can.onmotion.toggle(can, can.ui.plug, true) && can.onimport.layout(can)
|
toolkit: function(can, meta, cb) { can.page.isDisplay(can.ui.plug) || can.onmotion.toggle(can, can.ui.plug, true) && can.onimport.layout(can)
|
||||||
can.onimport.plug(can, meta, function(sub) { can.onappend.style(sub, [html.FLOAT, html.HIDE])
|
can.onimport.plug(can, meta, function(sub) { can.onappend.style(sub, [html.FLOAT, html.HIDE]), sub._legend._target = sub._target
|
||||||
can.ui.plug.appendChild(sub._legend), sub._legend.onclick = function(event) { can.misc.Event(event, can, function(msg) {
|
can.ui.plug.appendChild(sub._legend), sub._legend.onclick = function(event) { can.misc.Event(event, can, function(msg) {
|
||||||
if (can.page.SelectOne(can, can.ui.plug, ice.PT+html.SELECT, function(target) {
|
if (can.page.SelectOne(can, can.ui.plug, ice.PT+html.SELECT, function(target) {
|
||||||
can.page.ClassList.del(can, target, html.SELECT); return target
|
can.onmotion.hidden(can, target._target), can.page.ClassList.del(can, target, html.SELECT); return target
|
||||||
}) == event.target) { can.page.ClassList.add(can, sub._target, html.HIDE) } else {
|
}) == sub._legend) { return } can.onmotion.toggle(can, sub._target, true), can.page.ClassList.add(can, sub._legend, html.SELECT)
|
||||||
can.page.ClassList.add(can, event.target, html.SELECT)
|
if (sub._delay_init == true) { sub._delay_init = false, sub.Update() }
|
||||||
can.page.SelectChild(can, can.ui.plug.parentNode, can.core.Keys(html.FIELDSET, chat.PLUG), function(target) {
|
|
||||||
if (!can.page.ClassList.set(can, target, html.HIDE, target != sub._target)) {
|
|
||||||
if (sub._delay_init == true) { sub._delay_init = false, can.onmotion.delay(can, function() { sub._output.innerHTML == "" && sub.Update() }) }
|
|
||||||
}
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}) }, sub._delay_init = true
|
}) }, sub._delay_init = true
|
||||||
sub.onexport.record = function(sub, value, key, line) { if (!line.file && !line.line) { return }
|
sub.onexport.record = function(sub, value, key, line) { if (!line.file && !line.line) { return }
|
||||||
can.onimport.tabview(can, line.path||can.Option(nfs.PATH), can.base.trimPrefix(line.file, nfs.PWD)||can.Option(nfs.FILE), parseInt(line.line))
|
can.onimport.tabview(can, line.path||can.Option(nfs.PATH), can.base.trimPrefix(line.file, nfs.PWD)||can.Option(nfs.FILE), parseInt(line.line))
|
||||||
@ -208,38 +200,48 @@ Volcanos(chat.ONIMPORT, {_init: function(can, msg, cb, target) { can.onmotion.cl
|
|||||||
sub.onimport.size(sub, can.ConfHeight()/2, can.ConfWidth()-can.ui.project.offsetWidth, true), can.base.isFunc(cb) && cb(sub)
|
sub.onimport.size(sub, can.ConfHeight()/2, can.ConfWidth()-can.ui.project.offsetWidth, true), can.base.isFunc(cb) && cb(sub)
|
||||||
}, can.ui.plug.parentNode)
|
}, can.ui.plug.parentNode)
|
||||||
},
|
},
|
||||||
layout: function(can) {
|
layout: function(can) { if (can.isSimpleMode()) { return can.page.style(can, can.ui.content, html.WIDTH, can.ConfWidth()) }
|
||||||
if (can.isSimpleMode()) { return can.page.style(can, can.ui.content, html.WIDTH, can.ConfWidth()) }
|
|
||||||
if (can.isCmdMode()) { can.page.styleHeight(can, can._output, can.ConfHeight(can.page.height())), can.ConfWidth(can.page.width()) }
|
if (can.isCmdMode()) { can.page.styleHeight(can, can._output, can.ConfHeight(can.page.height())), can.ConfWidth(can.page.width()) }
|
||||||
var width = can.ConfWidth()+(can.user.isWindows && !can.isCmdMode()? 20: 0)
|
|
||||||
var height = can.user.isMobile && can.isFloatMode()? can.page.height()-2*html.ACTION_HEIGHT: can.base.Min(can.ConfHeight(), 320)-1
|
|
||||||
can.user.isMobile && can.isCmdMode() && can.page.style(can, can._output, html.MAX_HEIGHT, height)
|
|
||||||
can.ui.size = {profile: can.db.profile_size[can.onexport.keys(can)]||0.5, display: can.db.display_size[can.onexport.keys(can)]||3*html.ACTION_HEIGHT}
|
can.ui.size = {profile: can.db.profile_size[can.onexport.keys(can)]||0.5, display: can.db.display_size[can.onexport.keys(can)]||3*html.ACTION_HEIGHT}
|
||||||
can.ui.layout(width, height, 10, function(content_height, content_width) { var sub = can.ui.content._plugin; if (!sub) { return }
|
can.ui.layout(can.ConfWidth(), can.ConfHeight(), 0, function(content_height, content_width) { var sub = can.ui.content._plugin; if (!sub) { return }
|
||||||
if (content_height == sub.ConfHeight()+2*html.ACTION_HEIGHT && content_width == sub.ConfWidth()) { return }
|
if (content_height == sub.ConfHeight()+2*html.ACTION_HEIGHT && content_width == sub.ConfWidth()) { return }
|
||||||
sub.onimport.size(sub, can.ui.content.offsetHeight-2*html.ACTION_HEIGHT, can.ui.content.offsetWidth, true)
|
sub.onimport.size(sub, can.ui.content.offsetHeight, can.ui.content.offsetWidth, true)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
exts: function(can, url, cb) { can.onimport.toolkit(can, {index: ice.CAN_PLUGIN, display: (url[0] == ice.PS || url.indexOf(ice.HTTP) == 0? "": can.base.Dir(can._path))+url}, function(sub) {
|
exts: function(can, url, cb) { var sub = can.db.toolkit[url.split("?")[0]]; if (sub) { return can.base.isFunc(cb)? cb(sub): sub.select() }
|
||||||
|
can.onimport.toolkit(can, {index: ice.CAN_PLUGIN, display: (url[0] == ice.PS || url.indexOf(ice.HTTP) == 0? "": can.base.Dir(can._path))+url}, function(sub) {
|
||||||
sub.run = function(event, cmds, cb) {
|
sub.run = function(event, cmds, cb) {
|
||||||
if (cmds.length > 0 && cmds[0] == ctx.ACTION) {
|
if (cmds.length > 0 && cmds[0] == ctx.ACTION) {
|
||||||
can.run(can.request(event, can.Option()), cmds, cb||function(msg) { can.onappend._output(sub, msg, sub.Conf(ctx.DISPLAY)) }, true)
|
can.run(can.request(event, can.Option()), cmds, cb||function(msg) { can.onappend._output(sub, msg, sub.Conf(ctx.DISPLAY)) }, true)
|
||||||
} else {
|
} else {
|
||||||
can.onappend._output(sub, can.request(event), sub.Conf(ctx.DISPLAY))
|
can.onappend._output(sub, can.request(event), sub.Conf(ctx.DISPLAY))
|
||||||
}
|
}
|
||||||
}, can.db.extentions[url.split("?")[0]] = sub, can.base.isFunc(cb)? cb(sub): sub.select()
|
}, can.db.toolkit[url.split("?")[0]] = sub, can.base.isFunc(cb)? cb(sub): sub.select()
|
||||||
}) },
|
})
|
||||||
|
},
|
||||||
}, [""])
|
}, [""])
|
||||||
Volcanos(chat.ONFIGURE, {
|
Volcanos(chat.ONFIGURE, {
|
||||||
source: function(can, target, zone, path) { var total = 0
|
source: function(can, target, zone, path) { var args = can.base.getValid(can.misc.SearchHash(can), [can.Option(nfs.PATH), can.Option(nfs.FILE)])
|
||||||
function show(target, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) {
|
function show(target, zone, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) {
|
||||||
can.onimport.tree(can, msg.Table(), nfs.PATH, ice.PS, function(event, item) { can.onimport.tabview(can, path, item.path) }, target)
|
can.onimport.tree(can, can.core.List(msg.Table(), function(item) {
|
||||||
can.Status("目录", zone._total(total += msg.Length()))
|
if (args[1] && args[1].indexOf(item.path) == 0) { item.expand = true } return item
|
||||||
|
}), nfs.PATH, ice.PS, function(event, item) {
|
||||||
|
can.onimport.tabview(can, path, item.path)
|
||||||
|
}, target), zone._total(msg.Length())
|
||||||
}, true) } if (path.length == 1) { return show(target, path[0]) }
|
}, true) } if (path.length == 1) { return show(target, path[0]) }
|
||||||
can.onimport.zone(can, can.core.List(path, function(path) { return {name: path, _init: function(target, zone) {
|
can.onimport.zone(can, can.core.List(path, function(path) {
|
||||||
can.onmotion.hidden(can, zone._action), can.onmotion.hidden(can, zone._target)
|
return path.indexOf("-story") == -1 && path.indexOf("-dict") == -1 && {name: path, _init: function(target, zone) {
|
||||||
}, _delay_show: function(target) { show(target, path) } }}), target), can.page.Remove(can, target.previousSibling)
|
path == args[0] && show(target, zone, path)
|
||||||
|
}, _delay_show: path == args[0]? undefined: function(target, zone) { show(target, zone, path) }}
|
||||||
|
}), target), can.page.Remove(can, zone._action)
|
||||||
},
|
},
|
||||||
|
module: function(can, target, zone) { zone._delay_show = function() {
|
||||||
|
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), zone._total(msg.Length())
|
||||||
|
})
|
||||||
|
} },
|
||||||
plugin: function(can, target, zone) { var total = 0
|
plugin: function(can, target, zone) { var total = 0
|
||||||
can.onimport.tree(can, can.core.Item(can.onengine.plugin.meta, function(key) { return total++, {index: key} }), ctx.INDEX, ice.PT, function(event, item) {
|
can.onimport.tree(can, can.core.Item(can.onengine.plugin.meta, function(key) { return total++, {index: key} }), ctx.INDEX, ice.PT, function(event, item) {
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys(ice.CAN, item.index), ctx.INDEX)
|
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys(ice.CAN, item.index), ctx.INDEX)
|
||||||
@ -248,47 +250,37 @@ Volcanos(chat.ONFIGURE, {
|
|||||||
})
|
})
|
||||||
Volcanos(chat.ONSYNTAX, {_init: function(can, msg, cb) {
|
Volcanos(chat.ONSYNTAX, {_init: function(can, msg, cb) {
|
||||||
if (can.onmotion.cache(can, function(cache_data) {
|
if (can.onmotion.cache(can, function(cache_data) {
|
||||||
can.db.file && (cache_data[can.db.file] = {max: can.db.max, current: can.current, profile_display: can.ui.profile.className, display_display: can.ui.display.className})
|
can.db.file && (cache_data[can.db.file] = {max: can.db.max, current: can.current, profile: can.ui.profile.className, display: can.ui.display.className})
|
||||||
can.db.file = can.onexport.keys(can, can.Option(nfs.PATH), can.Option(nfs.FILE)); var p = cache_data[can.db.file]; if (p) {
|
can.db.file = can.onexport.keys(can, can.Option(nfs.PATH), can.Option(nfs.FILE)); var p = cache_data[can.db.file]; if (p) {
|
||||||
can.db.max = p.max, can.current = p.current, can.ui.profile.className = p.profile_display, can.ui.display.className = p.display_display
|
can.db.max = p.max, can.current = p.current, can.ui.profile.className = p.profile, can.ui.display.className = p.display
|
||||||
} else { can.onmotion.hidden(can, can.ui.profile), can.onmotion.hidden(can, can.ui.display) }
|
} else { can.onmotion.hidden(can, can.ui.profile), can.onmotion.hidden(can, can.ui.display) }
|
||||||
can.db.parse = can.base.Ext(can.db.file), can.Status("模式", mdb.PLUGIN); return can.db.file
|
can.db.parse = can.base.Ext(can.db.file), can.Status("模式", mdb.PLUGIN); return can.db.file
|
||||||
}, can.ui._content, can.ui._profile, can.ui._display)) { return can.base.isFunc(cb) && cb(msg._content) }
|
}, can.ui._content, can.ui._profile, can.ui._display)) { return can.base.isFunc(cb) && cb(msg._content) }
|
||||||
if (msg.Option(ctx.INDEX)) { return can.onsyntax._index(can, msg, cb) }
|
if (msg.Option(ctx.INDEX)) { return can.onsyntax._index(can, msg, cb) }
|
||||||
function init(p) { msg._can = can
|
function init(p) { msg._can = can
|
||||||
var list = ((new Error()).stack||"").split(ice.NL)
|
can.db.max = 0, can.core.List(msg.Result().split(ice.NL), function(item) { can.onaction.appendLine(can, item) })
|
||||||
can.db.max = 0, can.core.List(can.db.ls = msg.Result().split(ice.NL), function(item) { can.onaction.appendLine(can, item) })
|
can.onengine.signal(can, "tabview.view.create", msg), can.base.isFunc(cb) && cb(msg._content = can.ui._content)
|
||||||
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(chat.PLUG) && (can.onsyntax[can.db.parse] = can.Conf(chat.PLUG))
|
} can.require(["inner/syntax.js"], function() { can.Conf(chat.PLUG) && (can.onsyntax[can.db.parse] = can.Conf(chat.PLUG))
|
||||||
var p = can.onsyntax[can.db.parse]; !p? can.runAction({}, mdb.PLUGIN, [can.db.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)], function(msg) {
|
var p = can.onsyntax[can.db.parse]; !p? can.runAction({}, mdb.PLUGIN, [can.db.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)], function(msg) {
|
||||||
init(p = can.onsyntax[can.db.parse] = can.base.Obj(msg.Result()||"{}"))
|
init(p = can.onsyntax[can.db.parse] = can.base.Obj(msg.Result()||"{}"))
|
||||||
}): init(p)
|
}): init(p)
|
||||||
})
|
})
|
||||||
},
|
},
|
||||||
_index: function(can, msg, cb) {
|
_index: function(can, msg, cb) { if (msg._content) { return can.base.isFunc(cb) && cb(msg._content) }
|
||||||
if (can.Option(nfs.LINE) == web.DREAM) { can.ui.zone.dream && can.onmotion.delay(can, function() { can.ui.dream.refresh() }, 5000)
|
if (can.Option(nfs.LINE) == web.DREAM) { can.ui.zone.dream && can.onmotion.delay(can, function() { can.ui.dream.refresh() }, 5000)
|
||||||
return can.base.isFunc(cb) && cb(msg._content = msg._content||can.page.insertBefore(can, [{view: [html.CONTENT, html.IFRAME],
|
return can.base.isFunc(cb) && cb(msg._content = can.page.insertBefore(can, [{view: [html.CONTENT, html.IFRAME],
|
||||||
src: can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)}), height: can.ui.content.offsetHeight, width: can.ui.content.offsetWidth}], can.ui._content))
|
src: can.misc.MergePodCmd(can, {pod: can.Option(nfs.FILE)}), height: can.ui.content.offsetHeight, width: can.ui.content.offsetWidth}], can.ui._content))
|
||||||
} var index = msg.Option(ctx.INDEX).split(ice.FS); var meta = {type: "story", name: index[0], index: index[0], args: index.slice(1)}
|
} var index = msg.Option(ctx.INDEX).split(ice.FS), meta = {type: chat.STORY, index: index[0], args: index.slice(1)}
|
||||||
if (msg._content) { return can.base.isFunc(cb) && cb(msg._content) }
|
|
||||||
return can.onimport.plug(can, meta, function(sub) {
|
return can.onimport.plug(can, meta, function(sub) {
|
||||||
can.page.ClassList.del(sub, sub._target, html.HIDE)
|
can.onimport.layout(can), sub.onimport.size(sub, can.ui.content.offsetHeight, can.ui.content.offsetWidth, true)
|
||||||
|
sub.onimport._open = function(sub, msg, arg) { var url = can.base.ParseURL(arg), ls = url.origin.split("/chat/pod/")
|
||||||
|
arg.indexOf(location.origin) == 0 && ls.length > 1? can.onimport.tabview(can, can.Option(nfs.PATH), ls[1].split(ice.PS)[0], web.DREAM): can.user.open(arg), sub.Update()
|
||||||
|
}
|
||||||
|
sub.onaction["打开链接"] = function() { can.onimport.tabview(can, can.Option(nfs.PATH), [meta.index].concat(sub.Input([], false)).join(ice.FS), ctx.INDEX) }
|
||||||
sub.onaction.close = function() { can.onaction.back(can), msg._tab._close() }
|
sub.onaction.close = function() { can.onaction.back(can), msg._tab._close() }
|
||||||
sub.onaction["打开链接"] = function() {
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), [meta.index].concat(sub.Input([], false)).join(ice.FS), ctx.INDEX)
|
|
||||||
}
|
|
||||||
sub.onexport.title = function(_, title) { can.page.Modify(can, msg._tab, title) }
|
sub.onexport.title = function(_, title) { can.page.Modify(can, msg._tab, title) }
|
||||||
sub.onexport.record = function(_, value, key, line) {
|
sub.onexport.record = function(_, value, key, line) { line.path && can.onimport.tabview(can, line.path, line.file, line.line); return true }
|
||||||
line.path && can.onimport.tabview(can, line.path, line.file, line.line)
|
msg._plugin = sub, can.base.isFunc(cb) && cb(msg._content = sub._target), sub.Focus()
|
||||||
return true
|
|
||||||
}
|
|
||||||
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(ice.PS)[0], web.DREAM), sub.Update()
|
|
||||||
} return can.user.open(_arg), sub.Update()
|
|
||||||
}, sub.onimport.size(sub, sub.ConfHeight(can.ui.content.offsetHeight-2*html.ACTION_HEIGHT), sub.ConfWidth(can.ui.content.offsetWidth), true)
|
|
||||||
can.onimport.layout(can)
|
|
||||||
msg._plugin = sub, can.base.isFunc(cb) && cb(msg._content = sub._target), can.onmotion.delay(can, function() { sub.Focus() })
|
|
||||||
}, can.ui._content.parentNode)
|
}, can.ui._content.parentNode)
|
||||||
},
|
},
|
||||||
_parse: function(can, line) { line = can.page.replace(can, line||"")
|
_parse: function(can, line) { line = can.page.replace(can, line||"")
|
||||||
@ -307,72 +299,58 @@ Volcanos(chat.ONSYNTAX, {_init: function(can, msg, cb) {
|
|||||||
case code.FUNCTION:
|
case code.FUNCTION:
|
||||||
case code.CONSTANT:
|
case code.CONSTANT:
|
||||||
case code.OBJECT: return wrap(text, type)
|
case code.OBJECT: return wrap(text, type)
|
||||||
default:
|
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} })
|
||||||
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} })
|
|
||||||
return t && t.length > 0? wrap(text, t[0]): type? wrap(text, type): text
|
return t && t.length > 0? wrap(text, t[0]): type? wrap(text, type): text
|
||||||
}
|
}
|
||||||
}).join(""))
|
}).join("")); return line
|
||||||
return line
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONACTION, {
|
Volcanos(chat.ONACTION, {list: ["首页", "官网", "调试", "百度"],
|
||||||
_getLine: function(can, line) { return can.page.Select(can, can.ui.content, "tr.line>td.line", function(td, index) { if (td.parentNode == line || index+1 == line) { return td.parentNode } })[0] },
|
_getLine: function(can, line) { return can.page.Select(can, can.ui.content, "tr.line>td.line", function(td, index) { if (td.parentNode == line || index+1 == line) { return td.parentNode } })[0] },
|
||||||
_getLineno: function(can, line) { return can.page.Select(can, can.ui.content, "tr.line>td.line", function(td, index) { if (td.parentNode == line || index+1 == line) { return index+1 } })[0] },
|
_getLineno: function(can, line) { return can.page.Select(can, can.ui.content, "tr.line>td.line", function(td, index) { if (td.parentNode == line || index+1 == line) { return index+1 } })[0] },
|
||||||
appendLine: function(can, value) {
|
appendLine: function(can, value) { var ui = can.page.Append(can, can.ui._content, [{view: [nfs.LINE, html.TR], list: [
|
||||||
var ui = can.page.Append(can, can.ui._content, [{type: html.TR, className: "line", list: [
|
|
||||||
{view: [nfs.LINE, html.TD, ++can.db.max], onclick: function(event) {
|
{view: [nfs.LINE, html.TD, ++can.db.max], onclick: function(event) {
|
||||||
can.onaction.selectLine(can, ui.tr)
|
can.onaction.selectLine(can, ui.tr)
|
||||||
}, ondblclick: function(event) {
|
}, ondblclick: function(event) {
|
||||||
can.onaction.find(event, can)
|
can.onaction.find(event, can)
|
||||||
}},
|
}},
|
||||||
{view: [html.TEXT, html.TD, can.onsyntax._parse(can, value)], onclick: function(event) {
|
{view: [mdb.TEXT, html.TD, can.onsyntax._parse(can, value)], onclick: function(event) {
|
||||||
if (event.metaKey) {
|
|
||||||
if (ui.text.innerText.indexOf(ice.HTTP) > -1) {
|
|
||||||
var ls = (/(http[^ ]+)/).exec(ui.text.innerText)
|
|
||||||
if (ls && ls[1]) {
|
|
||||||
can.user.open(ls[1])
|
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
can.onaction.selectLine(can, ui.tr)
|
can.onaction.selectLine(can, ui.tr)
|
||||||
|
if (event.metaKey) { if (ui.text.innerText.indexOf(ice.HTTP) > -1) { var ls = (/(http[^ ]+)/).exec(ui.text.innerText); if (ls && ls[1]) { can.user.open(ls[1]) } } }
|
||||||
}, ondblclick: function(event) {
|
}, ondblclick: function(event) {
|
||||||
can.onaction.searchLine(event, can, can.onexport.selection(can, ui.text.innerText))
|
can.onaction.searchLine(event, can, can.onexport.selection(can, ui.text.innerText))
|
||||||
}}
|
}}
|
||||||
]}]); return ui.tr
|
]}]); return ui._target },
|
||||||
},
|
|
||||||
selectLine: function(can, line, scroll) { if (!line) { return can.onexport.line(can, can.page.SelectOne(can, can.ui._content, "tr.select")) }
|
selectLine: function(can, line, scroll) { if (!line) { return can.onexport.line(can, can.page.SelectOne(can, can.ui._content, "tr.select")) }
|
||||||
can.page.Select(can, can.ui._content, "tr.line>td.line", function(td, index) { var tr = td.parentNode, n = parseInt(td.innerText)
|
can.page.Select(can, can.ui._content, "tr.line>td.line", function(td, index) { var tr = td.parentNode, n = parseInt(td.innerText)
|
||||||
if (!can.page.ClassList.set(can, tr, html.SELECT, tr == line || n == line)) { return }
|
if (!can.page.ClassList.set(can, tr, html.SELECT, tr == line || n == line)) { return }
|
||||||
line = tr, can.Status("行号", can.onexport.position(can, can.Option(nfs.LINE, n)))
|
line = tr, can.Status("行号", can.onexport.position(can, can.Option(nfs.LINE, n)))
|
||||||
}); if (!can.base.isObject(line)) { return 0 }
|
}); if (!can.base.isObject(line)) { return 0 }
|
||||||
can.page.Select(can, line, "td.text", function(item) {
|
can.page.Select(can, line, "td.text", function(item) {
|
||||||
can.current = {
|
can.current = {line: line, next: function() { return line.nextSibling }, prev: function() { return line.previousSibling },
|
||||||
window: function() { return parseInt(can.ui._content.offsetHeight/can.current.line.offsetHeight) },
|
text: function(text) { return text != undefined && can.onaction.modifyLine(can, line, text), item.innerText },
|
||||||
scroll: function(count) { if (count) { can.ui._content.scrollTop += count*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)
|
return parseInt((can.current.line.offsetTop-can.ui._content.scrollTop)/can.current.line.offsetHeight)
|
||||||
}, prev: function() { return line.previousSibling }, next: function() { return line.nextSibling },
|
}, window: function() { return parseInt(can.ui._content.offsetHeight/can.current.line.offsetHeight) },
|
||||||
line: line, text: function(text) { return text != undefined && can.onaction.modifyLine(can, line, text), item.innerText },
|
|
||||||
}, can.onimport.history(can, {path: can.Option(nfs.PATH), file: can.Option(nfs.FILE), line: can.Option(nfs.LINE)})
|
}, can.onimport.history(can, {path: can.Option(nfs.PATH), file: can.Option(nfs.FILE), line: can.Option(nfs.LINE)})
|
||||||
can.onexport.hash(can), scroll && can.onaction.scrollIntoView(can), can.onengine.signal(can, "tabview.line.select", can._msg)
|
can.onexport.hash(can), scroll && can.onaction.scrollIntoView(can), can.onengine.signal(can, "tabview.line.select", can._msg)
|
||||||
})
|
})
|
||||||
can.misc.localStorage(can, "web.code.inner:currentFile", can.Option(nfs.PATH)+ice.DF+can.Option(nfs.FILE)+ice.DF+can.onaction._getLineno(can, can.current.line))
|
can.misc.localStorage(can, "web.code.inner:currentFile", [can.Option(nfs.PATH), can.Option(nfs.FILE), can.onaction._getLineno(can, can.current.line)].join(ice.DF))
|
||||||
can.misc.localStorage(can, "web.code.inner:selectLine:"+can.Option(nfs.PATH)+can.Option(nfs.FILE), can.onaction._getLineno(can, can.current.line))
|
can.misc.localStorage(can, "web.code.inner:selectLine:"+can.Option(nfs.PATH)+can.Option(nfs.FILE), can.onaction._getLineno(can, can.current.line))
|
||||||
return can.onexport.line(can, line)
|
return can.onexport.line(can, line)
|
||||||
},
|
},
|
||||||
searchLine: function(event, can, value) {
|
scrollIntoView: function(can, offset) { var current = can.onaction._getLineno(can, can.current.line), window = can.current.window(); offset = offset||parseInt(window/4)+2
|
||||||
can.runAction(can.request(event, {name: value, text: can.current.text()}, can.Option()), code.NAVIGATE, [], function(msg) {
|
can.ui.content.scrollTo(0, parseInt(current/window)*can.ui.content.offsetHeight+(parseInt(current%window)-offset-1)*can.current.line.offsetHeight)
|
||||||
msg.Append(nfs.FILE)? can.onimport.tabview(can, msg.Append(nfs.PATH), msg.Append(nfs.FILE), msg.Append(nfs.LINE)): can.user.toastFailure(can, "not found "+value)
|
|
||||||
})
|
|
||||||
},
|
},
|
||||||
favorLine: function(event, can, value) {
|
searchLine: function(event, can, value) { can.runAction(can.request(event, {name: value, text: can.current.text()}, can.Option()), code.NAVIGATE, [], function(msg) {
|
||||||
can.user.input(event, can, [{name: mdb.ZONE, value: "hi"}, {name: mdb.NAME, value: "hello"}], function(data) {
|
msg.Append(nfs.FILE)? can.onimport.tabview(can, msg.Append(nfs.PATH), msg.Append(nfs.FILE), msg.Append(nfs.LINE)): can.user.toastFailure(can, "not found "+value)
|
||||||
|
}) },
|
||||||
|
favorLine: function(event, can, value) { can.user.input(event, can, [{name: mdb.ZONE, value: "hi"}, {name: mdb.NAME, value: "hello"}], function(data) {
|
||||||
can.runAction(event, code.FAVOR, [ctx.ACTION, mdb.INSERT, mdb.ZONE, data.zone||"",
|
can.runAction(event, code.FAVOR, [ctx.ACTION, mdb.INSERT, mdb.ZONE, data.zone||"",
|
||||||
mdb.TYPE, can.db.parse, mdb.NAME, data.name||"", mdb.TEXT, (value||"").trimRight(),
|
mdb.TYPE, can.db.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),
|
nfs.PATH, can.Option(nfs.PATH), nfs.FILE, can.Option(nfs.FILE), nfs.LINE, can.Option(nfs.LINE),
|
||||||
], function() { can.user.toastSuccess(can) })
|
], function() { can.user.toastSuccess(can) })
|
||||||
})
|
}) },
|
||||||
},
|
|
||||||
listTags: function(event, can, button) { var list = []
|
listTags: function(event, can, button) { var list = []
|
||||||
can.core.Item(can.request(event), function(key, value) { if (key.indexOf("_") == 0) { return }
|
can.core.Item(can.request(event), function(key, value) { if (key.indexOf("_") == 0) { return }
|
||||||
list.push({zone: ice.MSG, type: typeof value, name: key, text: can.base.isObject(value)? "": (value+"").split(ice.NL)[0], path: ice.USR_VOLCANOS, file: ice.LIB_MISC, line: 1})
|
list.push({zone: ice.MSG, type: typeof value, name: key, text: can.base.isObject(value)? "": (value+"").split(ice.NL)[0], path: ice.USR_VOLCANOS, file: ice.LIB_MISC, line: 1})
|
||||||
@ -383,21 +361,14 @@ Volcanos(chat.ONACTION, {
|
|||||||
})
|
})
|
||||||
}), can.runAction(can.request(event, {text: can.base.Format(list)}), button)
|
}), can.runAction(can.request(event, {text: can.base.Format(list)}), button)
|
||||||
},
|
},
|
||||||
scrollIntoView: function(can, offset) { var window = can.current.window(); offset = offset||parseInt(window/4)+2
|
|
||||||
var current = can.onaction._getLineno(can, can.current.line)
|
|
||||||
// var to = current/window*can.ui.content.offsetHeight+(offset-current%window)*can.current.line.offsetHeight
|
|
||||||
var to = parseInt(current/window)*can.ui.content.offsetHeight+(parseInt(current%window)-offset-1)*can.current.line.offsetHeight
|
|
||||||
can.ui.content.scrollTo(0, to)
|
|
||||||
},
|
|
||||||
back: function(can) { can.db.history.pop(); var last = can.db.history.pop(); last && can.onimport.tabview(can, last.path, last.file, last.line) },
|
|
||||||
clear: function(event, can) {
|
clear: function(event, can) {
|
||||||
if (can.page.Select(can, can._root._target, "div.vimer.find.float", function(item) { return can.page.Remove(can, item) }).length > 0) { return }
|
if (can.page.Select(can, can._root._target, "div.vimer.find.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._root._target, ".input.float", function(item) { return can.page.Remove(can, item) }).length > 0) { return }
|
||||||
if (can.page.Select(can, can.ui.plug, "legend.select", function(item) { return item.click(), item }).length > 0) { return }
|
if (can.page.Select(can, can.ui.plug, "legend.select", function(item) { return item.click(), item }).length > 0) { return }
|
||||||
if (can.page.isDisplay(can.ui.display)) { return can.onmotion.hidden(can, can.ui.display), can.onimport.layout(can) }
|
if (can.page.isDisplay(can.ui.display)) { return can.onmotion.hidden(can, can.ui.display), can.onimport.layout(can) }
|
||||||
if (can.page.isDisplay(can.ui.profile)) { return can.onmotion.hidden(can, can.ui.profile), can.onimport.layout(can) }
|
if (can.page.isDisplay(can.ui.profile)) { return can.onmotion.hidden(can, can.ui.profile), can.onimport.layout(can) }
|
||||||
// can.onmotion.toggle(can, can.ui.project), can.onimport.layout(can)
|
|
||||||
},
|
},
|
||||||
|
back: function(can) { can.db.history.pop(); var last = can.db.history.pop(); last && can.onimport.tabview(can, last.path, last.file, last.line) },
|
||||||
exec: function(event, can) {
|
exec: function(event, can) {
|
||||||
if (can.base.Ext(can.Option(nfs.FILE)) == nfs.JS) { delete(Volcanos.meta.cache[can.base.Path(ice.PS, ice.REQUIRE, can.Option(nfs.PATH), can.Option(nfs.FILE))]) }
|
if (can.base.Ext(can.Option(nfs.FILE)) == nfs.JS) { delete(Volcanos.meta.cache[can.base.Path(ice.PS, ice.REQUIRE, can.Option(nfs.PATH), can.Option(nfs.FILE))]) }
|
||||||
can.runAction(can.request(event, {_toast: "执行中..."}), mdb.ENGINE, [can.db.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)], function(msg) { can.onimport.display(can, msg) })
|
can.runAction(can.request(event, {_toast: "执行中..."}), mdb.ENGINE, [can.db.parse, can.Option(nfs.FILE), can.Option(nfs.PATH)], function(msg) { can.onimport.display(can, msg) })
|
||||||
@ -414,37 +385,36 @@ Volcanos(chat.ONACTION, {
|
|||||||
var input = can.user.input(event, can, [{type: html.TEXT, name: ctx.INDEX, run: function(event, cmds, cb) { can.run(event, cmds, function(msg) {
|
var input = can.user.input(event, can, [{type: html.TEXT, name: ctx.INDEX, run: function(event, cmds, cb) { can.run(event, cmds, function(msg) {
|
||||||
if (cmds[0] == ctx.ACTION && cmds[1] == mdb.INPUTS && cmds[2] == ctx.INDEX) { var _msg = can.request({})
|
if (cmds[0] == ctx.ACTION && cmds[1] == mdb.INPUTS && cmds[2] == ctx.INDEX) { var _msg = can.request({})
|
||||||
can.core.Item(can.db.toolkit, function(index) { _msg.Push(ctx.INDEX, index).Push("cb", show) }), _msg.Push(ctx.INDEX, "").Push("cb", show)
|
can.core.Item(can.db.toolkit, function(index) { _msg.Push(ctx.INDEX, index).Push("cb", show) }), _msg.Push(ctx.INDEX, "").Push("cb", show)
|
||||||
can.core.List(msg.index, function() { msg.Push("cb", show) })
|
can.core.List(msg.index, function() { msg.Push("cb", show) }), _msg.Copy(msg), cb(_msg)
|
||||||
_msg.Copy(msg), cb(_msg)
|
|
||||||
} else { cb(msg) }
|
} else { cb(msg) }
|
||||||
}, true) }}], function(list) { show(list[0]) })
|
}, true) }}], function(list) { show(list[0]) })
|
||||||
},
|
},
|
||||||
open: function(event, can) {
|
open: function(event, can) {
|
||||||
var paths = can.core.List(can.db.paths, function(item) { if (can.base.endWith(item, "-story/", "-dict/")) { return } return item }).join(ice.FS)
|
var paths = can.core.List(can.db.paths, function(item) { if (can.base.endWith(item, "-story/", "-dict/")) { return } return item }).join(ice.FS)
|
||||||
can.page.style(can, can.user.input(can.request(event, {paths: paths}), can, [{name: nfs.FILE, style: {width: can.ui.content.offsetWidth/2}, run: function(event, cmds, cb) {
|
paths = "src/,usr/icebergs/,usr/volcanos/"
|
||||||
|
var input = can.user.input(can.request(event, {paths: paths}), can, [{name: nfs.FILE, style: {width: can.ui.content.offsetWidth/2}, run: function(event, cmds, cb) {
|
||||||
can.run(can.request(event, {paths: paths}), cmds, function(msg) {
|
can.run(can.request(event, {paths: paths}), cmds, function(msg) {
|
||||||
if (cmds[0] == ctx.ACTION && cmds[1] == mdb.INPUTS) { var _msg = can.request({}), func = can.onexport.func(can)
|
if (cmds[0] == ctx.ACTION && cmds[1] == mdb.INPUTS) { var _msg = can.onengine.signal(can, "tabview.open.inputs"), func = can.onexport.func(can)
|
||||||
can.core.Item(can.db.tabview, function(key) { var ls = can.core.Split(key, ice.DF); _msg.Push(nfs.PATH, ls[0]+ls[1]) })
|
can.core.Item(can.db.tabview, function(key) { var ls = can.core.Split(key, ice.DF); _msg.Push(nfs.PATH, ls[0]+ls[1]) })
|
||||||
can.core.List(func.list, function(item) { var ls = can.core.Split(item, ice.DF, ice.DF); _msg.Push(nfs.PATH, "line:"+ls[1]+":"+ls[0]) })
|
can.core.List(func.list, function(item) { var ls = can.core.Split(item, ice.DF, ice.DF); _msg.Push(nfs.PATH, "line:"+ls[1]+ice.DF+ls[0]) })
|
||||||
can.core.Item(can.onengine.plugin.meta, function(key, value) { _msg.Push(nfs.PATH, "index:can."+key) })
|
can.core.Item(can.onengine.plugin.meta, function(key, value) { _msg.Push(nfs.PATH, "index:can."+key) })
|
||||||
_msg.Copy(msg), cb(_msg)
|
_msg.Copy(msg), cb(_msg)
|
||||||
} else { cb(msg) }
|
} else { cb(msg) }
|
||||||
}, true)
|
}, true)
|
||||||
}}], function(list, input) { input.cancel()
|
}}], function(list, input) { input.cancel(); var ls = can.core.Split(list[0], ice.DF, ice.DF); switch (ls[0]) {
|
||||||
var ls = can.core.Split(list[0], ice.DF, ice.DF); switch (ls[0]) {
|
|
||||||
case "_open": return can.runAction(event, ls[0], ls[1])
|
case "_open": return can.runAction(event, ls[0], ls[1])
|
||||||
case ctx.INDEX:
|
case ctx.INDEX:
|
||||||
case web.DREAM: return can.onimport.tabview(can, can.Option(nfs.PATH), ls[1], ls[0])
|
case web.DREAM: return can.onimport.tabview(can, can.Option(nfs.PATH), ls[1], ls[0])
|
||||||
case nfs.LINE: return can.onaction.selectLine(can, parseInt(ls[1]), true)
|
case nfs.LINE: return can.onaction.selectLine(can, parseInt(ls[1]), true)
|
||||||
default: can.core.List(can.db.paths, function(path) { if (list[0].indexOf(path) == 0) { can.onimport.tabview(can, path, list[0].slice(path.length)) } })
|
default: can.core.List(can.db.paths, function(path) { if (list[0].indexOf(path) == 0) { can.onimport.tabview(can, path, list[0].slice(path.length)) } })
|
||||||
}
|
} })._target
|
||||||
})._target, html.LEFT, can.ui.project.offsetWidth+can.ui.content.offsetWidth/4-34, html.TOP, can.ui.content.offsetHeight/4, html.RIGHT, "")
|
can.page.Modify(can, input, {"className": "input vimer open float"})
|
||||||
|
can.page.style(can, input, html.LEFT, can.ui.project.offsetWidth+can.ui.content.offsetWidth/4-34, html.TOP, can.ui.content.offsetHeight/4, html.RIGHT, "")
|
||||||
},
|
},
|
||||||
find: function(event, can) {
|
find: function(event, can) {
|
||||||
var ui = can.page.Append(can, can._output, [{view: "vimer find float", list: [html.ACTION, html.OUTPUT],
|
var ui = can.page.Append(can, can._output, [{view: "vimer find float", list: [html.ACTION, html.OUTPUT],
|
||||||
style: {left: can.ui.project.offsetWidth+can.ui.content.offsetWidth/4, top: can.ui.content.offsetHeight/2+4*can.current.line.offsetHeight}}])
|
style: {left: can.ui.project.offsetWidth+can.ui.content.offsetWidth/4, top: can.ui.content.offsetHeight/2}}]); can.onmotion.move(can, ui._target)
|
||||||
can.onmotion.delay(can, function() { can.page.style(can, ui._target, html.LEFT, can.ui.project.offsetWidth+can.ui.content.offsetWidth/2-ui._target.offsetWidth/2) })
|
can.onmotion.delay(can, function() { can.page.style(can, ui._target, html.LEFT, can.ui.project.offsetWidth+can.ui.content.offsetWidth/2-ui._target.offsetWidth/2) })
|
||||||
can.onmotion.move(can, ui._target)
|
|
||||||
var last = can.onaction._getLineno(can, can.current.line)
|
var last = can.onaction._getLineno(can, can.current.line)
|
||||||
function find(begin, text) { if (parseInt(text) > 0) { return can.onaction.selectLine(can, parseInt(text)) && meta.close() }
|
function find(begin, text) { if (parseInt(text) > 0) { return can.onaction.selectLine(can, parseInt(text)) && meta.close() }
|
||||||
for (begin; begin <= can.db.max; begin++) { if (can.onexport.text(can, can.onaction._getLine(can, begin)).indexOf(text) > -1) {
|
for (begin; begin <= can.db.max; begin++) { if (can.onexport.text(can, can.onaction._getLine(can, begin)).indexOf(text) > -1) {
|
||||||
@ -455,12 +425,10 @@ Volcanos(chat.ONACTION, {
|
|||||||
can.onappend.figure(can, {action: "key", mode: chat.SIMPLE, _enter: function(event) {
|
can.onappend.figure(can, {action: "key", mode: chat.SIMPLE, _enter: function(event) {
|
||||||
if (event.ctrlKey) { meta.grep() } else { meta[button](), can.onmotion.delay(can, function() { target.focus() }) } return true
|
if (event.ctrlKey) { meta.grep() } else { meta[button](), can.onmotion.delay(can, function() { target.focus() }) } return true
|
||||||
}, run: function(event, cmds, cb) { var msg = can.request(event); can.core.List(can.core.Split(can.current.text(), "\t {([,:;=<>])}", {detail: true}), function(value) {
|
}, run: function(event, cmds, cb) { var msg = can.request(event); can.core.List(can.core.Split(can.current.text(), "\t {([,:;=<>])}", {detail: true}), function(value) {
|
||||||
if (can.base.isObject(value)) {
|
if (can.base.isObject(value)) { if (value.type == lang.SPACE) { return }
|
||||||
if (value.type == lang.SPACE) { return }
|
|
||||||
value.type == lang.STRING && msg.Push(mdb.VALUE, value.left+value.text+value.right), msg.Push(mdb.VALUE, value.text)
|
value.type == lang.STRING && msg.Push(mdb.VALUE, value.left+value.text+value.right), msg.Push(mdb.VALUE, value.text)
|
||||||
} else {
|
} else {
|
||||||
if (value.indexOf(ice.PT) > -1) { msg.Push(mdb.VALUE, value.split(ice.PT).pop()) }
|
value.indexOf(ice.PT) > -1 && msg.Push(mdb.VALUE, value.split(ice.PT).pop()), msg.Push(mdb.VALUE, value)
|
||||||
msg.Push(mdb.VALUE, value)
|
|
||||||
}
|
}
|
||||||
}), cb(msg) }}, target)
|
}), cb(msg) }}, target)
|
||||||
}
|
}
|
||||||
@ -470,7 +438,10 @@ Volcanos(chat.ONACTION, {
|
|||||||
{type: html.BUTTON, name: nfs.REPLACE}, {type: html.BUTTON, name: cli.CLOSE},
|
{type: html.BUTTON, name: nfs.REPLACE}, {type: html.BUTTON, name: cli.CLOSE},
|
||||||
], ui.action, {_trans: {find: "查找", grep: "搜索", replace: "替换"},
|
], ui.action, {_trans: {find: "查找", grep: "搜索", replace: "替换"},
|
||||||
find: function() { find(last+1, from.value) },
|
find: function() { find(last+1, from.value) },
|
||||||
grep: function() { can.onimport.exts(can, "inner/search.js", function(sub) { sub.select(), meta.close(), can.onmotion.delay(can, function() { sub.runAction(event, nfs.GREP, [from.value, can.Option(nfs.PATH)]) }) }) },
|
grep: function() { can.onimport.exts(can, "inner/search.js", function(sub) {
|
||||||
|
can.page.isDisplay(sub._target) || (sub._delay_init = false, sub.select()), meta.close()
|
||||||
|
sub.runAction(can.request(event, {value: from.value}), nfs.GREP, [from.value, can.Option(nfs.PATH)])
|
||||||
|
}) },
|
||||||
replace: function() { var text = can.current.text(), line = can.onaction._getLineno(can, can.current.line)
|
replace: function() { var text = can.current.text(), line = can.onaction._getLineno(can, can.current.line)
|
||||||
can.db.undo.push(function() { can.onaction.selectLine(can, line), can.onaction.modifyLine(can, line, text) })
|
can.db.undo.push(function() { can.onaction.selectLine(can, line), can.onaction.modifyLine(can, line, text) })
|
||||||
can.current.text(text.replace(from.value, to.value)), can.current.text().indexOf(from.value) == -1 && meta.find()
|
can.current.text(text.replace(from.value, to.value)), can.current.text().indexOf(from.value) == -1 && meta.find()
|
||||||
@ -479,17 +450,17 @@ Volcanos(chat.ONACTION, {
|
|||||||
},
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONEXPORT, {list: ["目录", "类型", "文件", "行号", "跳转"],
|
Volcanos(chat.ONEXPORT, {list: ["目录", "类型", "文件", "行号", "跳转"],
|
||||||
hash: function(can) { if (!can.isCmdMode()) { return }
|
size: function(can, size, full) {
|
||||||
location.hash = [can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE)].join(ice.DF)
|
if (size > 1) { return size }
|
||||||
|
if (size > 0) { return size*full }
|
||||||
},
|
},
|
||||||
keys: function(can, path, file) { return [path||can.Option(nfs.PATH), file||can.Option(nfs.FILE)].join(ice.DF) },
|
keys: function(can, path, file) { return [path||can.Option(nfs.PATH), file||can.Option(nfs.FILE)].join(ice.DF) },
|
||||||
line: function(can, line) { return parseInt(can.core.Value(can.page.SelectOne(can, line, "td.line"), "innerText")) },
|
line: function(can, line) { return parseInt(can.core.Value(can.page.SelectOne(can, line, "td.line"), "innerText")) },
|
||||||
position: function(can, index, total) { total = total||can.db.max; return (parseInt(index))+ice.PS+parseInt(total)+" = "+parseInt((index)*100/total)+"%" },
|
position: function(can, index, total) { total = total||can.db.max; return (parseInt(index))+ice.PS+parseInt(total)+" = "+parseInt((index)*100/total)+"%" },
|
||||||
selection: function(can, str) {
|
selection: function(can, str) { var s = document.getSelection().toString(), begin = str.indexOf(s), end = begin+s.length
|
||||||
var s = document.getSelection().toString(), 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 } } return s
|
||||||
for (var i = begin; i >= 0; i--) { if (str[i].match(/[a-zA-Z0-9_.]/)) { s = str.slice(i, end) } else { break } }
|
|
||||||
return s
|
|
||||||
},
|
},
|
||||||
|
hash: function(can) { if (!can.isCmdMode()) { return } location.hash = [can.Option(nfs.PATH), can.Option(nfs.FILE), can.Option(nfs.LINE)].join(ice.DF) },
|
||||||
func: function(can) { var list = []
|
func: function(can) { var list = []
|
||||||
function indent(text) { var indent = 0; for (var i = 0; i < text.length; i++) { switch (text[i]) {
|
function indent(text) { var indent = 0; for (var i = 0; i < text.length; i++) { switch (text[i]) {
|
||||||
case ice.TB: indent+=4; break
|
case ice.TB: indent+=4; break
|
||||||
@ -499,16 +470,15 @@ Volcanos(chat.ONEXPORT, {list: ["目录", "类型", "文件", "行号", "跳转"
|
|||||||
var package = "", block = "", current = "", percent = ""
|
var package = "", block = "", current = "", percent = ""
|
||||||
can.page.Select(can, can.ui.content, "tr.line>td.text", function(item, index) { var text = item.innerText, _indent = indent(text)
|
can.page.Select(can, can.ui.content, "tr.line>td.text", function(item, index) { var text = item.innerText, _indent = indent(text)
|
||||||
function push(item) { list.push(item); if (index < can.Option(nfs.LINE)) { current = list[list.length-1], percent = " = "+parseInt((index+1)*100/(can.db.max||1))+"%" } }
|
function push(item) { list.push(item); if (index < can.Option(nfs.LINE)) { current = list[list.length-1], percent = " = "+parseInt((index+1)*100/(can.db.max||1))+"%" } }
|
||||||
if (can.db.parse == nfs.JS) {
|
if (can.db.parse == nfs.JS) { var ls = can.core.Split(text, "\t ({:}),")
|
||||||
if (_indent == 0 && can.base.beginWith(text, "Volcanos")) {
|
if (_indent == 0 && can.base.beginWith(text, "Volcanos")) {
|
||||||
var ls = can.core.Split(text, "\t ({:}),"), _block = can.base.trimPrefix(ls[1], "chat.").toLowerCase()
|
var _block = can.base.trimPrefix(ls[1], "chat.").toLowerCase()
|
||||||
if (_block != block) { push("") } block = _block
|
if (_block != block) { push("") } block = _block
|
||||||
if (text.indexOf("_init") > -1) { push(block+ice.PT+"_init"+ice.DF+(index+1)) }
|
if (text.indexOf("_init") > -1) { push(block+ice.PT+"_init"+ice.DF+(index+1)) }
|
||||||
} else if (_indent == 4) {
|
} else if (_indent == 4) {
|
||||||
var ls = can.core.Split(text, "\t ({:}),"); ls[0] && push(block+ice.PT+ls[0]+ice.DF+(index+1))
|
ls[0] && push(block+ice.PT+ls[0]+ice.DF+(index+1))
|
||||||
}
|
}
|
||||||
} else if (can.db.parse == nfs.GO) {
|
} else if (can.db.parse == nfs.GO) { var ls = can.core.Split(text, "\t *", "({:})")
|
||||||
var ls = can.core.Split(text, "\t *", "({:})")
|
|
||||||
if (_indent == 0) {
|
if (_indent == 0) {
|
||||||
switch (ls[0]) {
|
switch (ls[0]) {
|
||||||
case "package": package = ls[1]; break
|
case "package": package = ls[1]; break
|
||||||
@ -517,7 +487,7 @@ Volcanos(chat.ONEXPORT, {list: ["目录", "类型", "文件", "行号", "跳转"
|
|||||||
}
|
}
|
||||||
case "type":
|
case "type":
|
||||||
case "var":
|
case "var":
|
||||||
if (ls[1].toLowerCase()[0] == ls[1][0]) { push("- "+ls[1]+ice.DF+(index+1)) } else { push("+ "+package+"."+ls[1]+ice.DF+(index+1)) } break
|
if (ls[1].toLowerCase()[0] == ls[1][0]) { push("- "+ls[1]+ice.DF+(index+1)) } else { push("+ "+package+ice.PT+ls[1]+ice.DF+(index+1)) } break
|
||||||
}
|
}
|
||||||
} else if (_indent == 4) {
|
} else if (_indent == 4) {
|
||||||
if (text.indexOf("MergeCommands(") > -1) { block = "cmds" } else if (text == "})") { block = "" }
|
if (text.indexOf("MergeCommands(") > -1) { block = "cmds" } else if (text == "})") { block = "" }
|
||||||
@ -527,8 +497,7 @@ Volcanos(chat.ONEXPORT, {list: ["目录", "类型", "文件", "行号", "跳转"
|
|||||||
if (block && ls[1] == ice.DF) { push("+ "+block+ice.SP+ls[0]+ice.DF+(index+1)) }
|
if (block && ls[1] == ice.DF) { push("+ "+block+ice.SP+ls[0]+ice.DF+(index+1)) }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
}); return {list: list, current: current, percent: percent}
|
||||||
return {list: list, current: current, percent: percent}
|
|
||||||
},
|
},
|
||||||
})
|
})
|
||||||
Volcanos(chat.ONENGINE, {
|
Volcanos(chat.ONENGINE, {
|
||||||
|
@ -1,13 +1,4 @@
|
|||||||
Volcanos(chat.ONIMPORT, {list: ["main", "filter", "grep:button", "history", "last"], _init: function(can, msg) {
|
Volcanos(chat.ONIMPORT, {list: ["value", "filter", "run:button"], _init: function(can, msg) {
|
||||||
can.onmotion.clear(can), can.onappend.table(can, msg)
|
can.onmotion.clear(can), can.onappend.table(can, msg), can.onmotion.highlight(can, can.Option(mdb.VALUE, msg.Option(mdb.VALUE)))
|
||||||
can.onmotion.delay(can, function() {
|
can.page.Select(can, can._option, "input[name=filter]", function(target) { target.onkeyup = function(event) { can.onmotion.highlight(can, target.value) } })
|
||||||
can.page.Select(can, can._option, "input[name=filter]", function(target) {
|
|
||||||
target.onkeyup = function(event) { can.misc.Event(event, can, function(msg) {
|
|
||||||
can.onmotion.highlight(can, target.value)
|
|
||||||
}) }
|
|
||||||
})
|
|
||||||
})
|
|
||||||
}})
|
}})
|
||||||
Volcanos(chat.ONACTION, {
|
|
||||||
grep: function(event, can, button) { can.runAction(event, nfs.GREP, [can.Option("main")], function(msg) { can.onimport._init(can, msg) }) },
|
|
||||||
})
|
|
||||||
|
@ -27,7 +27,7 @@ Volcanos(chat.ONFIGURE, {
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
source: function(can, target, zone, path) { var args = can.base.getValid(can.misc.SearchHash(can), [can.Option(nfs.PATH), can.Option(nfs.FILE)])
|
source: function(can, target, zone, path) { var args = can.base.getValid(can.misc.SearchHash(can), [can.Option(nfs.PATH), can.Option(nfs.FILE)])
|
||||||
zone._icon({"+": function(event) { can.user.carteRight(event, can, {}, ["script", "autogen"]) } })
|
// zone._icon({"+": function(event) { can.user.carteRight(event, can, {}, ["script", "autogen"]) } })
|
||||||
function show(target, zone, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) { can.onmotion.clear(can, target)
|
function show(target, zone, path) { can.run(can.request({}, {dir_root: path, dir_deep: true}), [nfs.PWD], function(msg) { can.onmotion.clear(can, target)
|
||||||
if (path == nfs.SRC) { can.ui.zone.source.refresh = function() { show(target, zone, path) } }
|
if (path == nfs.SRC) { can.ui.zone.source.refresh = function() { show(target, zone, path) } }
|
||||||
var total, node; function add(list) {
|
var total, node; function add(list) {
|
||||||
@ -62,20 +62,8 @@ Volcanos(chat.ONFIGURE, {
|
|||||||
can.page.Select(can, sub._output, html.DIV_ITEM, function(target, index) { can.onappend.style(can, msg.status[index], target) })
|
can.page.Select(can, sub._output, html.DIV_ITEM, function(target, index) { can.onappend.style(can, msg.status[index], target) })
|
||||||
zone._icon({ "\u21BA": function() { sub.Update() }, "+": function() { sub.run({}, [ctx.ACTION, mdb.CREATE]) }})
|
zone._icon({ "\u21BA": function() { sub.Update() }, "+": function() { sub.run({}, [ctx.ACTION, mdb.CREATE]) }})
|
||||||
}) },
|
}) },
|
||||||
module: function(can, target, zone) { zone._delay_show = function() {
|
|
||||||
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), zone._total(msg.Length())
|
|
||||||
})
|
})
|
||||||
} },
|
Volcanos(chat.ONACTION, {
|
||||||
plugin: function(can, target, zone) { var total = 0
|
|
||||||
can.onimport.tree(can, can.core.ItemKeys(can.onengine.plugin.meta, function(key) { return total++, {index: key} }), ctx.INDEX, ice.PT, function(event, item) {
|
|
||||||
can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys(ice.CAN, item.index), ctx.INDEX)
|
|
||||||
}, target), zone._total(total)
|
|
||||||
},
|
|
||||||
})
|
|
||||||
Volcanos(chat.ONACTION, {list: ["首页", "官网", "调试", "百度"],
|
|
||||||
_daemon: function(event, can, arg) { switch (arg[0]) {
|
_daemon: function(event, can, arg) { switch (arg[0]) {
|
||||||
case web.DREAM: can.runAction({}, arg[0], arg.slice(1), function(msg) { can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys(can.misc.Search(can, ice.POD), msg.Option(mdb.NAME)), web.DREAM) }); break
|
case web.DREAM: can.runAction({}, arg[0], arg.slice(1), function(msg) { can.onimport.tabview(can, can.Option(nfs.PATH), can.core.Keys(can.misc.Search(can, ice.POD), msg.Option(mdb.NAME)), web.DREAM) }); break
|
||||||
case code.XTERM: can.runAction({}, arg[0], arg.slice(1), function(msg) { can.onimport.tabview(can, ctx.COMMAND, code.XTERM, msg.Result()) }); break
|
case code.XTERM: can.runAction({}, arg[0], arg.slice(1), function(msg) { can.onimport.tabview(can, ctx.COMMAND, code.XTERM, msg.Result()) }); break
|
||||||
@ -149,7 +137,7 @@ Volcanos(chat.ONACTION, {list: ["首页", "官网", "调试", "百度"],
|
|||||||
can.onimport.toolkit(can, {index: list[0]}, function(sub) { can.db.toolkit[list[0]] = sub.select() })
|
can.onimport.toolkit(can, {index: list[0]}, function(sub) { can.db.toolkit[list[0]] = sub.select() })
|
||||||
}) },
|
}) },
|
||||||
"扩展": function(event, can) { can.user.input(can.request(event, {action: "extension"}), can, ["url"], function(list) {
|
"扩展": function(event, can) { can.user.input(can.request(event, {action: "extension"}), can, ["url"], function(list) {
|
||||||
var sub = can.db.extentions[list[0]]; sub? sub.select(): can.onimport.exts(can, list[0])
|
var sub = can.db.toolkit[list[0]]; sub? sub.select(): can.onimport.exts(can, list[0])
|
||||||
}) },
|
}) },
|
||||||
"录屏": function(event, can) { window.openapp("QuickTime Player") },
|
"录屏": function(event, can) { window.openapp("QuickTime Player") },
|
||||||
"日志": function(event, can) { window.opencmd("cd ~/contexts; tail -f var/log/bench.log") },
|
"日志": function(event, can) { window.opencmd("cd ~/contexts; tail -f var/log/bench.log") },
|
||||||
|
@ -28,7 +28,7 @@ Volcanos(chat.ONIMPORT, {_process: function(can, msg) { msg.OptionStatus() && ca
|
|||||||
msg.Table(function(item) { can.onappend._plugin(can, item, {mode: chat.FLOAT, index: item.index, args: arg.slice(1)}, function(sub, meta) {
|
msg.Table(function(item) { can.onappend._plugin(can, item, {mode: chat.FLOAT, index: item.index, args: arg.slice(1)}, function(sub, meta) {
|
||||||
sub.run = function(event, cmds, cb) { can.runAction(can.request(event, {path: msg.Option(nfs.PATH), text: msg.Option(mdb.TEXT)}), [ice.RUN, arg[0]], cmds, cb) }
|
sub.run = function(event, cmds, cb) { can.runAction(can.request(event, {path: msg.Option(nfs.PATH), text: msg.Option(mdb.TEXT)}), [ice.RUN, arg[0]], cmds, cb) }
|
||||||
can.getActionSize(function(left, top, width, height) { left = left||0, top = !can.Mode()? 120: 0
|
can.getActionSize(function(left, top, width, height) { left = left||0, top = !can.Mode()? 120: 0
|
||||||
sub.onimport.size(sub, can.base.Max(height, can.page.height())-top-2*html.ACTION_HEIGHT-(can.user.isMobile&&!can.user.isLandscape()? 2*html.ACTION_HEIGHT: 0), width, true)
|
sub.onimport.size(sub, can.base.Max(height, can.page.height())-top-(can.user.isMobile&&!can.user.isLandscape()? 2*html.ACTION_HEIGHT: 0), width, true)
|
||||||
can.onmotion.move(can, sub._target, {left: left, top: top})
|
can.onmotion.move(can, sub._target, {left: left, top: top})
|
||||||
})
|
})
|
||||||
}, document.body) })
|
}, document.body) })
|
||||||
@ -54,13 +54,14 @@ Volcanos(chat.ONIMPORT, {_process: function(can, msg) { msg.OptionStatus() && ca
|
|||||||
}).length == 0) { can.onappend.board(can, arg) }
|
}).length == 0) { can.onappend.board(can, arg) }
|
||||||
},
|
},
|
||||||
_open: function(can, msg, arg) { return can.user.open(arg) },
|
_open: function(can, msg, arg) { return can.user.open(arg) },
|
||||||
size: function(can, height, width, auto, mode) {
|
size: function(can, height, width, auto, mode) { var sub = can.core.Value(can, chat._OUTPUTS_CURRENT)
|
||||||
|
height -= html.ACTION_HEIGHT+(sub? can.onexport.statusHeight(can): html.ACTION_HEIGHT)
|
||||||
if (auto) {
|
if (auto) {
|
||||||
can.page.style(can, can._output, html.HEIGHT, "", html.WIDTH, "", html.MAX_HEIGHT, height? can.ConfHeight(height): "", html.MAX_WIDTH, can.ConfWidth(width))
|
can.page.style(can, can._output, html.HEIGHT, "", html.WIDTH, "", html.MAX_HEIGHT, height? can.ConfHeight(height): "", html.MAX_WIDTH, can.ConfWidth(width))
|
||||||
} else {
|
} else {
|
||||||
can.page.style(can, can._output, html.HEIGHT, can.ConfHeight(height), html.WIDTH, can.ConfWidth(width), html.MAX_HEIGHT, "", html.MAX_WIDTH, "")
|
can.page.style(can, can._output, html.HEIGHT, can.ConfHeight(height), html.WIDTH, can.ConfWidth(width), html.MAX_HEIGHT, "", html.MAX_WIDTH, "")
|
||||||
}
|
}
|
||||||
var sub = can.core.Value(can, chat._OUTPUTS_CURRENT); if (!sub) { return } sub.ConfHeight(can.ConfHeight()), sub.ConfWidth(can.ConfWidth())
|
if (!sub) { return } sub.ConfHeight(can.ConfHeight()), sub.ConfWidth(can.ConfWidth())
|
||||||
if (mode) { sub.Mode(can.Mode(mode)), sub.onlayout[mode](sub) } else { sub.onlayout._init(sub) }
|
if (mode) { sub.Mode(can.Mode(mode)), sub.onlayout[mode](sub) } else { sub.onlayout._init(sub) }
|
||||||
},
|
},
|
||||||
change: function(event, can, name, value, cb) { return can.page.SelectArgs(can, can._option, "", function(input) {
|
change: function(event, can, name, value, cb) { return can.page.SelectArgs(can, can._option, "", function(input) {
|
||||||
@ -82,9 +83,8 @@ Volcanos(chat.ONACTION, {list: [
|
|||||||
html.HEIGHT, can.ConfHeight(), html.WIDTH, can.ConfWidth(), ice.MODE, can.Mode()||"",
|
html.HEIGHT, can.ConfHeight(), html.WIDTH, can.ConfWidth(), ice.MODE, can.Mode()||"",
|
||||||
html.ACTION, can.page.isDisplay(can._action), html.STATUS, can.page.isDisplay(can._status),
|
html.ACTION, can.page.isDisplay(can._action), html.STATUS, can.page.isDisplay(can._status),
|
||||||
html.OUTPUT, can.base.Copy({}, can._output.style, html.HEIGHT, html.WIDTH, html.MAX_HEIGHT, html.MAX_WIDTH),
|
html.OUTPUT, can.base.Copy({}, can._output.style, html.HEIGHT, html.WIDTH, html.MAX_HEIGHT, html.MAX_WIDTH),
|
||||||
ctx.STYLE, can.base.Copy({}, can._target.style, html.LEFT, html.TOP, html.RIGHT, html.BOTTOM),
|
ctx.STYLE, can.base.Copy({}, can._target.style, html.LEFT, html.TOP, html.RIGHT, html.BOTTOM), save(),
|
||||||
save(),
|
)), can.onimport.size(can, can.ConfHeight()+html.ACTION_HEIGHT+can.onexport.statusHeight(can), can.ConfWidth(), false, mode)
|
||||||
)), can.onimport.size(can, can.ConfHeight(), can.ConfWidth(), false, mode)
|
|
||||||
} else { var back = (can._mode_list = can._mode_list||[]).pop(); if (!back) { return }
|
} else { var back = (can._mode_list = can._mode_list||[]).pop(); if (!back) { return }
|
||||||
can.ConfHeight(back.height), can.ConfWidth(back.width), can.Mode(back.mode),
|
can.ConfHeight(back.height), can.ConfWidth(back.width), can.Mode(back.mode),
|
||||||
can.onmotion.toggle(can, can._action, back.action), can.onmotion.toggle(can, can._status, back.status)
|
can.onmotion.toggle(can, can._action, back.action), can.onmotion.toggle(can, can._status, back.status)
|
||||||
|
3
proto.js
3
proto.js
@ -33,6 +33,7 @@ var ice = {
|
|||||||
MSG_TOOLKIT: "_toolkit",
|
MSG_TOOLKIT: "_toolkit",
|
||||||
MSG_PROCESS: "_process",
|
MSG_PROCESS: "_process",
|
||||||
PROCESS_AGAIN: "_again",
|
PROCESS_AGAIN: "_again",
|
||||||
|
PROCESS_FIELD: "_field",
|
||||||
MSG_PREFIX: "_prefix",
|
MSG_PREFIX: "_prefix",
|
||||||
|
|
||||||
MSG_USERNAME: "user.name", MSG_USERNICK: "user.nick",
|
MSG_USERNAME: "user.name", MSG_USERNICK: "user.nick",
|
||||||
@ -41,7 +42,7 @@ var ice = {
|
|||||||
LOG_DISABLE: "log.disable",
|
LOG_DISABLE: "log.disable",
|
||||||
|
|
||||||
ErrWarn: "warn: ", ErrNotLogin: "not login: ", ErrNotRight: "not right: ", ErrNotFound: "not found: ", ErrNotValid: "not valid: ",
|
ErrWarn: "warn: ", ErrNotLogin: "not login: ", ErrNotRight: "not right: ", ErrNotFound: "not found: ", ErrNotValid: "not valid: ",
|
||||||
|
USR: "usr",
|
||||||
USR_ICEBERGS: "usr/icebergs/",
|
USR_ICEBERGS: "usr/icebergs/",
|
||||||
USR_VOLCANOS: "usr/volcanos/",
|
USR_VOLCANOS: "usr/volcanos/",
|
||||||
LIB_MISC: "lib/misc.js",
|
LIB_MISC: "lib/misc.js",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user