1
0
mirror of https://shylinux.com/x/volcanos synced 2025-04-25 08:48:06 +08:00

opt header

This commit is contained in:
harveyshao 2021-04-21 18:53:39 +08:00
parent ada341c213
commit 9285c9a171
7 changed files with 81 additions and 45 deletions

View File

@ -152,6 +152,9 @@ Volcanos("onengine", {help: "解析引擎", list: [], _init: function(can, meta,
"nfs": {name: "文件 nfs", index: [
"nfs.cat", "nfs.dir", "nfs.tail", "nfs.trash",
]},
"aaa": {name: "权限 aaa", index: [
"user", "sess", "role",
]},
}},
},
})
@ -892,5 +895,20 @@ Volcanos("onmotion", {help: "动态交互", list: [], _init: function(can, targe
}
}
},
downward: function(can, target, top, speed) {
var begin = target.offsetTop
var space = (top - begin) / 30
can.core.Timer({interval: speed||10, length: 30}, function() {
can.page.Modify(can, target, {style: {top: begin+=space}})
})
},
resize: function(can, target, width, speed) {
var begin = target.offsetWidth
var space = (width - begin) / 30
can.core.Timer({interval: speed||10, length: 30}, function() {
can.page.Modify(can, target, {style: {width: begin+=space}})
})
},
})

View File

@ -62,7 +62,7 @@ Volcanos("core", {help: "数据结构",
}
return res
}),
Timer: shy("定时器, value, [1,2,3,4], {value, length}", function(interval, cb, cbs) {
Timer: shy("定时器, value, [1,2,3,4], {interval, length}", function(interval, cb, cbs) {
interval = typeof interval == "object"? interval || []: [interval]
var timer = {stop: false}; function loop(timer, i) {
if (timer.stop || i >= interval.length && interval.length >= 0) {

View File

@ -133,7 +133,7 @@ Volcanos("user", {help: "用户模块", agent: {
var ui = can.page.Append(can, document.body, [{view: "carte", style: {left: x, top: y}, onmouseleave: function(event) {
can.page.Remove(can, ui.first)
}, list: can.core.List(list, function(item) {
return {view: "item", list: [typeof item == "string"? /* button */ {text: item, click: function(event) {
return {view: "item", list: [typeof item == "string"? /* button */ {text: can.user.trans(can, item), click: function(event) {
can.user.isMobile && can.page.Remove(can, ui.first)
typeof cb == "function" && cb(event, item, meta)
}}: item.args? /* input */ {text: item.name, click: function(event) {

View File

@ -228,7 +228,7 @@ div.carte {
background:#295b61;
color:white;
padding:4px;
z-index:100;
z-index:10;
}
div.carte div.item {
padding:3px 12px;
@ -306,7 +306,8 @@ fieldset>form.option>div.item.textarea {
fieldset div.action>div.item {
float:left; margin-right:3px;
height:28px; vertical-align:middle;
/* height:28px; */
vertical-align:middle;
}
fieldset div.action>div.item.space {
width:10px;

View File

@ -11,6 +11,8 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg)
sub._option.dataset = sub._option.dataset || {}
item.id && (sub._option.dataset.id = item.id)
})
}, function() {
can.onaction._layout(can, can.Conf("layout")||can.user.Search(can, "layout"))
})
},
_plugin: function(can, river, storm, sub, item) {
@ -91,7 +93,6 @@ Volcanos("onaction", {help: "交互操作", list: [], _init: function(can, msg,
!can.user.isMobile && can.run({}, ["search", "Header.onimport.menu", "action",
["布局", "默认布局", "流动布局", "网格布局", "标签布局", "自由布局"],
], function(event, key) { can.onaction._layout(can, key) })
can.onaction._layout(can, can.user.Search(can, "layout"))
},
_layout: function(can, key) { if (!key) { return }
var trans = {
@ -106,7 +107,7 @@ Volcanos("onaction", {help: "交互操作", list: [], _init: function(can, msg,
can.page.Modify(can, can._action, {className: "action "+key})
can.page.Modify(can, can._output, {className: "output "+key})
if (key == "标签布局") {
if (key == "tabs") {
can.onmotion.select(can, can._output, "fieldset.plugin", 0)
can.onmotion.select(can, can._action, "div.item", 0)
}

View File

@ -1,6 +1,9 @@
fieldset.Header {
height:32px; padding:0 5px;
z-index:1;
z-index:1000;
}
fieldset.Header>div.output {
z-index:1000;
}
fieldset.Header>div.output>div {
height:22px; padding:5px;
@ -20,8 +23,8 @@ fieldset.Header>div.output>div.search {
fieldset.Header>div.output>div.search>input {
width:120px;
}
fieldset.Header>div.output>div.search>input:focus {
width:240px;
fieldset.Header>div.output>div.search>input:hover {
/* width:240px; */
}
fieldset.Header>div.output>div.menus {
float:left; margin-left:5px;

View File

@ -2,14 +2,16 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
can._trans = {
"river": "菜单",
"search": "搜索",
"setting": "设置",
"black": "黑色主题",
"white": "白色主题",
"print": "打印主题",
"clear": "清除背景",
"pack": "打包页面",
"usernick": "昵称",
"logout": "退出",
"usernick": "修改昵称",
"logout": "退出登录",
}
can.onmotion.clear(can)
can.onimport._title(can, msg, target)
@ -19,6 +21,9 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
can.onimport._agent(can, msg, target)
can.onimport._menu(can, msg, target)
typeof cb == "function" && cb(msg)
can.page.Modify(can, can._output, {onmouseover: function(event) {
can.menu && can.page.Remove(can, can.menu.first)
}})
},
_title: function(can, msg, target) {
can.user.title(can.user.Search(can, "title")||can.user.Search(can, "pod"))
@ -30,29 +35,31 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
},
_state: function(can, msg, target) {
can.core.List(can.Conf("state")||["time", "username"], function(item) {
can.page.Append(can, target, [{view: ["state "+item, "div", (can.Conf(item)||"").slice(0, 10)], onclick: function(event) {
can.page.Append(can, target, [{view: ["state "+item, "div", (can.Conf(item)||"").slice(0, 10)], onmouseenter: function(event) {
can.core.CallFunc([can.onaction, item], [event, can, item])
}, _init: function(target) {
item == "time" && can.onimport._time(can, target)
}}])
})
},
_background: function(can, msg) {
!can.user.isLocalFile && can.onlayout.background(can, msg.Option("background"), document.body)
},
_search: function(can, msg, target) {
can.user.isMobile || (can.search = can.page.Append(can, target, [{view: "search", list: [{type: "input", data: {placeholder: "search"}, onkeydown: function(event) {
!can.user.isMobile && (can.search = can.page.Append(can, target, [{view: "search", list: [{type: "input", data: {placeholder: "search"}, onkeydown: function(event) {
can.onkeypop.input(event, can); switch (event.key) {
case "Enter": can.run(event, ["search", "Search.onimport.select", "*", event.target.value]); break
}
}, }], }]).input)
},
_daemon: function(can, name, cb) {
can.misc.WSS(can, {type: "chrome", name: name}, cb||function(event, msg, cmd, arg) {
msg && can.run(event, ["search"].concat(msg["detail"]||[]), function(msg) {
msg.Reply()
})
})
},
_background: function(can, msg) {
can.user.isLocalFile || can.onlayout.background(can, msg.Option("background"), document.body)
}, onfocus: function(event) {
can.onmotion.resize(can, event.target, 240, 10)
}, onmouseenter: function(event) {
can.onmotion.resize(can, event.target, 240, 10)
}, onmouseleave: function(event) {
can.onmotion.resize(can, event.target, 120, 5)
}, onblur: function(event) {
can.onmotion.resize(can, event.target, 120, 5)
},
}] }]).input)
},
_agent: function(can, msg, target) {
if (can.user.isMobile) {
@ -67,14 +74,20 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
can.user.isWeiXin && can.onimport._weixin(can)
},
_menu: function(can, msg, target) {
can.page.Append(can, target, can.core.List(can.user.isMobile || can.user.isExtension || can.user.Search(can, "pod")? ["river"]: ["setting"], function(item) {
return {view: ["menus", "div", item], onclick: function(event) {
can.onimport.menu(can, can.user.isMobile||can.user.isExtension||can.user.Search(can, "pod")? ["header", "river"]:
["header", ["setting", "black", "white", "print", "clear", "pack"]], function(event, item) {
can.core.CallFunc([can.onaction, item], [event, can, item])
}}
}))
})
},
_weixin: function(can, msg) { can.run({}, ["action", "wx"], function(msg) {
_daemon: function(can, name, cb) {
can.misc.WSS(can, {type: "chrome", name: name}, cb||function(event, msg, cmd, arg) {
msg && can.run(event, ["search"].concat(msg["detail"]||[]), function(msg) {
msg.Reply()
})
})
},
_weixin: function(can, msg) { can.run({}, ["action", "agent"], function(msg) {
can.require(["https://res.wx.qq.com/open/js/jweixin-1.6.0.js"], function(can) {
wx.config({debug: msg.Option("debug") == "true", jsApiList: can.core.Item({
scanQRCode: function(cb) { wx.scanQRCode({needResult: cb? 1: 0, scanType: ["qrCode","barCode"], success: function (res) {
@ -98,11 +111,11 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
})
}) })
},
_time: function(can, target) {
can.core.Timer({interval: 1000}, function() { can.onimport.time(can, target) })
can.onappend.figure(can, {style: {left: "", right: "0", top: can._target.offsetHeight, "min-width": 310}}, "@date", target)
},
time: function(can, target) { can.onlayout.topic(can)
target.innerHTML = can.base.Time(null, "%w %H:%M:%S")
},
@ -121,9 +134,8 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
}}
} else if (item.length > 0) {
return {view: ["menu", "div", item[0]], onclick: function(event) {
var ui = can.user.carte(event, can, can.onaction, item.slice(1), cb)
can.page.Modify(can, ui.first, {style: {top: can._target.offsetHeight}})
return {view: ["menu", "div", item[0]], onmouseenter: function(event) {
can.onaction.carte(event, can, item.slice(1), cb)
}}
} else if (typeof item == "object") {
@ -136,12 +148,17 @@ Volcanos("onaction", {help: "交互数据", list: [], _init: function(can, msg,
function init() { can.run({}, [], function(msg) {
can.Conf("username", msg.Option("user.nick")||msg.Option("user.name"))
can.onimport._init(can, msg, list, function(msg) {
can.onengine.listen(can, "storm.select", function(msg, river, storm) {
can.Conf("river", river), can.Conf("storm", storm)
})
can.run(msg._event, ["search", "Search.onaction._init"])
can.run(msg._event, ["search", "Action.onaction._init"])
can.run(msg._event, ["search", "River.onaction._init"])
can.run(msg._event, ["search", "Footer.onaction._init"])
typeof cb == "function" && cb(msg)
}, can._output)
can.page.Select(can, document.body, "fieldset.River", function(item) {
can.onmotion.toggle(can, item)
})
@ -150,11 +167,6 @@ Volcanos("onaction", {help: "交互数据", list: [], _init: function(can, msg,
can.onmotion.hidden(can, item)
})
can.onengine.listen(can, "storm.select", function(msg, river, storm) {
can.Conf("river", river), can.Conf("storm", storm)
})
can.onlayout.topic(can)
can.user.isLocalFile? init(): can.run({}, ["check"], function(msg) {
msg.Result()? init(): msg.Option("sso")? can.user.jumps(msg.Option("sso")): can.user.login(can, init)
@ -168,8 +180,7 @@ Volcanos("onaction", {help: "交互数据", list: [], _init: function(can, msg,
can.user.jumps(can.user.MergeURL(can, args, true))
},
username: function(event, can) {
var ui = can.user.carte(event, can, can.onaction, ["usernick", "logout"])
can.page.Modify(can, ui.first, {style: {top: can._target.offsetHeight}})
can.onaction.carte(event, can, ["usernick", "logout"])
},
usernick: function(event, can) {
can.user.input(event, can, [{_input: "text", name: "usernick", value: can.Conf("username")}], function(ev, button, data, list, args) {
@ -182,11 +193,7 @@ Volcanos("onaction", {help: "交互数据", list: [], _init: function(can, msg,
},
logout: function(event, can) { can.user.logout(can) },
river: function(event, can) { can.run(event, ["search", "River.onmotion.toggle"]) },
setting: function(event, can) {
var ui = can.user.carte(event, can, can.onaction, ["black", "white", "print", "clear", "pack"])
can.page.Modify(can, ui.first, {style: {top: can._target.offsetHeight}})
},
river: function(event, can) { can.onaction.River(can) },
black: function(event, can, button) { can.onlayout.topic(can, button) },
white: function(event, can, button) { can.onlayout.topic(can, button) },
print: function(event, can, button) { can.onlayout.topic(can, "white print") },
@ -209,6 +216,12 @@ Volcanos("onaction", {help: "交互数据", list: [], _init: function(can, msg,
})
})
},
carte: function(event, can, list, cb) {
can.menu && can.page.Remove(can, can.menu.first)
can.menu = can.user.carte(event, can, can.onaction, list, cb)
can.page.Modify(can, can.menu.first, {style: {top: -list.length*15, left: event.target.offsetLeft}})
can.onmotion.downward(can, can.menu.first, can._target.offsetHeight, 10-list.length)
},
River: function(can) { can.run({}, ["search", "River.onmotion.toggle"]) },
Footer: function(can) { can.run({}, ["search", "River.onmotion.autosize"]) },