mirror of
https://shylinux.com/x/volcanos
synced 2025-04-26 01:04:06 +08:00
opt feel
This commit is contained in:
parent
9198f0e1ae
commit
2f83d52087
2
frame.js
2
frame.js
@ -344,7 +344,7 @@ Volcanos("onappend", {help: "渲染引擎", list: [], _init: function(can, meta,
|
||||
can._msg = msg
|
||||
if (can.core.CallFunc([sub, "onimport._process"], [sub, msg, cmds, cb])) { return }
|
||||
if (can.core.CallFunc([can, "onimport._process"], [can, msg, cmds, cb])) { return }
|
||||
if (can.base.isFunc(cb) && cb(msg)) { return }
|
||||
if (can.base.isFunc(cb) && can.core.CallFunc(cb, {can: can, msg: msg})) { return }
|
||||
if (silent) { return }
|
||||
|
||||
var display = msg.Option("_display") || meta.display || meta.feature.display || "/plugin/table.js"
|
||||
|
@ -1,6 +1,5 @@
|
||||
Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg, list, cb, target) {
|
||||
can.path = can.request(), can.list = []
|
||||
msg.Table(function(value) { if (value.path.indexOf("/local") == 0) { return }
|
||||
can.path = can.request(), can.list = [], msg.Table(function(value) {
|
||||
value.path.endsWith("/")? can.path.Push(value): can.list.push(value)
|
||||
})
|
||||
|
||||
@ -9,19 +8,20 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
can.onappend.table(can, can.path, null, can.ui.content)
|
||||
can.base.isFunc(cb) && cb(msg)
|
||||
|
||||
var feature = can.Conf("feature") || {}
|
||||
can.Action("倍速", can.rate = parseInt(msg.Option("rate"))||feature["rate"]||1)
|
||||
can.Action("起始", can.begin = parseInt(msg.Option("begin"))||feature["begin"]||0)
|
||||
can.Action("数量", can.limit = parseInt(msg.Option("limit"))||feature["limit"]||6)
|
||||
can.Action("高度", can.height = parseInt(msg.Option("height"))||feature["height"]||100)
|
||||
can.Option("path") != "最近/" && can.onimport._page(can, can.list, can.begin, can.limit)
|
||||
can.Action("rate", msg.Option("rate")||"1")
|
||||
can.Action("begin", msg.Option("begin")||"0")
|
||||
can.Action("limit", msg.Option("limit")||"6")
|
||||
can.Action("height", msg.Option("height")||"100")
|
||||
can.Option("path") != "最近/" && can.onimport._page(can, can.list)
|
||||
},
|
||||
_page: function(can, list, begin, limit) { can.onmotion.clear(can, can.ui.content)
|
||||
begin = parseInt(begin||can.Action("begin"))
|
||||
limit = parseInt(limit||can.Action("limit"))
|
||||
for (var i = begin; i < begin+limit; i++) { list && list[i] && can.onimport.file(can, list[i].path, i) }
|
||||
can.Status("begin", begin), can.Status("limit", limit), can.Status("total", can.list.length)
|
||||
can.Status({begin: begin, limit: limit, total: can.list.length})
|
||||
},
|
||||
_file: function(can, path, index) { var p = location.href.indexOf("http") == 0? "": "http://localhost:9020"
|
||||
return path.indexOf("http") == 0? path: p+can.base.Path("/share/local", " "+(can._msg.Option("prefix")||""), path)
|
||||
return path.indexOf("http") == 0? path: p+can.base.Path("/share/local", can._msg.Option("dir_root")||"", path)
|
||||
},
|
||||
file: function(can, path, index) { path = can.onimport._file(can, path, index)
|
||||
var cb = can.onfigure[can.base.Ext(path)]; can.Status("file", path)
|
||||
@ -32,47 +32,15 @@ Volcanos("onfigure", {help: "组件菜单", list: [],
|
||||
png: function(can, path, index) { return can.onfigure.image(can, path, index) },
|
||||
jpg: function(can, path, index) { return can.onfigure.image(can, path, index) },
|
||||
jpeg: function(can, path, index) { return can.onfigure.image(can, path, index) },
|
||||
image: function(can, path, index) { return {img: path, height: can.height, onclick: function(event) {
|
||||
can.onappend._init(can, {type: "story feel float"}, [], function(sub) {
|
||||
sub.run = function(event, cmds, cb) { return can.run(event, cmds, cb, true) }
|
||||
|
||||
var header = sub.run({}, ["search", "Header.onexport.height"])
|
||||
var footer = sub.run({}, ["search", "Footer.onexport.height"])
|
||||
var river = sub.run({}, ["search", "River.onexport.width"])
|
||||
var height = window.innerHeight-header-footer
|
||||
|
||||
sub.page.Modify(sub, sub._target, {style: {left: river, top: header}})
|
||||
sub.page.Modify(sub, sub._output, {style: {"max-height": height}})
|
||||
|
||||
var order = index; function show(order) {
|
||||
path = can.onimport._file(can, can.list[order].path)
|
||||
sub.page.Appends(sub, sub._output, [{img: path, height: height-55}])
|
||||
sub.Status("位置", order+1+"/"+can.list.length), sub.Status("file", path)
|
||||
}; show(order)
|
||||
|
||||
sub.onappend._action(sub, ["关闭", "下载", "上一个", "下一个", "设置头像", "设置背景", "复制链接"], sub._action, {
|
||||
"关闭": function(event) { sub.page.Remove(sub, sub._target) },
|
||||
"下载": function(event) { can.user.download(can, path) },
|
||||
"上一个": function(event) { order > 0? show(--order): can.user.toast(can, "已经是第一张啦!") },
|
||||
"下一个": function(event) { order < can.list.length-1? show(++order): can.user.toast(can, "已经是最后一张啦!") },
|
||||
"设置头像": function(event) { var msg = can.request(event, {url: can.onimport._file(can, can.list[order].path)})
|
||||
sub.run(event, ["search", "Header.onimport.avatar"])
|
||||
},
|
||||
"设置背景": function(event) { var msg = can.request(event, {url: can.onimport._file(can, can.list[order].path)})
|
||||
sub.run(event, ["search", "Header.onimport.background"])
|
||||
},
|
||||
"复制链接": function(event) {
|
||||
can.user.copy(event, can, can.user.MergeURL(can, {_path: path}, true))
|
||||
},
|
||||
})
|
||||
}, document.body)
|
||||
image: function(can, path, index) { return {img: path, height: can.Action("height"), onclick: function(event) {
|
||||
can.ondetail._init(can, index)
|
||||
}, _init: function(target) { can.Status("file", path) },
|
||||
onmouseover: function(event) { can.Status("file", path) },
|
||||
} },
|
||||
|
||||
video: function(can, path) { var auto = true, loop = true, total = 0; function cb(event) { }
|
||||
return {type: "video", style: {height: can.height}, className: "preview",
|
||||
data: {src: path, controls: "controls", autoplay: auto, loop: loop, playbackRate: can.rate},
|
||||
return {type: "video", style: {height: parseInt(can.Action("height"))}, className: "preview",
|
||||
data: {src: path, controls: "controls", autoplay: auto, loop: loop, playbackRate: parseFloat(can.Action("rate"))},
|
||||
oncontextmenu: cb, onplay: cb, onpause: cb, onended: cb,
|
||||
onmouseover: function(event) { can.Status("file", path) },
|
||||
onloadedmetadata: function(event) { total = event.timeStamp
|
||||
@ -87,25 +55,29 @@ Volcanos("onfigure", {help: "组件菜单", list: [],
|
||||
mov: function(can, path) { return can.onfigure.video(can, path) },
|
||||
})
|
||||
Volcanos("onaction", {help: "组件菜单", list: [
|
||||
["数量", 1, 3, 6, 9, 12, 15],
|
||||
["高度", 100, 200, 400, 600, 800],
|
||||
["倍速", 0.1, 0.2, 0.5, 1, 2, 3, 5, 10],
|
||||
["limit", 1, 3, 6, 9, 12, 15],
|
||||
["begin", 0],
|
||||
["height", 100, 200, 400, 600, 800],
|
||||
["rate", 0.1, 0.2, 0.5, 1, 2, 3, 5, 10],
|
||||
],
|
||||
"上一页": function(event, can, key, value) {
|
||||
can.begin > 0 && (can.begin -= can.limit, can.onimport._page(can, can.list, can.begin, can.limit))
|
||||
"上一页": function(event, can, key, value) { var begin = parseInt(can.Action("begin"))
|
||||
begin > 0 && (can.Action("begin", begin - parseInt(can.Action("limit"))), can.onimport._page(can, can.list))
|
||||
},
|
||||
"下一页": function(event, can, key, value) {
|
||||
can.begin + can.limit < can.list.length && (can.begin += can.limit, can.onimport._page(can, can.list, can.begin, can.limit))
|
||||
"下一页": function(event, can, key, value) { var begin = parseInt(can.Action("begin"))
|
||||
begin + parseInt(can.Action("limit")) < can.list.length && (can.Action("begin", begin + parseInt(can.Action("limit")), can.onimport._page(can, can.list)))
|
||||
},
|
||||
|
||||
"数量": function(event, can, key, value) {
|
||||
can.limit = parseInt(value), can.onimport._page(can, can.list, can.begin, can.limit)
|
||||
"rate": function(event, can, key, value) {
|
||||
can.Action("rate", value), can.onimport._page(can, can.list)
|
||||
},
|
||||
"高度": function(event, can, key, value) {
|
||||
can.height = parseInt(value), can.onimport._page(can, can.list, can.begin, can.limit)
|
||||
"begin": function(event, can, key, value) {
|
||||
can.Action("begin", value), can.onimport._page(can, can.list)
|
||||
},
|
||||
"倍速": function(event, can, key, value) {
|
||||
can.rate = parseInt(value), can.onimport._page(can, can.list, can.begin, can.limit)
|
||||
"limit": function(event, can, key, value) {
|
||||
can.Action("limit", value), can.onimport._page(can, can.list)
|
||||
},
|
||||
"height": function(event, can, key, value) {
|
||||
can.Action("height", value), can.onimport._page(can, can.list)
|
||||
},
|
||||
|
||||
chooseImage: function(event, can) { var msg = can.request(event)
|
||||
@ -114,6 +86,39 @@ Volcanos("onaction", {help: "组件菜单", list: [
|
||||
}) })
|
||||
},
|
||||
})
|
||||
Volcanos("ondetail", {help: "组件菜单", list: ["关闭", "下载", "上一个", "下一个", "设置头像", "设置背景", "复制链接"], _init: function(can, index) {
|
||||
can.onappend._init(can, {type: "story feel float"}, [], function(sub) {
|
||||
sub.run = function(event, cmds, cb) { return can.run(event, cmds, cb, true) }
|
||||
can.sub = sub
|
||||
|
||||
sub.search(["Action.onexport.size"], function(msg, left, top, width, height) {
|
||||
sub.page.Modify(sub, sub._target, {style: {left: left, top: top}})
|
||||
sub.page.Modify(sub, sub._output, {style: {"max-width": width, "max-height": height}})
|
||||
|
||||
can.order = index, can.show = function(order) {
|
||||
path = can.onimport._file(can, can.list[order].path)
|
||||
sub.page.Appends(sub, sub._output, [{img: path, style: {"max-width": width-40, "max-height": height-55}}])
|
||||
sub.Status("begin", order+1+"/"+can.list.length), sub.Status("file", path)
|
||||
}, can.show(can.order)
|
||||
})
|
||||
|
||||
sub.onappend._action(can, can.ondetail.list, sub._action, can.ondetail)
|
||||
}, document.body)
|
||||
},
|
||||
"关闭": function(event, can) { can.page.Remove(can, can.sub._target) },
|
||||
"下载": function(event, can) { can.user.download(can, path = can.onimport._file(can, can.list[can.order].path)) },
|
||||
"上一个": function(event, can) { can.order > 0? can.show(--can.order): can.user.toast(can, "已经是第一张啦!") },
|
||||
"下一个": function(event, can) { can.order < can.list.length-1? can.show(++can.order): can.user.toast(can, "已经是最后一张啦!") },
|
||||
"设置头像": function(event, can) { var msg = can.request(event, {url: can.onimport._file(can, can.list[can.order].path)})
|
||||
can.run(event, ["search", "Header.onimport.avatar"])
|
||||
},
|
||||
"设置背景": function(event, can) { var msg = can.request(event, {url: can.onimport._file(can, can.list[can.order].path)})
|
||||
can.run(event, ["search", "Header.onimport.background"])
|
||||
},
|
||||
"复制链接": function(event, can) {
|
||||
can.user.copy(event, can, can.user.MergeURL(can, {_path: path}, true))
|
||||
},
|
||||
})
|
||||
Volcanos("onexport", {help: "导出数据", list: ["begin", "limit", "total", "position", "file"],
|
||||
position: function(can, index, total) { total = total || can.max
|
||||
return parseInt((index+1)*100/total)+"%"+" = "+(parseInt(index)+1)+"/"+parseInt(total)
|
||||
|
@ -114,3 +114,7 @@ fieldset.word.float h3 {
|
||||
text-align:center;
|
||||
}
|
||||
|
||||
fieldset.word video.story {
|
||||
max-height:320px;
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user