mirror of
https://shylinux.com/x/volcanos
synced 2025-04-25 08:48:06 +08:00
opt search.js
This commit is contained in:
parent
0a54310d91
commit
a256c59d19
15
frame.js
15
frame.js
@ -6,7 +6,7 @@ Volcanos(chat.ONENGINE, {help: "搜索引擎", list: [], _init: function(can, me
|
||||
can.require([can.volcano], null, function(can, key, sub) { can[key] = sub })
|
||||
can.run = function(event, cmds, cb) { var msg = can.request(event); cmds = cmds||[]
|
||||
return (can.onengine[cmds[0]]||can.onengine._remote)(event, can, msg, can, cmds, cb)
|
||||
}, Volcanos.meta.args = can.user.args(can), can.onlayout.topic(can)
|
||||
}, Volcanos.meta.args = can.user.args(can)
|
||||
can.user.title(can.misc.Search(can, chat.TITLE)||can.misc.Search(can, ice.POD)||location.host)
|
||||
|
||||
can.core.Next(list, function(item, next) { item.type = chat.PANEL
|
||||
@ -23,7 +23,7 @@ Volcanos(chat.ONENGINE, {help: "搜索引擎", list: [], _init: function(can, me
|
||||
}), can.core.CallFunc([panel.onaction, chat._INIT], {can: panel, cb: next, target: panel._target})
|
||||
}, target)
|
||||
}, function() { can.misc.Log(can.user.title(), ice.RUN, can)
|
||||
can.onmotion._init(can, target), can.onkeymap._init(can)
|
||||
can.onmotion._init(can, target), can.onkeymap._init(can), can.setHeader(chat.TOPIC)
|
||||
can.onengine.signal(can, chat.ONMAIN, can.request()), can.base.isFunc(cb) && cb()
|
||||
})
|
||||
|
||||
@ -258,7 +258,8 @@ Volcanos(chat.ONAPPEND, {help: "渲染引擎", list: [], _init: function(can, me
|
||||
if (can._daemon) { msg.Option(ice.MSG_DAEMON, can.core.Keys(can.ondaemon._list[0], can._daemon)) }
|
||||
}
|
||||
|
||||
return can.run(event, cmds, function(msg) { var sub = can.core.Value(can, chat._OUTPUTS_CURRENT)||{}; can._msg = msg, sub._msg = msg
|
||||
return can.run(event, cmds, function(msg) { var sub = can.core.Value(can, chat._OUTPUTS_CURRENT)||{};
|
||||
(!cmds || cmds[0] != ctx.ACTION) && (can._msg = msg, sub._msg = msg)
|
||||
if (can.base.isFunc(cb)) { can.core.CallFunc(cb, {can: can, msg: msg}); return }
|
||||
var process = msg._can == can || msg._can == sub
|
||||
if (process && can.core.CallFunc([sub, chat.ONIMPORT, ice.MSG_PROCESS], {can: sub, msg: msg})) { return }
|
||||
@ -267,6 +268,7 @@ Volcanos(chat.ONAPPEND, {help: "渲染引擎", list: [], _init: function(can, me
|
||||
})
|
||||
},
|
||||
_output: function(can, msg, display, output, action, cb) { display = display||chat.PLUGIN_TABLE_JS, output = output||can._output
|
||||
can._display = display
|
||||
Volcanos(display, {_follow: can.core.Keys(can._follow, display), _target: output, _fields: can._target, _display: display,
|
||||
_legend: can._legend, _option: can._option, _action: can._action, _output: can._output, _status: can._status, _root: can._root,
|
||||
Update: can.Update, Option: can.Option, Action: can.Action, Status: can.Status,
|
||||
@ -462,9 +464,6 @@ Volcanos(chat.ONLAYOUT, {help: "页面布局", list: [], _init: function(can, ta
|
||||
|
||||
can.onengine.signal(can, chat.ONSIZE, can.request({}, {width: width, height: height}))
|
||||
},
|
||||
topic: function(can, topic) { topic && (can._topic = topic)
|
||||
can.user.topic(can, can._topic || can.misc.Search(can, chat.TOPIC) || Volcanos.meta.args.topic || (can.base.isNight()? chat.BLACK: chat.WHITE))
|
||||
},
|
||||
background: function(can, url, target) {
|
||||
can.page.style(can, target||can._root._target, html.BACKGROUND, url == "" || url == "void"? "": 'url("'+url+'")')
|
||||
},
|
||||
@ -666,7 +665,7 @@ Volcanos(chat.ONMOTION, {help: "动态特效", list: [], _init: function(can, ta
|
||||
var toast = can.user.toast(can, {content: {img: url, style: {"max-height": 240, display: html.BLOCK}}, duration: -1,
|
||||
action: shy({}, [cli.CLOSE, "download"], function(event, button) {
|
||||
can.user.input(event, can, [{name: mdb.NAME, value: name}], function(ev, button, data) { toast.close()
|
||||
can.page.Create(can, html.A, {href: url, download: data.name}).click()
|
||||
can.page.Create(can, html.A, {href: url, download: data.name+".png"}).click()
|
||||
})
|
||||
}),
|
||||
})
|
||||
@ -784,7 +783,7 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", list: [], _focus: [], _init: func
|
||||
case "q": window.terminate(); break
|
||||
case "w": can.user.close(); break
|
||||
case "r": can.user.reload(); break
|
||||
case "f": can.onengine.signal(can, "onopensearch", can.request({}, {type: "*"})); break
|
||||
case "f": can.onengine.signal(can, chat.ONOPENSEARCH, can.request({}, {type: "*"})); break
|
||||
case "[": history.back(); break
|
||||
case "]": history.forward(); break
|
||||
}
|
||||
|
@ -89,6 +89,7 @@ Volcanos("core", {help: "数据结构",
|
||||
}),
|
||||
CallFunc: shy("调用器", function(func, args, mod) { args = args||{}
|
||||
var event = args["event"]||{}, can = args["can"]||args[0], msg = args["msg"]||args[1], cmds = args["cmds"]||[]
|
||||
event = event._event||event
|
||||
|
||||
// 查找调用
|
||||
func = typeof func == lang.FUNCTION? func: typeof func == lang.STRING? this.Value(mod||can, func):
|
||||
|
@ -66,7 +66,7 @@ Volcanos("user", {help: "用户操作", info: {}, agent: {
|
||||
can.Conf("display") && (name += " "+can.Conf("display"))
|
||||
can.user.isMobile && (name += " mobile") && can.user.isLandscape() && (name += " landscape")
|
||||
can.user.language(can) && (name += " "+can.user.language(can))
|
||||
can.page.styleClass(can, document.body, name)
|
||||
can.page.styleClass(can, can._root._target, name)
|
||||
},
|
||||
language: function(can) { return can.misc.Search(can, "language") },
|
||||
trans: function(can, text, list) { if (can.base.isObject(text)) {
|
||||
|
112
panel/action.js
112
panel/action.js
@ -7,6 +7,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
item.inputs = can.base.Obj(item.inputs||item.list)
|
||||
|
||||
can.onappend.plugin(can, item, function(sub, meta, skip) {
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, meta.width-(can.user.isWindows? 20: 0))
|
||||
can.onimport._plugin(can, river, storm, sub, meta), skip || next()
|
||||
})
|
||||
}, function() {
|
||||
@ -17,49 +18,39 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
_plugin: function(can, river, storm, sub, meta) { sub._target._meta = meta
|
||||
meta.id && (sub._option.dataset = sub._option.dataset||{}, sub._option.dataset.id = meta.id)
|
||||
|
||||
sub.run = function(event, cmds, cb) { var msg = sub.request(event)
|
||||
return can.run(event, can.misc.concat(can, [river, storm, meta.id||meta.index], cmds), function(msg) {
|
||||
can.base.isFunc(cb) && cb(msg)
|
||||
})
|
||||
sub.run = function(event, cmds, cb) {
|
||||
return can.run(sub.request(event), can.misc.concat(can, [river, storm, meta.id||meta.index], cmds), cb)
|
||||
}, can._plugins = can.misc.concat(can, can._plugins, [sub])
|
||||
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, meta.width-(can.user.isWindows? 20: 0))
|
||||
can.onengine.listen(can, chat.ORIENTATIONCHANGE, function(event) {
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, meta.width-(can.user.isWindows? 20: 0))
|
||||
})
|
||||
|
||||
can.page.Append(can, can._action, [{view: [html.TABS, html.DIV, meta.name], onclick: function(event) {
|
||||
can.onmotion.select(can, can._output, html.FIELDSET_PLUGIN, sub._target)
|
||||
can.onmotion.select(can, can._action, html.DIV_TABS, event.target)
|
||||
}, onmouseenter: sub._legend.onmouseenter, ondblclick: sub._legend.onclick}])
|
||||
},
|
||||
_menu: function(can, msg) { if (can.user.mod.isPod||can.user.isMobile) { return }
|
||||
_menu: function(can, msg) { if (can.user.mod.isPod || can.user.isMobile) { return }
|
||||
can.setHeaderMenu(can.base.Obj(msg.Option(chat.MENUS), can.Conf(chat.MENUS)||can.onaction._menus), function(event, button, list) {
|
||||
can.core.CallFunc([can.onaction, list[0]], [can, button])
|
||||
})
|
||||
},
|
||||
_cmd: function(can, item, next) {
|
||||
can.base.Copy(item, {
|
||||
height: can._root._height-can.Conf(html.MARGIN_Y)+(can.user.isWindows? 17: 0),
|
||||
width: can._root._width,
|
||||
opts: can.misc.Search(can),
|
||||
})
|
||||
can.onappend.plugin(can, item, function(sub, meta, skip) {
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, can._root._width)
|
||||
can.user.title(meta.name), skip || next()
|
||||
})
|
||||
},
|
||||
_share: function(can, share) { share && can.run({}, ["_share", share], function(msg) {
|
||||
msg.Length() == 1 && can.onengine.signal(can, chat.ONACTION_CMD)
|
||||
can.setHeader(chat.TOPIC, msg.OptionOrSearch(chat.TOPIC))
|
||||
can.user.title(msg.OptionOrSearch(chat.TITLE))
|
||||
|
||||
msg.Length() == 1 && can.onengine.signal(can, chat.ONACTION_CMD)
|
||||
can.Conf(html.MARGIN_X, 0, html.MARGIN_Y, 2*html.ACTION_HEIGHT)
|
||||
can.onlayout._init(can, can._root._target)
|
||||
|
||||
can.Conf(chat.RIVER, "_share", chat.STORM, share)
|
||||
msg.Length() > 0 && can.onimport._init(can, msg)
|
||||
}) },
|
||||
_cmd: function(can, item, next) {
|
||||
can.onengine.signal(can, chat.ONACTION_CMD)
|
||||
|
||||
can.onappend.plugin(can, can.base.Copy(item, {opts: can.misc.Search(can)}), function(sub, meta, skip) {
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, can._root._width)
|
||||
can.user.title(meta.name), skip || next()
|
||||
})
|
||||
},
|
||||
height: function(can, height) {
|
||||
can.page.styleHeight(can._target, height)
|
||||
},
|
||||
})
|
||||
Volcanos(chat.ONENGINE, {help: "解析引擎", list: [], _engine: function(event, page, msg, can, cmds, cb) {
|
||||
var storm = can.core.Value(can._root, can.core.Keys(chat.RIVER, cmds[0], chat.STORM, cmds[1]))
|
||||
@ -83,9 +74,6 @@ Volcanos(chat.ONENGINE, {help: "解析引擎", list: [], _engine: function(event
|
||||
return true
|
||||
}})
|
||||
Volcanos(chat.ONPLUGIN, {help: "注册插件", list: [],
|
||||
"alert": shy("提示", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
can.user.alert(cmds[0])
|
||||
}),
|
||||
"parse": shy("解析", {
|
||||
"show": function(can, msg, cmds) {
|
||||
can.require(["/plugin/story/parse.js"], function() {
|
||||
@ -104,28 +92,14 @@ Volcanos(chat.ONPLUGIN, {help: "注册插件", list: [],
|
||||
},
|
||||
}, ["text", "show:button@auto"], function(can, msg, cmds, cb) { can.run({}, cmds, cb, true) }),
|
||||
|
||||
"cookie": shy("提示", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
can.core.Item(can.misc.Cookie(can), function(key, value) {
|
||||
msg.Push("key", key)
|
||||
msg.Push("value", value)
|
||||
})
|
||||
}),
|
||||
"plugin": shy("插件", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
msg.Echo("hello world")
|
||||
}),
|
||||
"info": shy("信息", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
msg.Echo("hello world")
|
||||
}),
|
||||
"log": shy("日志", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
console.log(cmds[0])
|
||||
}),
|
||||
|
||||
"nfs.save": shy("保存文件", {}, ["file=hi.txt", "text:textarea='hello world'", "save:button"], function(can, msg, cmds, cb) {
|
||||
can.misc.runAction(can, msg, cmds, cb, kit.Dict(
|
||||
"save", function(cmds) { can.user.downloads(can, cmds[1], cmds[0]) }
|
||||
))
|
||||
}),
|
||||
|
||||
"pie": shy("比例图", {}, ["list", "back"], function(can, msg, cmds) {
|
||||
msg.DisplayStory("pie.js")
|
||||
msg.Push("value", 200)
|
||||
@ -152,12 +126,11 @@ Volcanos(chat.ONKEYMAP, {help: "键盘交互", list: [], _focus: [], _init: func
|
||||
t: function(event, can, target) { can.search(event, ["River.ondetail.添加工具"]) },
|
||||
|
||||
" ": function(event, can, target) {
|
||||
can.onengine.signal(can, "onsearchfocus"), can.onkeymap.prevent(event)
|
||||
can.onengine.signal(can, chat.ONSEARCHFOCUS), can.onkeymap.prevent(event)
|
||||
},
|
||||
":": function(event, can, target) {
|
||||
can.onengine.signal(can, "oncommandfocus"), can.onkeymap.prevent(event)
|
||||
can.onengine.signal(can, chat.ONCOMMANDFOCUS), can.onkeymap.prevent(event)
|
||||
},
|
||||
enter: function(event, can, target) { can.misc.Log("enter") },
|
||||
escape: function(event, can, target) {
|
||||
can.page.Select(can, can._root._target, can.page.Keys(html.FIELDSET_FLOAT, html.DIV_FLOAT), function(item) {
|
||||
can.page.Remove(can, item)
|
||||
@ -183,6 +156,7 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [], _init: function(can, cb
|
||||
_menus: [
|
||||
[chat.LAYOUT, "auto", "tabs", "grid", "free", "flow", "page", "toimage"],
|
||||
[ice.HELP, "tutor", "manual", "service", "devops", "refer"],
|
||||
"refresh",
|
||||
],
|
||||
_trans: {
|
||||
"layout": "布局",
|
||||
@ -202,11 +176,7 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [], _init: function(can, cb
|
||||
"refer": "参考手册",
|
||||
},
|
||||
onmain: function(can) { can.onimport._share(can, can.misc.Search(can, web.SHARE)) },
|
||||
onlogin: function(can) { if (!can.Conf(chat.TOOL) && !can.user.mod.isCmd) { return }
|
||||
can.Conf(html.MARGIN_X, 0, html.MARGIN_Y, 2*html.ACTION_HEIGHT)
|
||||
can.page.ClassList.add(can, can._target, ice.CMD)
|
||||
can.onlayout._init(can)
|
||||
|
||||
onlogin: function(can) { if (!can.user.mod.isCmd && !can.Conf(chat.TOOL)) { return }
|
||||
can._names = location.pathname
|
||||
can.Conf(chat.TOOL)? can.core.Next(can.Conf(chat.TOOL), function(item, next) {
|
||||
can.onimport._cmd(can, item, next)
|
||||
@ -214,10 +184,10 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [], _init: function(can, cb
|
||||
can.onimport._cmd(can, item, next)
|
||||
}) })
|
||||
},
|
||||
onsize: function(can, msg, height, width) { can.Conf({height: height, width: width}) },
|
||||
onsearch: function(can, msg, word) {
|
||||
if (word[0] == mdb.PLUGIN || word[1] != "") { can.onexport.plugin(can, msg, word) }
|
||||
if (word[0] == mdb.PLUGIN || word[0] == mdb.FOREACH) { can.onexport.plugin(can, msg, word) }
|
||||
},
|
||||
onsize: function(can, msg, height, width) { can.Conf({height: height, width: width}) },
|
||||
onstorm_select: function(can, msg, river, storm) {
|
||||
if (can.onmotion.cache(can, function() {
|
||||
return can.core.Keys(can.Conf(chat.RIVER, river), can.Conf(chat.STORM, storm))
|
||||
@ -231,9 +201,11 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [], _init: function(can, cb
|
||||
})
|
||||
},
|
||||
onaction_cmd: function(can, msg) {
|
||||
can.ConfHeight(can._root._height), can.ConfWidth(can._root._width)
|
||||
can.Conf(html.MARGIN_X, 0, html.MARGIN_Y, 2*html.ACTION_HEIGHT)
|
||||
can.page.ClassList.add(can, can._root._target, "simple")
|
||||
can.page.ClassList.add(can, can._target, "cmd")
|
||||
can.ConfHeight(can._root._height)
|
||||
can.ConfWidth(can._root._width)
|
||||
can.onlayout._init(can)
|
||||
},
|
||||
|
||||
layout: function(can, button, silent) { button = button||ice.AUTO
|
||||
@ -243,14 +215,29 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [], _init: function(can, cb
|
||||
can.onlayout._init(can)
|
||||
},
|
||||
help: function(can, button) { can.user.open("/help/"+button+".shy") },
|
||||
refresh: function(can, button) {
|
||||
can._root._height = window.innerHeight, can._root._width = window.innerWidth
|
||||
can.onlayout._init(can)
|
||||
|
||||
var width = can.ConfWidth()-can.Conf(html.MARGIN_X)
|
||||
can.core.List(can._plugins, function(sub) {
|
||||
can.page.style(can, sub._output, html.MAX_WIDTH, sub.ConfWidth(width)-(can.user.isWindows? 20: 0))
|
||||
can.onappend._output(sub, can.core.Value(sub, chat._OUTPUT_CURRENT)._msg, sub._display)
|
||||
})
|
||||
},
|
||||
})
|
||||
Volcanos(chat.ONLAYOUT, {help: "导出数据", list: [],
|
||||
toimage: function(can) {
|
||||
return can.onmotion.toimage(event, can, can.Conf(chat.STORM), can._output), true
|
||||
},
|
||||
auto: function(can) {
|
||||
can.Conf(chat.LAYOUT, "")
|
||||
},
|
||||
grid: function(can, silent) {
|
||||
var ACTION_LAYOUT_FMT = " fieldset.Action.grid>div.output fieldset.plugin { width:_width; height:_height; } fieldset.Action.grid>div.output fieldset.plugin>div.output { width:_width; height:_height; } "
|
||||
can.user.input(event, can, [{name: "m", value: 2}, {name: "n", value: 2}], function(event, button, data, list, args) {
|
||||
can.getActionSize(function(height, width) { var m = parseInt(data.m)||2, n = parseInt(data.n)||2
|
||||
can.page.css(can.base.replaceAll(ACTION_LAYOUT_FMT, "_width", (width-(4*m+1)*html.PLUGIN_MARGIN)/m+"px", "_height", (height-(4*n+1)*html.PLUGIN_MARGIN)/n+"px"))
|
||||
})
|
||||
}, silent)
|
||||
},
|
||||
tabs: function(can) {
|
||||
can.onmotion.select(can, can._action, html.DIV_TABS, 0)
|
||||
can.onmotion.select(can, can._output, html.FIELDSET_PLUGIN, 0)
|
||||
@ -261,13 +248,8 @@ Volcanos(chat.ONLAYOUT, {help: "导出数据", list: [],
|
||||
can.onmotion.move(can, item, {left: 40*index, top: 40*index})
|
||||
})
|
||||
},
|
||||
grid: function(can, silent) {
|
||||
var ACTION_LAYOUT_FMT = " fieldset.Action.grid>div.output fieldset.plugin { width:_width; height:_height; } fieldset.Action.grid>div.output fieldset.plugin>div.output { width:_width; height:_height; } "
|
||||
can.user.input(event, can, [{name: "m", value: 2}, {name: "n", value: 2}], function(event, button, data, list, args) {
|
||||
can.getActionSize(function(height, width) { var m = parseInt(data.m)||2, n = parseInt(data.n)||2
|
||||
can.page.css(can.base.replaceAll(ACTION_LAYOUT_FMT, "_width", (width-(4*m+1)*html.PLUGIN_MARGIN)/m+"px", "_height", (height-(4*n+1)*html.PLUGIN_MARGIN)/n+"px"))
|
||||
})
|
||||
}, silent)
|
||||
toimage: function(can) {
|
||||
return can.onmotion.toimage(event, can, can.Conf(chat.STORM), can._output), true
|
||||
},
|
||||
})
|
||||
Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
@ -296,7 +278,7 @@ Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
var list = can.page.Select(can, item.nextSibling, html.OPTION_ARGS, function(item) { return item.value||"" })
|
||||
var meta = item.parentNode._meta; if (!meta) { return }
|
||||
|
||||
var data = {ctx: "web.chat", cmd: ctx.ACTION,
|
||||
var data = {ctx: "can", cmd: "Action",
|
||||
type: mdb.PLUGIN, name: item.innerHTML, text: shy("跳转", function(event) {
|
||||
var input = can.page.Select(can, item.parentNode, html.INPUT_ARGS)[0]; input && input.focus()
|
||||
}), argument: JSON.stringify(list),
|
||||
|
@ -3,7 +3,7 @@ fieldset.Footer>div.output { height:32px; overflow:hidden; }
|
||||
fieldset.Footer>div.output>div { padding:5px; height:22px; cursor:pointer; }
|
||||
fieldset.Footer>div.output>div:hover { background-color:#2e515f; border-top:solid 2px red; }
|
||||
fieldset.Footer>div.output div.title { float:left; }
|
||||
fieldset.Footer>div.output div.state { float:right; }
|
||||
fieldset.Footer>div.output div.state { float:right; font-family:monospace; }
|
||||
fieldset.Footer>div.output div.toast { background-color:darkcyan; float:right; }
|
||||
fieldset.Footer>div.output div.cmd { padding:0px; float:left; }
|
||||
fieldset.Footer>div.output input[name=cmd] { height:25px; width:120px; border-radius:0; }
|
||||
|
@ -1,23 +1,12 @@
|
||||
Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, msg, cb, target) {
|
||||
can.onmotion.clear(can)
|
||||
can.onmotion.clear(can), can.base.isFunc(cb) && cb(msg)
|
||||
can.onimport._title(can, msg, target)
|
||||
can.onimport._state(can, msg, target)
|
||||
can.onimport._toast(can, msg, target)
|
||||
can.onimport._cli(can, msg, target)
|
||||
can.base.isFunc(cb) && cb(msg)
|
||||
|
||||
can.core.Timer(100, function() {
|
||||
window.webview && can.setHeaderMenu(["后退", "列表"], function(event, button, list) {
|
||||
switch (button) {
|
||||
case "后退": history.back(); break
|
||||
case "列表": window.menu(); break
|
||||
}
|
||||
can.core.CallFunc([can.onaction, list[0]], [can, button])
|
||||
})
|
||||
})
|
||||
can.onimport._command(can, msg, target)
|
||||
},
|
||||
_title: function(can, msg, target) {
|
||||
!can.user.isMobile && can.core.List(msg.result, function(item) {
|
||||
_title: function(can, msg, target) { if (can.user.isMobile) { return }
|
||||
can.core.List(msg.result, function(item) {
|
||||
can.page.Append(can, target, [{view: [chat.TITLE, html.DIV, item], title: "联系站长"}])
|
||||
})
|
||||
},
|
||||
@ -25,28 +14,21 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
can.core.List(can.base.Obj(msg.Option(chat.STATE)||can.Conf(chat.STATE), ["ncmd", "ntip"]), function(item) {
|
||||
can.page.Append(can, target, [{view: [can.base.join([chat.STATE, item]), html.DIV, can.Conf(item)], list: [
|
||||
{text: [item, html.LABEL]}, {text: [": ", html.LABEL]}, {text: [can.Conf(item)||"", html.SPAN, item]},
|
||||
], onclick: function(event) {
|
||||
can[item] = can[item]? (can.page.Remove(can, can[item]), null): can.onexport[item](can)
|
||||
can.page.style(can, can.show, {left: "", top: "", right: 0, bottom: can.onexport.height(can)})
|
||||
}}])
|
||||
], onclick: function(event) { can.onexport[item](can) }}])
|
||||
})
|
||||
},
|
||||
_toast: function(can, msg, target) {
|
||||
can.toast = can.page.Append(can, target, [{view: chat.TOAST, onclick: function(event) { var item = "ntip"
|
||||
can[item] = can[item]? (can.page.Remove(can, can[item]), null): can.onexport[item](can)
|
||||
can.page.style(can, can.show, {left: "", top: "", right: 0, bottom: can.onexport.height(can)})
|
||||
}}]).first
|
||||
can.toast = can.page.Append(can, target, [{view: chat.TOAST, onclick: function(event) { can.onexport["ntip"](can) }}]).first
|
||||
},
|
||||
_cli: function(can, msg, target) {
|
||||
_command: function(can, msg, target) {
|
||||
can.onappend.input(can, {type: html.TEXT, name: "cmd", onkeydown: function(event) {
|
||||
can.onkeymap.input(event, can); if (event.key != lang.ENTER) { return }
|
||||
switch (event.target.value) {
|
||||
case cli.CLEAR: can.cli && can.cli.close(); break
|
||||
case cli.CLOSE: can.cli && can.cli.close(); break
|
||||
case cli.CLEAR: can.cli && can.cli.close(); break
|
||||
default:
|
||||
can.run(event, [ice.RUN].concat(can.core.Split(event.target.value, ice.SP)), function(msg) {
|
||||
can.cli && can.cli.close(), can.cli = can.onexport.float(can, msg, function(value, key, index, line, list) {})
|
||||
can.page.style(can, can.cli.first, "bottom", can.onexport.height(can), "top", "")
|
||||
can.cli && can.cli.close(), can.onexport.float(can, msg, function(value, key, index, line, list) {}, "cli", true)
|
||||
})
|
||||
}
|
||||
}}, "", target, "title cmd")
|
||||
@ -75,22 +57,22 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
ontoast: function(can, msg) { can.core.CallFunc(can.onimport.toast, {can: can, msg: msg}) },
|
||||
onremote: function(can, msg) { can.core.CallFunc(can.onimport.ncmd, {can: can, msg: msg}) },
|
||||
onaction_cmd: function(can, msg) { can.onmotion.hidden(can) },
|
||||
oncommandfocus: function(can) { can.page.Select(can, can._output, "div.cmd input", function(target) { target.focus() }) },
|
||||
oncommandfocus: function(can) { can.page.Select(can, can._output, ["div.cmd", "input"], function(target) { can.onmotion.focus(can, target) }) },
|
||||
})
|
||||
Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
height: function(can) { return can._target.offsetHeight },
|
||||
float: function(can, msg, cb) {
|
||||
float: function(can, msg, cb, name, bottom) { if (can[name]) { return can[name].close() }
|
||||
var ui = can.onappend.field(can, "story toast float", {}, can._root._target)
|
||||
ui.close = function() { can.page.Remove(can, ui.first) }
|
||||
ui.close = function() { can.page.Remove(can, ui.first), delete(can[name]) }
|
||||
|
||||
can.getActionSize(function(left, top, height, width) {
|
||||
can.page.style(can, ui.output, html.MAX_HEIGHT, height-28, html.MAX_WIDTH, width)
|
||||
can.page.style(can, ui.first, html.LEFT, left, html.TOP, top)
|
||||
can.page.style(can, ui.output, html.MAX_HEIGHT, height-28, html.MAX_WIDTH, width)
|
||||
})
|
||||
|
||||
can.onappend._action(can, [cli.CLOSE, cli.REFRESH, {input: html.TEXT, placeholder: "filter", _init: function(input) {
|
||||
can.onengine.signal(can, "keymap.focus", can.request({}, {cb: function(event) {
|
||||
if (event.target.tagName == "INPUT") { return }
|
||||
if (can.page.tagis(html.INPUT, event.target)) { return }
|
||||
if (event.key == lang.ESCAPE) { ui.close(); return }
|
||||
if (event.key == ice.SP) { input.focus(), can.onkeymap.prevent(event) }
|
||||
}}))
|
||||
@ -106,31 +88,31 @@ Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
})
|
||||
}}], ui.action, kit.Dict(cli.CLOSE, ui.close, cli.REFRESH, function(event) { ui.close(), can.toast.click()}))
|
||||
|
||||
can.onappend.table(can, msg, function(value, key, index, line, list) {
|
||||
return {text: [value, html.TD], onclick: function(event) {
|
||||
can.base.isFunc(cb) && cb(value, key, index, line, list)
|
||||
}}
|
||||
}, ui.output), can.onappend.board(can, msg.Result(), ui.output)
|
||||
return ui
|
||||
if (msg) {
|
||||
can.onappend.table(can, msg, function(value, key, index, line, list) {
|
||||
return {text: [value, html.TD], onclick: function(event) {
|
||||
can.base.isFunc(cb) && cb(value, key, index, line, list)
|
||||
}}
|
||||
}, ui.output), can.onappend.board(can, msg.Result(), ui.output)
|
||||
}
|
||||
return can.page.style(can, ui.first, bottom? {bottom: 32, top: ""}: {}), can[name] = ui
|
||||
},
|
||||
ntip: function(can) {
|
||||
return can.onexport.float(can, can._tips).first
|
||||
can.onexport.float(can, can._tips, function() {}, "ntip")
|
||||
},
|
||||
ncmd: function(can) {
|
||||
return can.onexport.float(can, can._cmds, function(value, key, index, line, list) {
|
||||
can.onexport.float(can, can._cmds, function(value, key, index, line, list) {
|
||||
var cmds = can.base.Obj(line.cmds); switch (line.follow) {
|
||||
case "chat.Action": cmds = cmds.slice(2); break
|
||||
case "chat.Footer": cmds = cmds.slice(2); break
|
||||
case "can.Action": cmds = cmds.slice(2); break
|
||||
case "can.Footer": cmds = cmds.slice(2); break
|
||||
}
|
||||
switch (cmds[0]) {
|
||||
case "web.wiki.word": cmds = cmds.slice(5); break
|
||||
}
|
||||
|
||||
can.get("Action", "size", function(msg, top, left, width, height) {
|
||||
can.getActionSize(function(msg, top, left, width, height) {
|
||||
can.onappend.plugin(can, {index: cmds[0], args: cmds.slice(1), height: height-100, width: width}, function(sub) {
|
||||
sub.run = function(event, cmd, cb) {
|
||||
can.run(event, can.misc.concat(can, [ctx.ACTION, ice.RUN, cmds[0]], cmd), cb)
|
||||
}
|
||||
sub.run = function(event, cmd, cb) { can.runAction(event, ice.RUN, [cmds[0]].concat(cmd), cb) }
|
||||
|
||||
can.page.style(can, sub._target, {top: top+100, left: left})
|
||||
can.page.style(can, sub._legend, {display: html.BLOCK})
|
||||
@ -138,6 +120,6 @@ Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
can.page.ClassList.add(can, sub._target, chat.FLOAT)
|
||||
}, can._root._target)
|
||||
})
|
||||
}).first
|
||||
}, "ncmd")
|
||||
},
|
||||
})
|
||||
|
181
panel/header.js
181
panel/header.js
@ -1,42 +1,15 @@
|
||||
Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, msg, cb, target) {
|
||||
can.Conf(aaa.USERNICK, msg.Option(aaa.USERNICK)||msg.Option(ice.MSG_USERNICK)||msg.Option(ice.MSG_USERNAME)||can.Conf(aaa.USERNICK))
|
||||
can.user.info.usernick = can.Conf(aaa.USERNICK)
|
||||
can.user.info.avatar = msg.Option(aaa.AVATAR)
|
||||
can.onmotion.clear(can), can.base.isFunc(cb) && cb(msg)
|
||||
can.onimport._title(can, msg, target)
|
||||
can.onimport._state(can, msg, target)
|
||||
can.onimport._avatar(can, msg, target)
|
||||
can.onimport._background(can, msg, target)
|
||||
can.onimport._search(can, msg, target)
|
||||
can.onimport._menus(can, msg, target)
|
||||
can.ondaemon._init(can)
|
||||
|
||||
can.onlayout.topic(can, can.Conf("topic"))
|
||||
if (can.user.mod.isCmd) {
|
||||
can.onmotion.hidden(can, can._fields)
|
||||
can.page.ClassList.add(can, can._root._target, "simple")
|
||||
}
|
||||
|
||||
can.onmotion.clear(can)
|
||||
can.onimport._agent(can, msg, target)
|
||||
can.onimport._grant(can, msg, target)
|
||||
if (can.Conf("display") != "simple") {
|
||||
can.onimport._title(can, msg, target)
|
||||
can.onimport._state(can, msg, target)
|
||||
can.onimport._search(can, msg, target)
|
||||
can.onimport._background(can, msg, target)
|
||||
can.onimport._avatar(can, msg, target)
|
||||
can.onimport._menus(can, msg, target)
|
||||
|
||||
}
|
||||
can.base.isFunc(cb) && cb(msg)
|
||||
},
|
||||
_agent: function(can, msg, target) { if (!msg.Option(nfs.SCRIPT)) { return }
|
||||
can.require(can.base.Obj(msg.Option(nfs.SCRIPT)), function(can) { can.onaction.source(can, msg) })
|
||||
},
|
||||
_grant: function(can, msg, target) {
|
||||
if (can.misc.Search(can, chat.GRANT)) {
|
||||
if (can.user.confirm(chat.GRANT+ice.SP+can.misc.Search(can, chat.GRANT))) {
|
||||
can.run(event, [ctx.ACTION, chat.GRANT, web.SPACE, can.misc.Search(can, chat.GRANT)])
|
||||
}
|
||||
can.misc.Search(can, chat.GRANT, "")
|
||||
}
|
||||
},
|
||||
_title: function(can, msg, target) {
|
||||
!can.user.isMobile && can.core.List(can.base.getValid(msg.result, can.Conf(chat.TITLE)||["shylinux.com/x/contexts"]), function(item) {
|
||||
_title: function(can, msg, target) { if (can.user.isMobile) { return }
|
||||
can.core.List(can.base.getValid(msg.result, can.Conf(chat.TITLE)||["shylinux.com/x/contexts"]), function(item) {
|
||||
can.page.Append(can, target, [{view: [chat.TITLE, html.DIV, item], title: "返回主页", onclick: function(event) {
|
||||
can.onaction.title(event, can)
|
||||
}, onmouseenter: function(event) { var list = msg.Table()
|
||||
@ -50,47 +23,36 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
can.core.List(can.base.Obj(msg.Option(chat.STATE)||can.Conf(chat.STATE), [mdb.TIME, aaa.USERNICK]), function(item) {
|
||||
if (item == aaa.AVATAR ) { if (can.user.isLocalFile) { return }
|
||||
can.page.Append(can, target, [{view: can.base.join([chat.STATE, item]), list: [{img: ice.SP}], onmouseenter: function(event) {
|
||||
if (msg.Option(aaa.AVATAR).indexOf("http") == 0) {
|
||||
can.onaction.carte(event, can, [can.page.Format(html.IMG, msg.Option(aaa.AVATAR), 160)])
|
||||
} else {
|
||||
can.onaction.carte(event, can, [can.page.Format(html.IMG, "/share/local/avatar", 160)])
|
||||
}
|
||||
can.onaction.carte(event, can, [can.page.Format(html.IMG, can.onexport.avatar(can), 160)])
|
||||
}}]); return
|
||||
}
|
||||
|
||||
can.page.Append(can, target, [{view: [can.base.join([chat.STATE, item]), html.DIV, (can.Conf(item)||"").slice(0, 10)], onmouseenter: function(event) {
|
||||
can.core.CallFunc([can.onaction, item], [event, can, item])
|
||||
}, _init: function(target) { item == mdb.TIME && can.onimport._time(can, target) }}])
|
||||
})
|
||||
},
|
||||
_avatar: function(can, msg) { if (can.user.isExtension || can.user.isLocalFile || !msg.Option(aaa.AVATAR)) { return }
|
||||
can.page.Modify(can, "div.state.avatar>img", {src: can.onexport.avatar(can)})
|
||||
},
|
||||
_background: function(can, msg) { if (can.user.isExtension || can.user.isLocalFile || can.Conf(aaa.BACKGROUND) == "_") { return }
|
||||
msg.Option(aaa.BACKGROUND) && can.onlayout.background(can, "/share/local/background")
|
||||
},
|
||||
_search: function(can, msg, target) {
|
||||
var ui = can.onappend.input(can, {type: html.TEXT, name: mdb.SEARCH, onkeydown: function(event) {
|
||||
can.onkeymap.input(event, can); switch (event.key) {
|
||||
case lang.ENTER: can.onengine.signal(can, "onopensearch", can.request(event, {type: "*", word: event.target.value}))
|
||||
case lang.ENTER: can.onengine.signal(can, chat.ONOPENSEARCH, can.request(event, {type: mdb.FOREACH, word: event.target.value}))
|
||||
}
|
||||
}}, "", target, "title search").parentNode
|
||||
can.page.Append(can, target, [{type: "search", list: [{view: ["menu", "div", can.user.trans(can, "search")], onclick: function() {
|
||||
can.onengine.signal(can, "onopensearch", can.request(event, {type: "*", word: ""}))
|
||||
}}] }])
|
||||
can.user.isMobile && can.page.style(can, ui, {float: html.RIGHT})
|
||||
},
|
||||
_background: function(can, msg) {
|
||||
if (can.Conf("background") == "_") { return }
|
||||
if (can.user.isExtension || can.user.isLocalFile) { return }
|
||||
msg.Option(aaa.BACKGROUND) && can.onlayout.background(can, "/share/local/background", can._root._target)
|
||||
},
|
||||
_avatar: function(can, msg) { if (can.user.isExtension || can.user.isLocalFile) { return } if (!msg.Option(aaa.AVATAR)) { return }
|
||||
if (msg.Option(aaa.AVATAR).indexOf("http") == 0) {
|
||||
can.page.Modify(can, "div.state.avatar>img", {src: msg.Option(aaa.AVATAR)})
|
||||
} else {
|
||||
can.page.Modify(can, "div.state.avatar>img", {src: "/share/local/avatar"})
|
||||
}
|
||||
}}, "", target, "title search")
|
||||
can.onimport.menu(can, mdb.SEARCH, function() {
|
||||
can.onengine.signal(can, chat.ONOPENSEARCH, can.request(event, {type: mdb.FOREACH, word: ui.value}))
|
||||
})
|
||||
can.user.isMobile && can.page.style(can, ui.parentNode, {float: html.RIGHT})
|
||||
},
|
||||
_menus: function(can, msg, target) {
|
||||
can.setHeaderMenu(can.user.mod.isPod||can.user.isExtension||can.user.isMobile? [ctx.CONFIG]:
|
||||
can.base.Obj(msg.Option(chat.MENUS)||can.Conf(chat.MENUS), can.onaction._menus), function(event, button) {
|
||||
can.core.CallFunc(can.onaction[button]||function(event, can) {
|
||||
can.run(event, [button], function(msg) { can.user.toast(can, "执行成功", can.user.trans(can, button)) })
|
||||
can.run(event, [button], function(msg) { can.user.toastSuccess(can, can.user.trans(can, button)) })
|
||||
}, {event: event, can: can, button: button})
|
||||
})
|
||||
},
|
||||
@ -98,26 +60,27 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
_time: function(can, target) {
|
||||
can.core.Timer({interval: 500}, function() { can.onimport.time(can, target) })
|
||||
can.onappend.figure(can, {action: "date", style: {"min-width": 306}}, target, function(sub) {
|
||||
can.get("Action", "size", function(msg, top) {
|
||||
can.page.style(can, sub._target, {top: top, right: 0, left: null})
|
||||
})
|
||||
can.getActionSize(function(msg, top) { can.page.style(can, sub._target, {top: top, right: 0, left: ""}) })
|
||||
}), target.onmouseenter = target.click
|
||||
},
|
||||
time: function(can, target) { can.onlayout.topic(can)
|
||||
time: function(can, target) { can.onimport.topic(can)
|
||||
target.innerHTML = can.user.time(can, null, "%w %H:%M:%S")
|
||||
},
|
||||
topic: function(can, topic) { can.onlayout.topic(can, can._topic = topic) },
|
||||
background: function(event, can, url) { if (can.user.isExtension || can.user.isLocalFile) { return }
|
||||
can.run(event, [ctx.ACTION, aaa.BACKGROUND, url], function(msg) { can.onimport._background(can, msg) })
|
||||
},
|
||||
avatar: function(event, can, url) { if (can.user.isExtension || can.user.isLocalFile) { return }
|
||||
can.run(event, [ctx.ACTION, aaa.AVATAR, url], function(msg) { can.onimport._avatar(can, msg) })
|
||||
can.runAction(event, aaa.AVATAR, [url], function(msg) { can.onimport._avatar(can, msg) })
|
||||
},
|
||||
menu: function(can, cmds, cb, trans) {
|
||||
return can.page.Append(can, can._output, [{type: cmds[0], list: can.core.List(cmds.slice(1), function(item) {
|
||||
topic: function(can, topic) { topic && (can._topic = topic)
|
||||
can.user.topic(can, can._topic || can.misc.Search(can, chat.TOPIC) || Volcanos.meta.args.topic || (can.base.isNight()? chat.BLACK: chat.WHITE))
|
||||
},
|
||||
background: function(event, can, url) { if (can.user.isExtension || can.user.isLocalFile) { return }
|
||||
can.runAction(event, aaa.BACKGROUND, [url], function(msg) { can.onimport._background(can, msg) })
|
||||
},
|
||||
menu: function(can, cmds, cb, trans) { can.base.isString(cmds) && (cmds = [cmds])
|
||||
return can.page.Append(can, can._output, [{type: cmds[0], list: can.core.List(can.base.getValid(cmds.slice(1), [cmds[0]]), function(item) {
|
||||
if (can.base.isString(item)) {
|
||||
return {view: [html.MENU, html.DIV, can.user.trans(can, item, trans)], onclick: function(event) {
|
||||
can.base.isFunc(cb) && cb(event, item, cmds)
|
||||
can.base.isFunc(cb) && cb(event, item, [item])
|
||||
// can.base.isFunc(cb) && cb(event, item, cmds)
|
||||
}}
|
||||
|
||||
} else if (can.base.isArray(item)) {
|
||||
@ -136,9 +99,23 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
})
|
||||
Volcanos(chat.ONPLUGIN, {help: "注册插件", list: [],
|
||||
"topic": shy("主题", {
|
||||
"demo": function(can, msg, cmds) { can.onlayout.topic(can, cmds[0]) },
|
||||
"demo": function(can, msg, cmds) { can.onimport.topic(can, cmds[0]) },
|
||||
}, ["topic:select=white,black", "run:button", "demo:button"], function(can, msg, cmds) {
|
||||
can.onlayout.topic(can, cmds[0])
|
||||
can.onimport.topic(can, cmds[0])
|
||||
}),
|
||||
"cookie": shy("提示", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
can.core.Item(can.misc.Cookie(can), function(key, value) {
|
||||
msg.Push("key", key), msg.Push("value", value)
|
||||
})
|
||||
}),
|
||||
"alert": shy("提示", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
can.user.alert(cmds[0])
|
||||
}),
|
||||
"info": shy("信息", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
msg.Echo("hello world")
|
||||
}),
|
||||
"log": shy("日志", {}, ["text", "list", "back"], function(can, msg, cmds) {
|
||||
console.log(cmds[0])
|
||||
}),
|
||||
})
|
||||
Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb, target) {
|
||||
@ -172,6 +149,8 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
return // 登录认证
|
||||
}
|
||||
can.base.Copy(can.onaction._trans, can.base.Obj(msg.Option(chat.TRANS), {}))
|
||||
can.user.info.usernick = can.Conf(aaa.USERNICK), can.user.info.avatar = msg.Option(aaa.AVATAR)
|
||||
msg.Option(nfs.SCRIPT) && can.require(can.base.Obj(msg.Option(nfs.SCRIPT)), function(can) { can.onaction.source(can, msg) })
|
||||
can.onimport._init(can, msg, function(msg) { can.onengine.signal(can, chat.ONLOGIN, msg) }, can._output)
|
||||
})
|
||||
},
|
||||
@ -187,11 +166,9 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
can.user.jumps(can.misc.MergeURL(can, args, true))
|
||||
},
|
||||
|
||||
black: function(event, can, button) { can.onlayout.topic(can, button), can.onlayout._init(can) },
|
||||
white: function(event, can, button) { can.onlayout.topic(can, button), can.onlayout._init(can) },
|
||||
print: function(event, can, button) { can.onlayout.topic(can, [chat.WHITE, button])
|
||||
can.setRiver(html.HEIGHT, -1), can.setAction(html.HEIGHT, -1)
|
||||
},
|
||||
black: function(event, can, button) { can.onimport.topic(can, button), can.onlayout._init(can) },
|
||||
white: function(event, can, button) { can.onimport.topic(can, button), can.onlayout._init(can) },
|
||||
print: function(event, can, button) { can.onimport.topic(can, [chat.WHITE, button]), can.setRiver(html.HEIGHT, ""), can.setAction(html.HEIGHT, "") },
|
||||
webpack: function(event, can) {
|
||||
can.user.input(event, can, [{name: mdb.NAME, value: can.user.title()}], function(ev, button, meta, list) {
|
||||
can.core.Item(Volcanos.meta.pack, function(key, msg) {
|
||||
@ -207,7 +184,7 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
var toast = can.user.toastProcess(can, "打包中...", code.WEBPACK)
|
||||
can.runAction(event, code.WEBPACK, [], function(msg) {
|
||||
toast.close(), can.user.toastSuccess(can, "打包成功", code.WEBPACK)
|
||||
can.user.download(can, "/share/local/"+msg.Result(), name, "html")
|
||||
can.user.download(can, "/share/local/"+msg.Result(), name, nfs.HTML)
|
||||
})
|
||||
})
|
||||
},
|
||||
@ -220,37 +197,36 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
})
|
||||
},
|
||||
|
||||
carte: function(event, can, list, cb, trans) { can.user.carte(event, can, can.onaction, list, cb) },
|
||||
carte: function(event, can, list, cb) {
|
||||
can.user.carte(event, can, can.onaction, list, cb)
|
||||
},
|
||||
share: function(event, can, args) {
|
||||
can.user.share(can, can.request(event), [ctx.ACTION, chat.SHARE].concat(args||[],
|
||||
[chat.RIVER, can.Conf(chat.RIVER), chat.STORM, can.Conf(chat.STORM)]))
|
||||
can.user.share(can, can.request(event), [ctx.ACTION, chat.SHARE].concat(args||[], [chat.RIVER, can.Conf(chat.RIVER), chat.STORM, can.Conf(chat.STORM)]))
|
||||
},
|
||||
|
||||
usernick: function(event, can) {
|
||||
can.user.mod.isPod || can.user.isExtension || can.user.isLocalFile || can.onaction.carte(event, can, ["shareuser", "setnick", "password", [aaa.LANGUAGE, aaa.CHINESE, aaa.ENGLISH], cli.CLEAR, aaa.LOGOUT])
|
||||
usernick: function(event, can) { if (can.user.mod.isPod || can.user.isExtension || can.user.isLocalFile) { return }
|
||||
can.onaction.carte(event, can, ["shareuser", "setnick", aaa.PASSWORD, [aaa.LANGUAGE, aaa.CHINESE, aaa.ENGLISH], cli.CLEAR, aaa.LOGOUT])
|
||||
},
|
||||
shareuser: function(event, can) {
|
||||
can.user.share(can, can.request(event), [ctx.ACTION, chat.SHARE, mdb.TYPE, aaa.LOGIN])
|
||||
},
|
||||
shareuser: function(event, can) { can.user.share(can, can.request(event), [ctx.ACTION, chat.SHARE, mdb.TYPE, aaa.LOGIN]) },
|
||||
setnick: function(event, can) {
|
||||
var ui = can.user.input(event, can, [{name: aaa.USERNICK, value: can.Conf(aaa.USERNICK)}], function(ev, button, data, list, args) {
|
||||
can.run(event, [aaa.USERNICK, list[0]], function(msg) {
|
||||
can.runAction(event, aaa.USERNICK, [list[0]], function(msg) {
|
||||
can.page.Select(can, can._output, can.core.Keys(html.DIV, aaa.USERNICK), function(item) {
|
||||
can.page.Modify(can, item, can.Conf(aaa.USERNICK, list[0]))
|
||||
}), can.user.toastSuccess(can)
|
||||
}, true)
|
||||
})
|
||||
})
|
||||
can.user.isMobile && can.page.style(can, ui._target, {top: 40, right: 0, left: ""})
|
||||
},
|
||||
password: function(event, can) {
|
||||
var ui = can.user.input(event, can, [{name: html.PASSWORD, type: html.PASSWORD, action: ice.AUTO}, {name: html.PASSWORD, type: html.PASSWORD, action: ice.AUTO}], function(ev, button, data, list, args) {
|
||||
if (list[0] != list[1]) {
|
||||
can.user.toast(can, "密码不一致")
|
||||
ui.focus()
|
||||
return true
|
||||
}
|
||||
|
||||
can.run(event, [aaa.PASSWORD, list[0]], function(msg) {
|
||||
can.user.toastSuccess(can)
|
||||
}, true)
|
||||
var ui = can.user.input(event, can, [
|
||||
{name: html.PASSWORD, type: html.PASSWORD, action: ice.AUTO},
|
||||
{name: html.PASSWORD, type: html.PASSWORD, action: ice.AUTO},
|
||||
], function(ev, button, data, list, args) {
|
||||
if (list[0] != list[1]) { return can.user.toast(can, "密码不一致"), ui.focus(), true }
|
||||
can.runAction(event, aaa.PASSWORD, [list[0]])
|
||||
})
|
||||
can.user.isMobile && can.page.style(can, ui._target, {top: 40, right: 0, left: ""})
|
||||
},
|
||||
@ -262,4 +238,11 @@ Volcanos(chat.ONACTION, {help: "交互数据", list: [], _init: function(can, cb
|
||||
Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
height: function(can) { return can._target.offsetHeight },
|
||||
topic: function(can) { return can._topic },
|
||||
avatar: function(can) {
|
||||
if (can.user.info.avatar.indexOf("http") == 0) {
|
||||
return can.user.info.avatar
|
||||
} else {
|
||||
return "/share/local/avatar"
|
||||
}
|
||||
},
|
||||
})
|
||||
|
@ -240,7 +240,7 @@ Volcanos(chat.ONEXPORT, {help: "导出数据", list: [],
|
||||
can.core.Item(value.storm, function(storm, item) {
|
||||
if (word[1] != "" && word[1] != storm && word[1] != item.name) { return }
|
||||
|
||||
var data = {ctx: "web.chat", cmd: chat.STORM,
|
||||
var data = {ctx: "can", cmd: "Storm",
|
||||
type: river, name: storm, text: shy("跳转", function(event) {
|
||||
can.onaction.action(event, can, river, storm)
|
||||
}),
|
||||
|
@ -29,7 +29,9 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
|
||||
can.onengine.signal(can, chat.ONSEARCH, res)
|
||||
can.run(res, cmds, function(res) { can.onimport._init(can, res, fields) })
|
||||
can.onmotion.show(can), can.onmotion.focus(can, can.ui.word)
|
||||
can.onmotion.show(can), can.onmotion.delay(can, function() {
|
||||
can.onmotion.focus(can, can.ui.word)
|
||||
})
|
||||
},
|
||||
|
||||
select: function(can, msg, cmds, cb) { can.ui.word.value = cmds[1]
|
||||
@ -45,12 +47,12 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, ms
|
||||
can.getActionSize(function(msg, top, left, width, height) {
|
||||
can.page.style(can, can._target, {top: top, left: left})
|
||||
can.page.style(can, can._output, html.MAX_HEIGHT, height-71, html.MAX_WIDTH, width-2*html.PLUGIN_MARGIN)
|
||||
can.page.style(can, can.ui.content, html.MAX_HEIGHT, height/2, html.MAX_WIDTH, width-2*html.PLUGIN_MARGIN)
|
||||
can.page.style(can, can.ui.content, html.MAX_WIDTH, width-2*html.PLUGIN_MARGIN)
|
||||
can.page.style(can, can.ui.display, html.MAX_WIDTH, width-2*html.PLUGIN_MARGIN)
|
||||
})
|
||||
},
|
||||
})
|
||||
Volcanos(chat.ONACTION, {help: "交互操作", list: [cli.CLEAR, cli.CLOSE, cli.DONE], _init: function(can, cb, target) {
|
||||
Volcanos(chat.ONACTION, {help: "交互操作", list: [cli.CLOSE, cli.CLEAR, cli.DONE], _init: function(can, cb, target) {
|
||||
can.onmotion.hidden(can, can._target), can.base.isFunc(cb) && cb()
|
||||
},
|
||||
onlogin: function(can, msg) {
|
||||
|
@ -86,7 +86,7 @@ Volcanos(chat.ONIMPORT, {help: "导入数据", list: [], _init: function(can, me
|
||||
})
|
||||
Volcanos(chat.ONACTION, {help: "交互操作", list: [
|
||||
"刷新数据", "切换全屏", "共享工具", "打开链接", "生成链接", "生成脚本", "生成图片", [
|
||||
"其它", "刷新页面", "清空参数", "扩展参数", "复制数据", "下载数据", "清空数据", "删除工具","摄像头",
|
||||
"其它", "刷新页面", "保存参数", "清空参数", "扩展参数", "复制数据", "下载数据", "清空数据", "删除工具","摄像头",
|
||||
],
|
||||
], _init: function(can, msg, list, cb, target) {},
|
||||
_engine: function(event, can, button) { can.Update(event, [ctx.ACTION, button].concat(can.Input([], true))) },
|
||||
@ -129,18 +129,18 @@ Volcanos(chat.ONACTION, {help: "交互操作", list: [
|
||||
"刷新页面": function(event, can) { var sub = can.core.Value(can._outputs, "-1")
|
||||
can.core.CallFunc([sub, chat.ONIMPORT, "_init"], {can: sub, msg: sub._msg, cb: function(msg) {}, target: can._output})
|
||||
},
|
||||
"保存参数": function(event, can) { can.search(event, ["River.ondetail.保存参数"]) },
|
||||
"清空参数": function(event, can) { can.page.SelectArgs(can, can._option, "", function(item) { return item.value = "" }) },
|
||||
"扩展参数": function(event, can) { can.onmotion.toggle(can, can._action) },
|
||||
"复制数据": function(event, can) { can.user.copy(event, can, can.onexport.table(can)||can.onexport.board(can)) },
|
||||
"下载数据": function(event, can) { var meta = can.Conf()
|
||||
can.user.input(event, can, [{name: "filename", value: meta.name}], function(ev, button, data, list) {
|
||||
can.user.downloads(can, can.onexport.table(can), list[0], "csv")||can.user.downloads(can, can.onexport.board(can), meta.name, "txt")
|
||||
can.user.downloads(can, can.onexport.table(can), list[0], nfs.CSV)||can.user.downloads(can, can.onexport.board(can), meta.name, nfs.TXT)
|
||||
})
|
||||
},
|
||||
"清空数据": function(event, can) { can.onmotion.clear(can, can._output) },
|
||||
"删除工具": function(event, can) { can.page.Remove(can, can._target) },
|
||||
|
||||
"保存参数": function(event, can) { can.search(event, ["River.ondetail.保存参数"]) },
|
||||
"打包页面": function(event, can) { can.onengine.signal(can, "onwebpack", can.request(event)) },
|
||||
|
||||
"摄像头": function(event, can) {
|
||||
|
6
proto.js
6
proto.js
@ -72,7 +72,7 @@ var cli = {
|
||||
SHOW: "show",
|
||||
}
|
||||
var nfs = {
|
||||
ZML: "zml", IML: "iml",
|
||||
ZML: "zml", IML: "iml", TXT: "txt",
|
||||
HTML: "html", CSS: "css", JS: "js", GO: "go", SH: "sh", CSV: "csv", JSON: "json",
|
||||
PATH: "path", FILE: "file", LINE: "line", SIZE: "size",
|
||||
SAVE: "save", LOAD: "load", TAGS: "tags", FIND: "find", GREP: "grep",
|
||||
@ -183,8 +183,8 @@ var chat = {
|
||||
ONMAIN: "onmain", ONLOGIN: "onlogin", ONSEARCH: "onsearch",
|
||||
ONSIZE: "onsize", ONTOAST: "ontoast", ONREMOTE: "onremote",
|
||||
ONKEYDOWN: "onkeydown", ONMOUSEENTER: "onmouseenter", ORIENTATIONCHANGE: "orientationchange",
|
||||
ONSTORM_SELECT: "onstorm_select", ONACTION_TOUCH: "onaction_touch", ONACTION_NOTOOL: "onaction_notool",
|
||||
ONACTION_CMD: "onaction_cmd",
|
||||
ONSTORM_SELECT: "onstorm_select", ONACTION_TOUCH: "onaction_touch", ONACTION_NOTOOL: "onaction_notool", ONACTION_CMD: "onaction_cmd",
|
||||
ONOPENSEARCH: "onopensearch", ONSEARCHFOCUS: "onsearchfocus", ONCOMMANDFOCUS: "oncommandfocus",
|
||||
|
||||
_INIT: "_init", _ENGINE: "_engine", _SEARCH: "_search", _OUTPUTS_CURRENT: "_outputs.-1",
|
||||
_NAMES: "_names", _TOAST: "_toast",
|
||||
|
Loading…
x
Reference in New Issue
Block a user