mirror of
https://shylinux.com/x/ContextOS
synced 2025-04-25 16:58:06 +08:00
opt Jshy.js
This commit is contained in:
parent
d4464b9a74
commit
ab11ad2c12
@ -39,6 +39,9 @@ fieldset.Target>div.output>div.item>div.user {
|
|||||||
fieldset.Source {
|
fieldset.Source {
|
||||||
overflow:hidden;
|
overflow:hidden;
|
||||||
}
|
}
|
||||||
|
fieldset.Source div.action {
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
fieldset.Source div.output {
|
fieldset.Source div.output {
|
||||||
padding:0;
|
padding:0;
|
||||||
}
|
}
|
||||||
|
@ -101,6 +101,36 @@ var page = Page({check: true,
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Action: {
|
||||||
|
"聊天": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, page.conf.layout)
|
||||||
|
},
|
||||||
|
"办公": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, page.conf.layout)
|
||||||
|
page.onlayout(event, {river: 0, action:300})
|
||||||
|
},
|
||||||
|
"工作": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, page.conf.layout)
|
||||||
|
page.onlayout(event, {river:0, action:-1})
|
||||||
|
},
|
||||||
|
"最高": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, {action: -1})
|
||||||
|
},
|
||||||
|
"最宽": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, {river:0, storm:0})
|
||||||
|
},
|
||||||
|
"最大": function(event, value) {
|
||||||
|
page.which.set(value)
|
||||||
|
page.onlayout(event, {header:0, footer:0, river:0, storm:0, action: -1})
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
initOcean: function(page, field, option, output) {
|
initOcean: function(page, field, option, output) {
|
||||||
var table = kit.AppendChild(output, "table")
|
var table = kit.AppendChild(output, "table")
|
||||||
var ui = kit.AppendChild(field, [{view: ["create"], list: [
|
var ui = kit.AppendChild(field, [{view: ["create"], list: [
|
||||||
@ -233,6 +263,9 @@ var page = Page({check: true,
|
|||||||
river = value, field.Pane.Show()
|
river = value, field.Pane.Show()
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Choice: [
|
||||||
|
["layout", "工作", "聊天", "最高"],
|
||||||
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
initSource: function(page, field, option, output) {
|
initSource: function(page, field, option, output) {
|
||||||
@ -283,169 +316,15 @@ var page = Page({check: true,
|
|||||||
var temp = ""
|
var temp = ""
|
||||||
output.DisplayRaw = true
|
output.DisplayRaw = true
|
||||||
return {
|
return {
|
||||||
Tutor: function() {var pane = field.Pane
|
|
||||||
var event = window.event
|
|
||||||
function loop(list, index) {
|
|
||||||
if (index >= list.length) {return}
|
|
||||||
kit.Log(index, list[index])
|
|
||||||
pane.Core(event, {}, ["_cmd", list[index]])
|
|
||||||
setTimeout(function() {loop(list, index+1)}, 1000)
|
|
||||||
}
|
|
||||||
loop([
|
|
||||||
"聊天", "help", "最高", "最大", "聊天",
|
|
||||||
"工作", "串行", "清空", "并行", "help storm", "help storm list", "help action", "help action list",
|
|
||||||
"聊天", "help target", "help target list",
|
|
||||||
], 0)
|
|
||||||
},
|
|
||||||
Core: function(event, line, args, cbs) {var pane = field.Pane
|
|
||||||
var msg = pane.Event(event)
|
|
||||||
var plugin = event.Plugin || page.plugin && page.plugin.Plugin || {}, engine = {
|
|
||||||
share: function(args) {
|
|
||||||
return ctx.Share({"group": option.dataset.group, "names": option.dataset.names, "cmds": [
|
|
||||||
river, line.storm, line.action, args[1]||"",
|
|
||||||
]})
|
|
||||||
},
|
|
||||||
wssid: function(id) {
|
|
||||||
return id && (page.wssid = id)
|
|
||||||
},
|
|
||||||
pwd: function(name, value) {
|
|
||||||
name && kit.Selector(page.action, "fieldset.item."+name, function(item) {
|
|
||||||
item.Plugin.Select()
|
|
||||||
})
|
|
||||||
if (value) {return engine.set(value)}
|
|
||||||
return [river, storm, page.plugin && page.plugin.Meta.name, page.input && page.input.name, page.input && page.input.value]
|
|
||||||
},
|
|
||||||
set: function(value, name) {
|
|
||||||
try {
|
|
||||||
if (value == undefined) {
|
|
||||||
msg.append = ["name", "value"]
|
|
||||||
msg.name = [], msg.value = []
|
|
||||||
return kit.Selector(page.plugin, ".args", function(item) {
|
|
||||||
msg.Push("name", item.name)
|
|
||||||
msg.Push("value", item.value)
|
|
||||||
return item.name+":"+item.value
|
|
||||||
})
|
|
||||||
|
|
||||||
} else if (name == undefined) {
|
|
||||||
kit.Selector(page.plugin, "input[type=button]", function(item) {
|
|
||||||
if (item.value == value) {item.click(); return value}
|
|
||||||
}).length > 0 || (page.action.Pane.Action[value]?
|
|
||||||
page.action.Pane.Action[value](event, value): (page.input.value = value))
|
|
||||||
} else {
|
|
||||||
page.plugin.Plugin.Inputs[name].value = value
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
engine._cmd("_cmd", [value, name])
|
|
||||||
}
|
|
||||||
},
|
|
||||||
dir: function(rid, sid, pid, uid) {
|
|
||||||
if (!rid) {
|
|
||||||
return kit.Selector(page.river, "div.output>div.item>div.text>span", function(item) {
|
|
||||||
return item.innerText
|
|
||||||
})
|
|
||||||
}
|
|
||||||
if (!sid) {
|
|
||||||
return kit.Selector(page.storm, "div.output>div.item>div.text>span", function(item) {
|
|
||||||
return item.innerText
|
|
||||||
})
|
|
||||||
}
|
|
||||||
if (!pid) {
|
|
||||||
return kit.Selector(page.action, "fieldset.item>legend", function(item) {
|
|
||||||
msg.Push("name", item.parentNode.Meta.name)
|
|
||||||
msg.Push("help", item.parentNode.Meta.help)
|
|
||||||
return item.innerText
|
|
||||||
})
|
|
||||||
}
|
|
||||||
if (!uid) {
|
|
||||||
return kit.Selector(page.plugin, "input", function(item) {
|
|
||||||
msg.Push("name", item.name)
|
|
||||||
msg.Push("value", item.value)
|
|
||||||
return item.name+":"+item.value
|
|
||||||
})
|
|
||||||
}
|
|
||||||
return [river, storm, page.plugin && page.plugin.Meta.name, page.input && page.input.name]
|
|
||||||
},
|
|
||||||
echo: function(one, two) {
|
|
||||||
kit.Log(one, two)
|
|
||||||
},
|
|
||||||
helps: function() {
|
|
||||||
engine.help("river")
|
|
||||||
engine.help("action")
|
|
||||||
engine.help("storm")
|
|
||||||
},
|
|
||||||
help: function() {
|
|
||||||
var args = kit.List(arguments), cb, target
|
|
||||||
if (args.length > 0 && page.pane && page.pane.Pane[args[0]] && page.pane.Pane[args[0]].Plugin) {
|
|
||||||
cb = page.pane.Pane[args[0]].Plugin.Help, target = page.pane.Pane[args[0]], args = args.slice(1)
|
|
||||||
} else if (args.length > 1 && page[args[0]] && page[args[0]].Pane[args[1]]) {
|
|
||||||
cb = page[args[0]].Pane[args[1]].Plugin.Help, target = page[args[0]].Pane[args[1]], args = args.slice(2)
|
|
||||||
} else if (args.length > 0 && page[args[0]]) {
|
|
||||||
cb = page[args[0]].Pane.Help, target = page[args[0]], args = args.slice(1)
|
|
||||||
} else {
|
|
||||||
cb = page.Help, target = document.body, args
|
|
||||||
}
|
|
||||||
|
|
||||||
if (kit.Selector(target, "div.Help", function(help) {
|
|
||||||
target.removeChild(help)
|
|
||||||
return help
|
|
||||||
}).length > 0) {return}
|
|
||||||
|
|
||||||
var text = kit._call(cb, args)
|
|
||||||
var ui = kit.AppendChild(target, [{view: ["Help"], list: [{text: [text.join(""), "div"]}]}])
|
|
||||||
setTimeout(function() {target.removeChild(ui.last)}, 30000)
|
|
||||||
},
|
|
||||||
_split: function(str) {return str.trim().split(" ")},
|
|
||||||
_cmd: function(arg) {
|
|
||||||
var args = typeof arg[1] == "string"? engine._split(arg[1]): arg[1];
|
|
||||||
page.script("record", args)
|
|
||||||
kit.Log(["cmd"].concat(args))
|
|
||||||
|
|
||||||
if (typeof engine[args[0]] == "function") {
|
|
||||||
return kit._call(engine[args[0]], args.slice(1))
|
|
||||||
}
|
|
||||||
if (page.plugin && typeof page.plugin.Plugin[args[0]] == "function") {
|
|
||||||
return kit._call(page.plugin.Plugin[args[0]], args.slice(1))
|
|
||||||
}
|
|
||||||
|
|
||||||
if (page.dialog && (res = page.dialog.Pane.Jshy(event, args))) {return res}
|
|
||||||
if (page.pane && (res = page.pane.Pane.Jshy(event, args))) {return res}
|
|
||||||
if (page.storm && (res = page.storm.Pane.Jshy(event, args))) {return res}
|
|
||||||
if (page.river && (res = page.river.Pane.Jshy(event, args))) {return res}
|
|
||||||
|
|
||||||
|
|
||||||
if (page && (res = page.Jshy(event, args))) {return res}
|
|
||||||
if (page.plugin && (res = page.plugin.Plugin.Jshy(event, args))) {return res}
|
|
||||||
return kit.Log(["warn", "not", "find"].concat(args))
|
|
||||||
},
|
|
||||||
_msg: function(msg) {
|
|
||||||
if (msg) {
|
|
||||||
var text = msg.Format()
|
|
||||||
text && event.ctrlKey && page.target.Pane.Send(text[0], text[1])
|
|
||||||
} else {
|
|
||||||
page.target.Pane.Send("field", plugin.Reveal())
|
|
||||||
}
|
|
||||||
},
|
|
||||||
_run: function() {
|
|
||||||
var meta = plugin && plugin.target && plugin.target.Meta || {}
|
|
||||||
field.Pane.Run(event, [meta.river||river, meta.storm||storm, meta.action].concat(args), function(msg) {
|
|
||||||
engine._msg(msg), typeof cbs == "function" && cbs(msg)
|
|
||||||
})
|
|
||||||
},
|
|
||||||
}
|
|
||||||
if (args.length > 0 && engine[args[0]] && msg.Echo(engine[args[0]](args))) {typeof cbs == "function" && cbs(msg); return}
|
|
||||||
event.shiftKey? engine._msg(): engine._run()
|
|
||||||
},
|
|
||||||
Show: function() {var pane = field.Pane
|
Show: function() {var pane = field.Pane
|
||||||
if (river && storm && field.Pane.Load(river+"."+storm, output)) {return}
|
if (river && storm && field.Pane.Load(river+"."+storm, output)) {return}
|
||||||
|
|
||||||
pane.Event(event, {}, {name: pane.Zone("show", river, storm)})
|
pane.Event(event, {}, {name: pane.Zone("show", river, storm)})
|
||||||
output.innerHTML = "", pane.Appends([river, storm], "plugin", ["name", "help"], "name", true, function(line, index, event, args, cbs) {
|
output.innerHTML = "", pane.Appends([river, storm], "plugin", ["name", "help"], "name", true)
|
||||||
kit.notNone(args) && pane.Core(event, line, args, cbs)
|
|
||||||
})
|
|
||||||
},
|
},
|
||||||
Layout: function(name) {var pane = field.Pane
|
Layout: function(name) {var pane = field.Pane
|
||||||
var layout = field.querySelector("select.layout")
|
var layout = field.querySelector("select.layout")
|
||||||
name && pane.Action[layout.value = name](window.event, layout.value)
|
name && page.Action[layout.value = name](window.event, layout.value)
|
||||||
return layout.value
|
return layout.value
|
||||||
},
|
},
|
||||||
Listen: {
|
Listen: {
|
||||||
@ -458,33 +337,6 @@ var page = Page({check: true,
|
|||||||
target: function(value, old) {share = value},
|
target: function(value, old) {share = value},
|
||||||
},
|
},
|
||||||
Action: {
|
Action: {
|
||||||
"聊天": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, page.conf.layout)
|
|
||||||
},
|
|
||||||
"办公": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, page.conf.layout)
|
|
||||||
page.onlayout(event, {river: 0, action:300})
|
|
||||||
},
|
|
||||||
"工作": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, page.conf.layout)
|
|
||||||
page.onlayout(event, {river:0, action:-1})
|
|
||||||
},
|
|
||||||
"最高": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, {action: -1})
|
|
||||||
},
|
|
||||||
"最宽": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, {river:0, storm:0})
|
|
||||||
},
|
|
||||||
"最大": function(event, value) {
|
|
||||||
page.which.set(value)
|
|
||||||
page.onlayout(event, {header:0, footer:0, river:0, storm:0, action: -1})
|
|
||||||
},
|
|
||||||
|
|
||||||
"刷新": function(event, value) {
|
"刷新": function(event, value) {
|
||||||
output.innerHTML = "", field.Pane.Show()
|
output.innerHTML = "", field.Pane.Show()
|
||||||
},
|
},
|
||||||
@ -555,7 +407,7 @@ var page = Page({check: true,
|
|||||||
"", "执行", "下载", "清空", "返回",
|
"", "执行", "下载", "清空", "返回",
|
||||||
],
|
],
|
||||||
Choice: [
|
Choice: [
|
||||||
["layout", "聊天", "办公", "工作"],
|
["layout", "工作", "聊天", "最高"],
|
||||||
"", "刷新", "清屏", "并行", "串行", "调试",
|
"", "刷新", "清屏", "并行", "串行", "调试",
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
|
@ -218,7 +218,6 @@ fieldset.dialog.Carte>div.output div.space {
|
|||||||
clear:both;
|
clear:both;
|
||||||
}
|
}
|
||||||
fieldset.dialog.Debug {
|
fieldset.dialog.Debug {
|
||||||
height:300px;
|
|
||||||
opacity:0.8;
|
opacity:0.8;
|
||||||
}
|
}
|
||||||
fieldset.dialog.Debug tr.hide {
|
fieldset.dialog.Debug tr.hide {
|
||||||
@ -233,11 +232,35 @@ fieldset.dialog.Debug tr.run {
|
|||||||
fieldset.dialog.Debug tr.key {
|
fieldset.dialog.Debug tr.key {
|
||||||
background-color:lightyellow;
|
background-color:lightyellow;
|
||||||
}
|
}
|
||||||
|
fieldset.dialog.Debug>div.output {
|
||||||
|
overflow:auto;
|
||||||
|
margin-top:50px;
|
||||||
|
}
|
||||||
|
fieldset.dialog.Debug>div.output table caption {
|
||||||
|
position:absolute;
|
||||||
|
top:50px;
|
||||||
|
left:20px;
|
||||||
|
}
|
||||||
|
fieldset.dialog.Debug>div.output table thead {
|
||||||
|
position:absolute;
|
||||||
|
top:72px;
|
||||||
|
left:18px;
|
||||||
|
}
|
||||||
|
fieldset.dialog.Debug>div.output table thead th {
|
||||||
|
border:solid 1px red;
|
||||||
|
}
|
||||||
|
fieldset.dialog.Debug>div.output table caption>span {
|
||||||
|
margin-right:4px;
|
||||||
|
}
|
||||||
|
fieldset.dialog.Debug>div.output table caption>span:hover {
|
||||||
|
cursor:pointer;
|
||||||
|
background-color:red;
|
||||||
|
}
|
||||||
fieldset.dialog.Debug>div.output table th {
|
fieldset.dialog.Debug>div.output table th {
|
||||||
min-width:30px;
|
min-width:60px;
|
||||||
}
|
}
|
||||||
fieldset.dialog.Debug>div.output table td {
|
fieldset.dialog.Debug>div.output table td {
|
||||||
min-width:10px;
|
min-width:60px;
|
||||||
}
|
}
|
||||||
|
|
||||||
fieldset.Login {
|
fieldset.Login {
|
||||||
@ -292,7 +315,11 @@ fieldset.Footer>div.output div.title {
|
|||||||
float:left;
|
float:left;
|
||||||
}
|
}
|
||||||
fieldset.Footer>div.output div.magic {
|
fieldset.Footer>div.output div.magic {
|
||||||
float:left;
|
float:right;
|
||||||
|
margin-top:-6px;
|
||||||
|
}
|
||||||
|
fieldset.Footer>div.output div.magic>label {
|
||||||
|
margin-right:2px;
|
||||||
}
|
}
|
||||||
fieldset.Footer>div.output div.magic>input {
|
fieldset.Footer>div.output div.magic>input {
|
||||||
background-color:black;
|
background-color:black;
|
||||||
@ -364,6 +391,9 @@ fieldset table caption {
|
|||||||
font-style:italic;
|
font-style:italic;
|
||||||
border:solid 1px green;
|
border:solid 1px green;
|
||||||
}
|
}
|
||||||
|
fieldset table tbody {
|
||||||
|
overflow:auto;
|
||||||
|
}
|
||||||
fieldset table tr:hover {
|
fieldset table tr:hover {
|
||||||
background-color:lightgreen;
|
background-color:lightgreen;
|
||||||
}
|
}
|
||||||
@ -374,6 +404,7 @@ fieldset table th {
|
|||||||
font-family:monospace;
|
font-family:monospace;
|
||||||
background-color:lightgreen;
|
background-color:lightgreen;
|
||||||
cursor:pointer;
|
cursor:pointer;
|
||||||
|
padding: 0 6px;
|
||||||
}
|
}
|
||||||
fieldset table th.order {
|
fieldset table th.order {
|
||||||
background-color:red;
|
background-color:red;
|
||||||
@ -382,8 +413,7 @@ fieldset table th.order {
|
|||||||
fieldset table td {
|
fieldset table td {
|
||||||
max-width:1200px;
|
max-width:1200px;
|
||||||
font-family:monospace;
|
font-family:monospace;
|
||||||
padding-left: 6px;
|
padding: 0 6px;
|
||||||
padding-right: 6px;
|
|
||||||
}
|
}
|
||||||
fieldset table td.clip {
|
fieldset table td.clip {
|
||||||
background-color:red;
|
background-color:red;
|
||||||
|
@ -94,7 +94,7 @@ function Meta(zone, target, obj) {
|
|||||||
case "field": text = JSON.parse(line.text)
|
case "field": text = JSON.parse(line.text)
|
||||||
case "plugin": if (!text.name) {return {}}
|
case "plugin": if (!text.name) {return {}}
|
||||||
var id = "plugin"+meta.ID()
|
var id = "plugin"+meta.ID()
|
||||||
list.push({view: ["item", "fieldset"], data: {id: id}, list: [
|
list.push({view: ["item", "fieldset"], data: {id: id, draggable: true}, list: [
|
||||||
{text: [text.name+"("+text.help+")", "legend"]},
|
{text: [text.name+"("+text.help+")", "legend"]},
|
||||||
{view: ["option", "form"], list: [{type: "input", style: {"display": "none"}}]},
|
{view: ["option", "form"], list: [{type: "input", style: {"display": "none"}}]},
|
||||||
{view: ["output", "div"]},
|
{view: ["output", "div"]},
|
||||||
@ -102,7 +102,7 @@ function Meta(zone, target, obj) {
|
|||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
var ui = kit.AppendChild(output, item? list: [{view: ["item"], list:list}])
|
var ui = kit.AppendChild(output, item? list: [{view: ["item"], data: {draggable: true}, list:list}])
|
||||||
return ui.item.Meta = text, ui
|
return ui.item.Meta = text, ui
|
||||||
}),
|
}),
|
||||||
Include: shy("加载脚本", function(src, cb) {src = kit.List(src)
|
Include: shy("加载脚本", function(src, cb) {src = kit.List(src)
|
||||||
@ -116,6 +116,7 @@ function Meta(zone, target, obj) {
|
|||||||
Event: shy("事件入口", {name: zone}, function(event, msg, proto) {
|
Event: shy("事件入口", {name: zone}, function(event, msg, proto) {
|
||||||
return ctx.Event(event, msg, proto||arguments.callee.meta)
|
return ctx.Event(event, msg, proto||arguments.callee.meta)
|
||||||
}),
|
}),
|
||||||
|
Zones: function(name) {return zone.concat(kit.List(arguments)).join(".")},
|
||||||
Zone: function(name) {return zone.concat(kit.List(arguments))},
|
Zone: function(name) {return zone.concat(kit.List(arguments))},
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +128,7 @@ function Meta(zone, target, obj) {
|
|||||||
}
|
}
|
||||||
function Page(page) {
|
function Page(page) {
|
||||||
var script = {}, record = ""
|
var script = {}, record = ""
|
||||||
page = Meta([document.title], document.body, page, {__proto__: ctx,
|
page = Meta([document.title], document.body, page, {
|
||||||
onload: function(event) {
|
onload: function(event) {
|
||||||
// Event入口 0
|
// Event入口 0
|
||||||
page.Event(event, {})
|
page.Event(event, {})
|
||||||
@ -237,6 +238,9 @@ function Page(page) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
switch (event.key) {
|
switch (event.key) {
|
||||||
|
case " ":
|
||||||
|
event.stopPropagation()
|
||||||
|
return true
|
||||||
case "Escape":
|
case "Escape":
|
||||||
target.blur()
|
target.blur()
|
||||||
break
|
break
|
||||||
@ -342,19 +346,24 @@ function Page(page) {
|
|||||||
return true
|
return true
|
||||||
},
|
},
|
||||||
Help: function(pane, type, action) {return []},
|
Help: function(pane, type, action) {return []},
|
||||||
Jshy: function(event, args) {var msg = ctx.Event(event)
|
Jshy: shy("本地命令", function(event, args) {var msg = ctx.Event(event)
|
||||||
|
// 面板命令
|
||||||
if (page[args[0]] && page[args[0]].type == "fieldset") {
|
if (page[args[0]] && page[args[0]].type == "fieldset") {
|
||||||
if (args.length > 1) {
|
return page[args[0]].Pane.Jshy(event, args.slice(1)) || page.Zone("select", args[0])
|
||||||
return page[args[0]].Pane.Jshy(event, args.slice(1))
|
|
||||||
} else {
|
|
||||||
msg.Echo("pane", args[0])
|
|
||||||
return page[args[0]].Pane.Show()
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
// 控件命令
|
||||||
|
if (typeof page.Action[args[0]] == "function") {
|
||||||
|
return kit._call(page.Action[args[0]], [event, args[0]]) || page.Zone("action", args[0])
|
||||||
|
}
|
||||||
|
|
||||||
|
// 脚本命令
|
||||||
if (script[args[0]]) {return page.script("replay", args[0])}
|
if (script[args[0]]) {return page.script("replay", args[0])}
|
||||||
|
|
||||||
return typeof page[args[0]] == "function" && kit._call(page[args[0]], args.slice(1))
|
// 内部命令
|
||||||
},
|
if (typeof page[args[0]] == "function") {
|
||||||
|
return kit._call(page[args[0]], args.slice(1)) || page.Zone("function", args[0])
|
||||||
|
}
|
||||||
|
}),
|
||||||
WSS: function(cb, onerror, onclose) {
|
WSS: function(cb, onerror, onclose) {
|
||||||
return page.socket || (page.socket = ctx.WSS(cb || (function(m) {
|
return page.socket || (page.socket = ctx.WSS(cb || (function(m) {
|
||||||
if (m.detail) {
|
if (m.detail) {
|
||||||
@ -421,7 +430,7 @@ function Page(page) {
|
|||||||
return {
|
return {
|
||||||
Show: function(event, cb) {if (!cb.list || cb.list.length == 0) {return}
|
Show: function(event, cb) {if (!cb.list || cb.list.length == 0) {return}
|
||||||
output.innerHTML = ""
|
output.innerHTML = ""
|
||||||
kit.AppendActions(output, cb.list, function(value, event) {
|
kit.AppendActions(output, cb.list, function(event, value) {
|
||||||
kit._call(cb, [value, cb.meta, event]) && field.Pane.Hide()
|
kit._call(cb, [value, cb.meta, event]) && field.Pane.Hide()
|
||||||
}, true)
|
}, true)
|
||||||
|
|
||||||
@ -437,11 +446,12 @@ function Page(page) {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
initDebug: function(page, field, option, output) {
|
initDebug: function(page, field, option, output) {
|
||||||
var list = kit.AppendChilds(output, "table")
|
var table = kit.AppendChilds(output, "table")
|
||||||
var caption = kit.AppendChilds(list, [{type: "caption"}]).last
|
var caption = kit.AppendChild(table, [{type: "caption"}]).last
|
||||||
var head = kit.AppendChild(list, [{row: ["time", "type", "order", "action", "target", "args"], sub: "th"}]).last
|
var head = kit.AppendChild(table, [{type: "thead", list: [{row: ["time", "type", "order", "action", "target", "args"], sub: "th"}]}]).tr
|
||||||
kit.OrderTable(list)
|
var list = kit.AppendChild(table, "tbody")
|
||||||
var data, types = {all: 0, event: 0, run: 0, key: 0}
|
kit.OrderTable(table)
|
||||||
|
var last, types = {all: 0, event: 0, run: 0, key: 0}
|
||||||
|
|
||||||
|
|
||||||
kit.Log.meta.call.push(function(time, type, order, action, target) {var Choice = field.Pane && field.Pane.Choice || []
|
kit.Log.meta.call.push(function(time, type, order, action, target) {var Choice = field.Pane && field.Pane.Choice || []
|
||||||
@ -449,15 +459,26 @@ function Page(page) {
|
|||||||
types[type]++
|
types[type]++
|
||||||
types.all++
|
types.all++
|
||||||
|
|
||||||
data = kit.AppendChild(list, [{className: type, row: [time, type, order, action||"", target||"", kit.List(arguments, function(item) {
|
last = kit.AppendChild(list, [{className: type, row: [time, type, order, action||"", target||"", kit.List(arguments, function(item) {
|
||||||
return typeof item == "object"? "{...}": item
|
return typeof item == "object"? "{...}": item
|
||||||
}).slice(5).join(" ")]}]).last
|
}).slice(5).join(" ")]}]).last
|
||||||
data.scrollIntoView()
|
field.Pane && field.Pane.Head()
|
||||||
caption.innerHTML = kit.List(Choice.slice(1), function(item) {return item+": "+types[item]}).join(" ")
|
|
||||||
|
kit.AppendChilds(caption, kit.List(Choice.slice(1), function(item) {return {text: [item+": "+types[item], "span"], click: function(event) {
|
||||||
|
field.Pane.Action(event, item)
|
||||||
|
}}}))
|
||||||
})
|
})
|
||||||
|
var layout
|
||||||
return {
|
return {
|
||||||
Show: function() {
|
Head: function() {if (kit.isNone(last)) {return}
|
||||||
|
caption.style.width = last.offsetWidth+"px"
|
||||||
|
kit.Selector(last, "td", function(item, index) {
|
||||||
|
head.childNodes[index].style.width = item.offsetWidth-14+"px"
|
||||||
|
})
|
||||||
|
},
|
||||||
|
Show: function() {layout || (layout = field.Pane.Action.meta["最大"](), 1)
|
||||||
kit.ModifyView(field, {display: field.style.display != "block"? "block": "none"})
|
kit.ModifyView(field, {display: field.style.display != "block"? "block": "none"})
|
||||||
|
field.Pane.Head()
|
||||||
},
|
},
|
||||||
clear: function() {
|
clear: function() {
|
||||||
var th = kit.AppendChilds(list, [{row: ["time", "type", "main", "arg", "args"], sub: "th"}]).last
|
var th = kit.AppendChilds(list, [{row: ["time", "type", "main", "arg", "args"], sub: "th"}]).last
|
||||||
@ -467,24 +488,25 @@ function Page(page) {
|
|||||||
field.Pane.Show()
|
field.Pane.Show()
|
||||||
},
|
},
|
||||||
"最大": function() {
|
"最大": function() {
|
||||||
kit.size(field, document.body.clientWidth, document.body.clientHeight)
|
kit.size(output, document.body.clientWidth, document.body.clientHeight-160)
|
||||||
},
|
},
|
||||||
"最小": function() {
|
"最小": function() {
|
||||||
kit.size(field, document.body.clientWidth/2, document.body.clientHeight/2)
|
kit.size(output, document.body.clientWidth/2, document.body.clientHeight/2)
|
||||||
},
|
},
|
||||||
"左边": function() {
|
"左边": function() {
|
||||||
field.style.left = "0px"
|
field.style.left = "0px"
|
||||||
kit.size(field, document.body.clientWidth/2, document.body.clientHeight)
|
kit.size(output, document.body.clientWidth/2, document.body.clientHeight)
|
||||||
},
|
},
|
||||||
"右边": function() {
|
"右边": function() {
|
||||||
field.style.left = document.body.clientWidth/2+"px"
|
field.style.left = document.body.clientWidth/2+"px"
|
||||||
kit.size(field, document.body.clientWidth/2, document.body.clientHeight)
|
kit.size(output, document.body.clientWidth/2, document.body.clientHeight)
|
||||||
},
|
},
|
||||||
}, function(event, type) {
|
}, function(event, type) {last = null
|
||||||
kit.Selector(list, "tr", function(item, index) {
|
kit.Selector(list, "tr", function(item, index) {
|
||||||
index == 0 || type == "all" || kit.classList.has(item, type)?
|
type == "all" || kit.classList.has(item, type)?
|
||||||
kit.classList.del(item, "hide"): kit.classList.add(item, "hide")
|
(kit.classList.del(item, "hide"), last = item): kit.classList.add(item, "hide")
|
||||||
})
|
})
|
||||||
|
field.Pane.Head()
|
||||||
}),
|
}),
|
||||||
Choice: ["关闭", "all", "event", "run", "key"],
|
Choice: ["关闭", "all", "event", "run", "key"],
|
||||||
Button: ["关闭", "最大", "最小", "左边", "右边"],
|
Button: ["关闭", "最大", "最小", "左边", "右边"],
|
||||||
@ -545,9 +567,13 @@ function Page(page) {
|
|||||||
var state = {title: "<a href='mailto:shylinux@163.com'>shylinux@163.com</>"}, list = [], cb = function(event, item, value) {}
|
var state = {title: "<a href='mailto:shylinux@163.com'>shylinux@163.com</>"}, list = [], cb = function(event, item, value) {}
|
||||||
var ui = kit.AppendChilds(output, [
|
var ui = kit.AppendChilds(output, [
|
||||||
{"view": ["title", "div", state.title]},
|
{"view": ["title", "div", state.title]},
|
||||||
{"view": ["magic"], list: [{label: "0", name: "count"}, {input: ["magic", function(event) {
|
{"view": ["state"]},
|
||||||
|
{"view": ["magic"], list: [{label: "0", name: "count"}, {input: ["magics", function(event) {
|
||||||
if (event.key == "Enter" || event.ctrlKey && event.key == "j") {
|
if (event.key == "Enter" || event.ctrlKey && event.key == "j") {
|
||||||
page.action.Pane.Core(event, {}, ["_cmd", event.target.value]);
|
page.action.Pane.Core(event, {}, ["_cmd", event.target.value], function(msg) {
|
||||||
|
page.toast.Pane.Show(JSON.stringify(msg.result), event.target.value)
|
||||||
|
});
|
||||||
|
|
||||||
(ui.magic.History.length == 0 || ui.magic.History[ui.magic.History.length-1] != event.target.value) && ui.magic.History.push(event.target.value)
|
(ui.magic.History.length == 0 || ui.magic.History[ui.magic.History.length-1] != event.target.value) && ui.magic.History.push(event.target.value)
|
||||||
ui.magic.Current = ui.magic.History.length
|
ui.magic.Current = ui.magic.History.length
|
||||||
ui.count.innerHTML = ui.magic.Current
|
ui.count.innerHTML = ui.magic.Current
|
||||||
@ -567,13 +593,12 @@ function Page(page) {
|
|||||||
ui.count.innerHTML = ui.magic.Current || 0
|
ui.count.innerHTML = ui.magic.Current || 0
|
||||||
field.Pane.Show()
|
field.Pane.Show()
|
||||||
}]}]},
|
}]}]},
|
||||||
{"view": ["state"]},
|
|
||||||
])
|
])
|
||||||
|
|
||||||
ui.magic.History = []
|
ui.magic.History = []
|
||||||
|
|
||||||
return {
|
return {
|
||||||
Select: function() {ui.magic.focus()},
|
Select: function() {ui.magics.focus()},
|
||||||
Order: function(value, order, cbs) {
|
Order: function(value, order, cbs) {
|
||||||
state = value, list = order, cb = cbs || cb, field.Pane.Show()
|
state = value, list = order, cb = cbs || cb, field.Pane.Show()
|
||||||
},
|
},
|
||||||
@ -583,10 +608,10 @@ function Page(page) {
|
|||||||
},
|
},
|
||||||
Size: function(width, height) {
|
Size: function(width, height) {
|
||||||
kit.size(field, width, height)
|
kit.size(field, width, height)
|
||||||
ui && kit.size(ui.magic, (width - ui.count.offsetWidth - ui.first.offsetWidth - ui.last.offsetWidth - 20), height-6)
|
ui && kit.size(ui.magics, (width - ui.count.offsetWidth - ui.first.offsetWidth - ui.state.offsetWidth - 40), height-6)
|
||||||
},
|
},
|
||||||
Show: function() {
|
Show: function() {
|
||||||
kit.AppendChilds(ui.last, list.map(function(item) {return {text: [item+":"+state[item], "div"], click: function(item) {
|
kit.AppendChilds(ui.state, list.map(function(item) {return {text: [item+":"+state[item], "div"], click: function(item) {
|
||||||
cb(event, item, state[item])
|
cb(event, item, state[item])
|
||||||
}}}))
|
}}}))
|
||||||
field.Pane.Size(field.clientWidth, field.clientHeight)
|
field.Pane.Size(field.clientWidth, field.clientHeight)
|
||||||
@ -638,12 +663,25 @@ function Pane(page, field) {
|
|||||||
page.script("record", [name, line[key[0]]])
|
page.script("record", [name, line[key[0]]])
|
||||||
kit._call(cb, [line, index, event])
|
kit._call(cb, [line, index, event])
|
||||||
}
|
}
|
||||||
|
|
||||||
if (type == "plugin" && line.name || type == "field") {
|
if (type == "plugin" && line.name || type == "field") {
|
||||||
|
ui.item.ondragstart = function(event) {
|
||||||
|
event.stopPropagation()
|
||||||
|
event.dataTransfer.setData("item", event.target.id)
|
||||||
|
}
|
||||||
|
ui.item.ondragover = function(event) {
|
||||||
|
ui.item.Plugin && ui.item.Plugin.Select()
|
||||||
|
}
|
||||||
|
ui.item.ondrop = function(event) {
|
||||||
|
event.stopPropagation()
|
||||||
|
var item = pane[event.dataTransfer.getData("item")]
|
||||||
|
output.insertBefore(item, event.target)
|
||||||
|
}
|
||||||
|
|
||||||
page.Require(line.init? line.group+"/"+line.init: "", function(init) {
|
page.Require(line.init? line.group+"/"+line.init: "", function(init) {
|
||||||
page.Require(line.view? line.group+"/"+line.view: "", function(view) {
|
page.Require(line.view? line.group+"/"+line.view: "", function(view) {
|
||||||
pane.Plugin(page, pane, ui.item, init, function(event, cmds, cbs) {
|
pane.Plugin(page, pane, ui.item, init, function(event, cmds, cbs) {
|
||||||
kit._call(cb, [line, index, event, cmds, cbs])
|
cb? kit._call(cb, [line, index, event, cmds, cbs]):
|
||||||
|
kit._call(pane.Core, [event, line, cmds, cbs])
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
@ -713,23 +751,30 @@ function Pane(page, field) {
|
|||||||
}
|
}
|
||||||
return text
|
return text
|
||||||
},
|
},
|
||||||
Jshy: function(event, args) {var msg = ctx.Event(event)
|
Jshy: shy("本地命令", function(event, args) {var msg = ctx.Event(event)
|
||||||
|
if (kit.isNone(args) || args.length == 0) {
|
||||||
|
return kit.classList.has(field, "dialog") && pane.Show() || pane.Zone("show", args[0])
|
||||||
|
}
|
||||||
|
|
||||||
|
// 插件命令
|
||||||
if (pane[args[0]] && pane[args[0]].type == "fieldset") {
|
if (pane[args[0]] && pane[args[0]].type == "fieldset") {
|
||||||
msg.result = ["plugin", args[0]]
|
return pane[args[0]].Plugin.Jshy(event, args.slice(1)) || pane.Zone("plugin", args[0])
|
||||||
pane[args[0]].scrollIntoView(), pane[args[0]].Plugin.Select(true)
|
|
||||||
return pane[args[0]].Plugin.Jshy(event, args.slice(1))
|
|
||||||
}
|
}
|
||||||
|
// 控件命令
|
||||||
if (typeof pane.Action[args[0]] == "function") {
|
if (typeof pane.Action[args[0]] == "function") {
|
||||||
msg.result = ["action", args[0]]
|
return kit._call(pane.Action[args[0]], [event, args[0]]) || pane.Zone("action", args[0])
|
||||||
return kit._call(pane.Action[args[0]], [event, args[0]])
|
|
||||||
}
|
}
|
||||||
if (member[args[0]] != undefined) {
|
// 列表命令
|
||||||
msg.result = ["item", args[0]]
|
var list = kit.Selector(output, itemkey, function(item) {
|
||||||
pane.Select(member[args[0]].index, member[args[0]].key)
|
if (item.Meta.key == args[0] || item.Meta.name == args[0]) {return item}
|
||||||
return true
|
})
|
||||||
}
|
if (list.length > 0) {list[0].click(); return pane.Zone("select", args[0])}
|
||||||
return typeof pane[args[0]] == "function" && kit._call(pane[args[0]], args.slice(1))
|
|
||||||
},
|
// 内部命令
|
||||||
|
if (typeof pane[args[0]] == "function") {
|
||||||
|
return kit._call(pane[args[0]], args.slice(1)) || pane.Zone("function", args[0])
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
|
||||||
Tickers: shy("定时刷新", function(time, cmds, cb) {
|
Tickers: shy("定时刷新", function(time, cmds, cb) {
|
||||||
pane.Ticker(time, cmds, function(msg) {msg.Table(function(line, index) {
|
pane.Ticker(time, cmds, function(msg) {msg.Table(function(line, index) {
|
||||||
@ -759,6 +804,178 @@ function Pane(page, field) {
|
|||||||
} else if (typeof pane[value] == "function") {
|
} else if (typeof pane[value] == "function") {
|
||||||
kit._call(pane[value], [event, value])
|
kit._call(pane[value], [event, value])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (page.Action && page.Action.meta && typeof page.Action.meta[value] == "function") {
|
||||||
|
kit._call(page.Action.meta[value], [event, value])
|
||||||
|
} else if (page.Action && typeof page.Action[value] == "function") {
|
||||||
|
kit._call(page.Action[value], [event, value])
|
||||||
|
} else if (typeof page.Action == "function") {
|
||||||
|
kit._call(page.Action, [event, value])
|
||||||
|
} else if (typeof page[value] == "function") {
|
||||||
|
kit._call(page[value], [event, value])
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
Tutor: function() {var pane = field.Pane
|
||||||
|
var event = window.event
|
||||||
|
function loop(list, index) {
|
||||||
|
if (index >= list.length) {return}
|
||||||
|
kit.Log(index, list[index])
|
||||||
|
pane.Core(event, {}, ["_cmd", list[index]])
|
||||||
|
setTimeout(function() {loop(list, index+1)}, 1000)
|
||||||
|
}
|
||||||
|
loop([
|
||||||
|
"聊天", "help", "最高", "最大", "聊天",
|
||||||
|
"工作", "串行", "清空", "并行", "help storm", "help storm list", "help action", "help action list",
|
||||||
|
"聊天", "help target", "help target list",
|
||||||
|
], 0)
|
||||||
|
},
|
||||||
|
Core: shy("命令分发", {
|
||||||
|
wssid: function(id) {return id && (page.wssid = id)},
|
||||||
|
}, function(event, line, args, cbs) {var msg = pane.Event(event), meta = arguments.callee.meta
|
||||||
|
if (kit.isNone(args)) {return}
|
||||||
|
var plugin = event.Plugin || page.plugin && page.plugin.Plugin || {}, engine = {
|
||||||
|
share: function(args) {
|
||||||
|
return ctx.Share({"group": option.dataset.group, "names": option.dataset.names, "cmds": [
|
||||||
|
line.river, line.storm, line.action, args[1]||"",
|
||||||
|
]})
|
||||||
|
},
|
||||||
|
pwd: function(name, value) {
|
||||||
|
name && kit.Selector(page.action, "fieldset.item."+name, function(item) {
|
||||||
|
item.Plugin.Select()
|
||||||
|
})
|
||||||
|
if (value) {return engine.set(value)}
|
||||||
|
return [page.river.Pane.which.get(), page.storm.Pane.which.get(), page.plugin && page.plugin.Meta.name, page.input && page.input.name, page.input && page.input.value]
|
||||||
|
},
|
||||||
|
set: function(value, name) {
|
||||||
|
try {
|
||||||
|
if (value == undefined) {
|
||||||
|
msg.append = ["name", "value"]
|
||||||
|
msg.name = [], msg.value = []
|
||||||
|
return kit.Selector(page.plugin, ".args", function(item) {
|
||||||
|
msg.Push("name", item.name)
|
||||||
|
msg.Push("value", item.value)
|
||||||
|
return item.name+":"+item.value
|
||||||
|
})
|
||||||
|
|
||||||
|
} else if (name == undefined) {
|
||||||
|
kit.Selector(page.plugin, "input[type=button]", function(item) {
|
||||||
|
if (item.value == value) {item.click(); return value}
|
||||||
|
}).length > 0 || (page.action.Pane.Action[value]?
|
||||||
|
page.action.Pane.Action[value](event, value): (page.input.value = value))
|
||||||
|
} else {
|
||||||
|
page.plugin.Plugin.Inputs[name].value = value
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
engine._cmd("_cmd", [value, name])
|
||||||
|
}
|
||||||
|
},
|
||||||
|
dir: function(rid, sid, pid, uid) {
|
||||||
|
if (!rid) {
|
||||||
|
return kit.Selector(page.river, "div.output>div.item>div.text>span", function(item) {
|
||||||
|
return item.innerText
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if (!sid) {
|
||||||
|
return kit.Selector(page.storm, "div.output>div.item>div.text>span", function(item) {
|
||||||
|
return item.innerText
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if (!pid) {
|
||||||
|
return kit.Selector(page.action, "fieldset.item>legend", function(item) {
|
||||||
|
msg.Push("name", item.parentNode.Meta.name)
|
||||||
|
msg.Push("help", item.parentNode.Meta.help)
|
||||||
|
return item.innerText
|
||||||
|
})
|
||||||
|
}
|
||||||
|
if (!uid) {
|
||||||
|
return kit.Selector(page.plugin, "input", function(item) {
|
||||||
|
msg.Push("name", item.name)
|
||||||
|
msg.Push("value", item.value)
|
||||||
|
return item.name+":"+item.value
|
||||||
|
})
|
||||||
|
}
|
||||||
|
return [river, storm, page.plugin && page.plugin.Meta.name, page.input && page.input.name]
|
||||||
|
},
|
||||||
|
echo: function(one, two) {
|
||||||
|
kit.Log(one, two)
|
||||||
|
},
|
||||||
|
helps: function() {
|
||||||
|
engine.help("river")
|
||||||
|
engine.help("action")
|
||||||
|
engine.help("storm")
|
||||||
|
},
|
||||||
|
help: function() {
|
||||||
|
var args = kit.List(arguments), cb, target
|
||||||
|
if (args.length > 0 && page.pane && page.pane.Pane[args[0]] && page.pane.Pane[args[0]].Plugin) {
|
||||||
|
cb = page.pane.Pane[args[0]].Plugin.Help, target = page.pane.Pane[args[0]], args = args.slice(1)
|
||||||
|
} else if (args.length > 1 && page[args[0]] && page[args[0]].Pane[args[1]]) {
|
||||||
|
cb = page[args[0]].Pane[args[1]].Plugin.Help, target = page[args[0]].Pane[args[1]], args = args.slice(2)
|
||||||
|
} else if (args.length > 0 && page[args[0]]) {
|
||||||
|
cb = page[args[0]].Pane.Help, target = page[args[0]], args = args.slice(1)
|
||||||
|
} else {
|
||||||
|
cb = page.Help, target = document.body, args
|
||||||
|
}
|
||||||
|
|
||||||
|
if (kit.Selector(target, "div.Help", function(help) {
|
||||||
|
target.removeChild(help)
|
||||||
|
return help
|
||||||
|
}).length > 0) {return}
|
||||||
|
|
||||||
|
var text = kit._call(cb, args)
|
||||||
|
var ui = kit.AppendChild(target, [{view: ["Help"], list: [{text: [text.join(""), "div"]}]}])
|
||||||
|
setTimeout(function() {target.removeChild(ui.last)}, 30000)
|
||||||
|
},
|
||||||
|
_split: function(str) {return str.trim().split(" ")},
|
||||||
|
_cmd: function(arg) {
|
||||||
|
var args = typeof arg[1] == "string"? engine._split(arg[1]): arg[1];
|
||||||
|
kit.Log(["cmd"].concat(args))
|
||||||
|
page.script("record", args)
|
||||||
|
|
||||||
|
if (typeof meta[args[0]] == "function") {
|
||||||
|
return kit._call(meta[args[0]], args.slice(1))
|
||||||
|
}
|
||||||
|
if (typeof engine[args[0]] == "function") {
|
||||||
|
return kit._call(engine[args[0]], args.slice(1))
|
||||||
|
}
|
||||||
|
|
||||||
|
// if (page.output && typeof page.output.Output[args[0]] == "function") {
|
||||||
|
// return kit._call(page.output.Output[args[0]], args.slice(1))
|
||||||
|
// }
|
||||||
|
// if (page.input && typeof page.input.Input[args[0]] == "function") {
|
||||||
|
// return kit._call(page.input.Input[args[0]], args.slice(1))
|
||||||
|
// }
|
||||||
|
if (page.plugin && typeof page.plugin.Plugin[args[0]] == "function") {
|
||||||
|
return kit._call(page.plugin.Plugin[args[0]], args.slice(1))
|
||||||
|
}
|
||||||
|
|
||||||
|
if (page.dialog && (res = page.dialog.Pane.Jshy(event, args))) {return res}
|
||||||
|
if (page.pane && (res = page.pane.Pane.Jshy(event, args))) {return res}
|
||||||
|
if (page.action && (res = page.action.Pane.Jshy(event, args))) {return res}
|
||||||
|
if (page.storm && (res = page.storm.Pane.Jshy(event, args))) {return res}
|
||||||
|
if (page.river && (res = page.river.Pane.Jshy(event, args))) {return res}
|
||||||
|
|
||||||
|
if (page && (res = page.Jshy(event, args))) {return res}
|
||||||
|
|
||||||
|
if (page.plugin && (res = page.plugin.Plugin.Jshy(event, args))) {return res}
|
||||||
|
return kit.Log(["warn", "not", "find"].concat(args))
|
||||||
|
},
|
||||||
|
_msg: function(msg) {
|
||||||
|
event.ctrlKey? kit._call(page.target.Pane.Send, msg.Format()):
|
||||||
|
event.shiftKey && page.target.Pane.Send("field", plugin.Reveal())
|
||||||
|
kit._call(cbs, [msg])
|
||||||
|
},
|
||||||
|
_run: function(msg) {
|
||||||
|
var meta = plugin && plugin.target && plugin.target.Meta || {}
|
||||||
|
pane.Run(event, [meta.river, meta.storm, meta.action].concat(args), function(msg) {
|
||||||
|
kit._call(cbs, [msg]), engine._msg(msg)
|
||||||
|
})
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
page.footer.Pane.State("ncmd", kit.History("cmd", -1, args))
|
||||||
|
return args.length > 0 && meta[args[0]]? kit._call(cbs, [msg.Echo(meta[args[0]](args))]):
|
||||||
|
args.length > 0 && engine[args[0]]? kit._call(cbs, [msg.Echo(engine[args[0]](args))]):
|
||||||
|
event.shiftKey? engine._msg(msg): engine._run(msg)
|
||||||
}),
|
}),
|
||||||
Runs: shy("执行命令", function(event, cmds, cb) {
|
Runs: shy("执行命令", function(event, cmds, cb) {
|
||||||
pane.Run(event, cmds, function(msg) {msg.Table(function(line, index) {
|
pane.Run(event, cmds, function(msg) {msg.Table(function(line, index) {
|
||||||
@ -771,6 +988,13 @@ function Pane(page, field) {
|
|||||||
}),
|
}),
|
||||||
|
|
||||||
onaction: shy("事件列表", {
|
onaction: shy("事件列表", {
|
||||||
|
ondragover: function(event) {
|
||||||
|
event.preventDefault()
|
||||||
|
},
|
||||||
|
ondrop: function(event) {
|
||||||
|
event.preventDefault()
|
||||||
|
console.log(event.dataTransfer.getData("index"), "drop")
|
||||||
|
},
|
||||||
oncontextmenu: function(event) {
|
oncontextmenu: function(event) {
|
||||||
pane.Choice && page.carte.Pane.Show(event, shy({}, pane.Choice, function(value, meta, event) {
|
pane.Choice && page.carte.Pane.Show(event, shy({}, pane.Choice, function(value, meta, event) {
|
||||||
pane.Check(event, value)
|
pane.Check(event, value)
|
||||||
@ -798,7 +1022,7 @@ function Plugin(page, pane, field, inits, runs) {
|
|||||||
var feature = JSON.parse(meta.feature||'{}')
|
var feature = JSON.parse(meta.feature||'{}')
|
||||||
kit.classList.add(field, meta.group, name, feature.style)
|
kit.classList.add(field, meta.group, name, feature.style)
|
||||||
|
|
||||||
var plugin = Meta(pane.Zone(name), field, inits && inits(field, option, output) || {}, {Inputs: {},
|
var plugin = Meta(pane.Zone(name), field, inits && inits(field, option, output) || {}, {Inputs: {}, Outputs: {},
|
||||||
Appends: shy("添加控件", function(inputs) {
|
Appends: shy("添加控件", function(inputs) {
|
||||||
if (inputs) {return inputs.map(function(item) {plugin.Append(item)})}
|
if (inputs) {return inputs.map(function(item) {plugin.Append(item)})}
|
||||||
|
|
||||||
@ -835,6 +1059,8 @@ function Plugin(page, pane, field, inits, runs) {
|
|||||||
page.plugin = field, kit.classList.add(field, "select")
|
page.plugin = field, kit.classList.add(field, "select")
|
||||||
pane.which.set(name)
|
pane.which.set(name)
|
||||||
|
|
||||||
|
if (kit.isNone(target)) {return}
|
||||||
|
|
||||||
page.input = target || option.querySelectorAll("input")[1]
|
page.input = target || option.querySelectorAll("input")[1]
|
||||||
plugin.which.set(page.input.name)
|
plugin.which.set(page.input.name)
|
||||||
page.input.focus()
|
page.input.focus()
|
||||||
@ -893,15 +1119,21 @@ function Plugin(page, pane, field, inits, runs) {
|
|||||||
return text
|
return text
|
||||||
},
|
},
|
||||||
Jshy: function(event, args) {
|
Jshy: function(event, args) {
|
||||||
|
plugin.Select(), field.scrollIntoView()
|
||||||
|
// 显示命令
|
||||||
|
if (plugin.Outputs[args[0]]) {
|
||||||
|
return plugin.Outputs[args[0]].Output.Jshy(event, args.slice(1)) || plugin.Zone("output", args[0])
|
||||||
|
}
|
||||||
|
// 控件命令
|
||||||
|
if (plugin.Inputs[args[0]]) {
|
||||||
|
return plugin.Inputs[args[0]].Input.Jshy(event, args.slice(1)) || plugin.Zone("input", args[0])
|
||||||
|
}
|
||||||
|
// 内部命令
|
||||||
if (typeof plugin[args[0]] == "function") {
|
if (typeof plugin[args[0]] == "function") {
|
||||||
return kit._call(plugin[args[0]], args.slice(1))
|
return kit._call(plugin[args[0]], args.slice(1)) || plugin.Zone("function", args[0])
|
||||||
}
|
}
|
||||||
if (args.length > 0) {
|
// 远程命令
|
||||||
kit.Selector(option, ".args", function(item, index) {
|
return kit._call(plugin.Runs, [event]) || plugin.Zone("remote", args[0])
|
||||||
index < args.length && (item.value = args[index])
|
|
||||||
})
|
|
||||||
}
|
|
||||||
return kit._call(plugin.Runs, [event])
|
|
||||||
},
|
},
|
||||||
|
|
||||||
ontoast: function() {kit._call(page.toast.Pane.Show, arguments)},
|
ontoast: function() {kit._call(page.toast.Pane.Show, arguments)},
|
||||||
@ -994,6 +1226,15 @@ function Inputs(plugin, meta, item, target) {
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
Jshy: function(event, args) {
|
||||||
|
// 内部命令
|
||||||
|
if (typeof plugin[args[0]] == "function") {
|
||||||
|
return kit._call(plugin[args[0]], args.slice(1)) || plugin.Zone("function", args[0])
|
||||||
|
}
|
||||||
|
// 内部命令
|
||||||
|
return (target.value = args[0]) || plugin.Zone("value", args[0])
|
||||||
|
},
|
||||||
|
|
||||||
upload: function(event) {
|
upload: function(event) {
|
||||||
ctx.Upload({river: meta.river, table: plugin.Option("table")}, option.upload.files[0], function(event, msg) {
|
ctx.Upload({river: meta.river, table: plugin.Option("table")}, option.upload.files[0], function(event, msg) {
|
||||||
Output(plugin, "table", msg, null, output, option)
|
Output(plugin, "table", msg, null, output, option)
|
||||||
@ -1112,11 +1353,11 @@ function Inputs(plugin, meta, item, target) {
|
|||||||
|
|
||||||
input.onimport()
|
input.onimport()
|
||||||
target.value = input.onformat(item.init, item.value)
|
target.value = input.onformat(item.init, item.value)
|
||||||
plugin.Inputs[item.name] = target, target.Input = input
|
type == "text" && !target.placeholder && (target.placeholder = item.name)
|
||||||
type == "text" && !target.placeholder && item.name && (target.placeholder = item.name)
|
type == "text" && !target.title && (target.title = item.placeholder || item.name || "")
|
||||||
!target.title && item.placeholder && (target.title = item.placeholder)
|
|
||||||
kit.Log("init", "input", plug+"."+name, input)
|
kit.Log("init", "input", input.Zones(), input)
|
||||||
return input
|
return plugin.Inputs[item.name] = target, target.Input = input
|
||||||
}
|
}
|
||||||
function Output(plugin, type, msg, cb, target, option) {
|
function Output(plugin, type, msg, cb, target, option) {
|
||||||
var exports = plugin.target.Meta.exports
|
var exports = plugin.target.Meta.exports
|
||||||
@ -1125,6 +1366,15 @@ function Output(plugin, type, msg, cb, target, option) {
|
|||||||
_canvas: function() {plugin.onfigure("canvas")},
|
_canvas: function() {plugin.onfigure("canvas")},
|
||||||
clear: function() {target.innerHTML = ""},
|
clear: function() {target.innerHTML = ""},
|
||||||
|
|
||||||
|
Jshy: function(event, args) {
|
||||||
|
// 内部命令
|
||||||
|
if (typeof plugin[args[0]] == "function") {
|
||||||
|
return kit._call(plugin[args[0]], args.slice(1)) || plugin.Zone("function", args[0])
|
||||||
|
}
|
||||||
|
// 内部命令
|
||||||
|
return (target.value = args[0]) || plugin.Zone("value", args[0])
|
||||||
|
},
|
||||||
|
|
||||||
Download: function() {
|
Download: function() {
|
||||||
var type = ".csv", text = kit.Selector(output, "tr", function(tr) {
|
var type = ".csv", text = kit.Selector(output, "tr", function(tr) {
|
||||||
return kit.Selector(tr, "td,th", function(td) {
|
return kit.Selector(tr, "td,th", function(td) {
|
||||||
@ -1213,5 +1463,7 @@ function Output(plugin, type, msg, cb, target, option) {
|
|||||||
}, function(event, key, cb) {cb(event)}),
|
}, function(event, key, cb) {cb(event)}),
|
||||||
}, plugin)
|
}, plugin)
|
||||||
output.onimport(type, msg, cb)
|
output.onimport(type, msg, cb)
|
||||||
return target.Output = output
|
|
||||||
|
kit.Log("init", "output", output.Zones(), output)
|
||||||
|
return plugin.Outputs[type] = target, target.Output = output
|
||||||
}
|
}
|
||||||
|
@ -317,7 +317,9 @@ kit = toolkit = (function() {var kit = {__proto__: document,
|
|||||||
return table
|
return table
|
||||||
},
|
},
|
||||||
RangeTable: function(table, index, sort_asc) {
|
RangeTable: function(table, index, sort_asc) {
|
||||||
var list = kit.Selector(table, "tr").slice(1)
|
var list = kit.Selector(table, "tr", function(tr) {
|
||||||
|
return tr.style.display == "none" || kit.classList.has(tr, "hide")? null: tr
|
||||||
|
}).slice(1)
|
||||||
|
|
||||||
var is_time = true, is_number = true
|
var is_time = true, is_number = true
|
||||||
kit.List(list, function(tr) {
|
kit.List(list, function(tr) {
|
||||||
@ -343,8 +345,9 @@ kit = toolkit = (function() {var kit = {__proto__: document,
|
|||||||
list[j] = temp
|
list[j] = temp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
list[i].parentElement && list[i].parentElement.removeChild(list[i])
|
var tbody = list[i].parentElement
|
||||||
table.appendChild(list[i])
|
list[i].parentElement && tbody.removeChild(list[i])
|
||||||
|
tbody.appendChild(list[i])
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
OrderTable: function(table, field, cb) {if (!table) {return}
|
OrderTable: function(table, field, cb) {if (!table) {return}
|
||||||
@ -502,7 +505,7 @@ kit = toolkit = (function() {var kit = {__proto__: document,
|
|||||||
}
|
}
|
||||||
return list
|
return list
|
||||||
},
|
},
|
||||||
Opacity: function(obj, interval, list) {
|
Opacity: function(obj, interval, list) {
|
||||||
kit.List(kit.Value(list, [0, 0.2, 0.4, 0.6, 1.0]), function(value) {
|
kit.List(kit.Value(list, [0, 0.2, 0.4, 0.6, 1.0]), function(value) {
|
||||||
obj.style.opacity = value
|
obj.style.opacity = value
|
||||||
}, kit.Value(interval, 150))
|
}, kit.Value(interval, 150))
|
||||||
@ -534,7 +537,7 @@ kit = toolkit = (function() {var kit = {__proto__: document,
|
|||||||
s = s.replace(/\033\[m/g, "</span>")
|
s = s.replace(/\033\[m/g, "</span>")
|
||||||
return s
|
return s
|
||||||
},
|
},
|
||||||
Value: function() {
|
Value: function() {
|
||||||
for (var i = 0; i < arguments.length; i++) {
|
for (var i = 0; i < arguments.length; i++) {
|
||||||
switch (arguments[i]) {
|
switch (arguments[i]) {
|
||||||
case undefined:
|
case undefined:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user