mirror of
https://shylinux.com/x/volcanos
synced 2025-04-25 16:58:06 +08:00
opt miss
This commit is contained in:
parent
a26c236c29
commit
b800ce949a
3
frame.js
3
frame.js
@ -145,7 +145,7 @@ Volcanos("onappend", { _init: function(can, meta, list, cb, target, field) { met
|
||||
meta.feature = can.base.Obj(meta.feature, {})
|
||||
can.page.ClassList.add(can, field, meta.feature.style||"")
|
||||
|
||||
can.onappend._legend(can, legend)
|
||||
can.onappend._legend(sub, legend)
|
||||
if (can.user.Search(can, "share") && can.user.Search(can, "river") && can.user.Search(can, "storm")) {
|
||||
can.page.Select(can, field, "legend", function(item) { can.page.Remove(can, item) })
|
||||
}
|
||||
@ -253,6 +253,7 @@ Volcanos("onappend", { _init: function(can, meta, list, cb, target, field) { met
|
||||
can.run(event, ["search", item+".onexport.key"])
|
||||
})
|
||||
var args = {}; can.core.List(msg.option, function(key) { args[key] = msg.Option(key) })
|
||||
// can.core.Item(can.Option(), function(key, value) { args[key] = value })
|
||||
location.href = can.user.Share(can, args, true)
|
||||
})
|
||||
},
|
||||
|
@ -40,10 +40,11 @@ Volcanos("onexport", {help: "导出数据", list: [], _init: function(can, msg,
|
||||
sub.run = function(event, cmds, cb, silent) { var msg = can.request(event)
|
||||
can.Conf("active", sub.Option())
|
||||
can.Conf("action", value.name)
|
||||
can.Conf("current", sub)
|
||||
// console.log(event, sub, msg)
|
||||
// 插件回调
|
||||
//
|
||||
msg.Option("index", value.index)
|
||||
cmds[0] == "search" || msg.Option("index", value.index)
|
||||
return can.run(event, can.onengine[cmds[0]]? cmds: [river, storm, index].concat(cmds), function(msg) {
|
||||
can.run(msg._event, ["search", "Footer.onaction.ncmd"]);
|
||||
can.onappend.toast(can, "执行成功", value.name, 2000);
|
||||
@ -61,6 +62,9 @@ Volcanos("onexport", {help: "导出数据", list: [], _init: function(can, msg,
|
||||
},
|
||||
key: function(can, msg) { msg.Option("active", can.Conf("action"))
|
||||
can.core.Item(can.Conf("active"), msg.Option)
|
||||
can.core.List(can.Conf("current")._outputs, function(item) {
|
||||
item.onexport && item.onexport.key && item.onexport.key(item, msg)
|
||||
})
|
||||
},
|
||||
left: function(can) {
|
||||
return can._target.offsetLeft
|
||||
|
@ -1,7 +1,10 @@
|
||||
fieldset.plan>div.output table.project {
|
||||
float:left;
|
||||
}
|
||||
fieldset.plan>div.output table.content {
|
||||
float:left;
|
||||
}
|
||||
fieldset.plan>div.output table.display {
|
||||
fieldset.plan>div.output table.profile {
|
||||
float:left;
|
||||
}
|
||||
|
||||
@ -17,6 +20,13 @@ fieldset.plan>div.output table.content div.finish {
|
||||
fieldset.plan>div.output table.content div.cancel {
|
||||
background-color:red;
|
||||
}
|
||||
|
||||
fieldset.plan>div.output table.content td {
|
||||
vertical-align:top;
|
||||
}
|
||||
fieldset.plan>div.output table.content td div.date {
|
||||
color:gray;
|
||||
}
|
||||
fieldset.plan>div.output table.content td.over {
|
||||
border:solid 2px red;
|
||||
}
|
||||
|
@ -1,11 +1,49 @@
|
||||
Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg, list, cb, target) { can._target.innerHTML = ""
|
||||
can.ui = can.page.Append(can, can._target, [
|
||||
{view: ["project", "table"], style: {display: can.user.Search(can, "project")||"none"}},
|
||||
{view: ["content", "table"]},
|
||||
{view: ["display", "table"]},
|
||||
{view: ["profile", "table"], style: {display: can.user.Search(can, "project")||"none"}},
|
||||
])
|
||||
|
||||
can.Timer(10, function() { can.onimport._stat(can, msg)
|
||||
can.page.Select(can, can.ui.content, "div.item.id"+can.user.Search(can, "id"), function(item) {
|
||||
item.click()
|
||||
})
|
||||
})
|
||||
can.onimport[can.Option("scale")](can, msg)
|
||||
},
|
||||
_stat: function(can, msg) {
|
||||
var stat = {
|
||||
l1: 0, l2: 0, l3: 0, l4: 0, l5: 0,
|
||||
prepare: 0, process: 0, cancel: 0, finish: 0,
|
||||
s1: 0, s2: 0, s3: 0, s4: 0, s5: 0,
|
||||
count: 0,
|
||||
}
|
||||
msg.Table(function(value) {
|
||||
stat["l"+(value.level||"3")]++
|
||||
stat["s"+(value.score||"3")]++
|
||||
stat[value.status]++
|
||||
stat.count++
|
||||
})
|
||||
can.Status("count", stat.process+"/"+stat.count)
|
||||
can.page.Append(can, can.ui.project, [
|
||||
{th: ["key", "value"]},
|
||||
{td: ["prepare", stat.prepare]},
|
||||
{td: ["process", stat.process]},
|
||||
{td: ["cancel", stat.cancel]},
|
||||
{td: ["finish", stat.finish]},
|
||||
stat.l1 > 0 && {td: ["level-1", stat.l1]},
|
||||
stat.l2 > 0 && {td: ["level-2", stat.l2]},
|
||||
stat.l3 > 0 && {td: ["level-3", stat.l3]},
|
||||
stat.l4 > 0 && {td: ["level-4", stat.l4]},
|
||||
stat.l5 > 0 && {td: ["level-5", stat.l5]},
|
||||
stat.s1 > 0 && {td: ["score-1", stat.s1]},
|
||||
stat.s2 > 0 && {td: ["score-2", stat.s2]},
|
||||
stat.s3 > 0 && {td: ["score-3", stat.s3]},
|
||||
stat.s4 > 0 && {td: ["score-4", stat.s4]},
|
||||
stat.s5 > 0 && {td: ["score-5", stat.s5]},
|
||||
])
|
||||
},
|
||||
_task: function(can, msg, time, list, view) {
|
||||
return {text: ["", "td"],
|
||||
ondragover: function(event) { event.preventDefault()
|
||||
@ -17,24 +55,25 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
can.drop(event, event.target, time)
|
||||
},
|
||||
list: can.core.List(list, function(task) {
|
||||
return {view: [["item", task.status, "l"+task.level, "s"+task.score].join(" "), "div", can.onexport[can.Action("view")||"name"](can, task)], title: can.onexport.title(can, task), draggable: true,
|
||||
return typeof task == "string"? {view: ["date", "div", task]}: {view: [["item", task.status, "id"+task.id, "l"+(task.level||""), "s"+(task.score||"")].join(" "),
|
||||
"div", can.onexport[can.Action("view")||view||"name"](can, task)],
|
||||
title: can.onexport.title(can, task), draggable: true,
|
||||
ondragstart: function(event) { var target = event.target; can.drop = function(event, td, time) { td.append(target)
|
||||
can.onaction.modifyTask(event, can, task, "begin_time", time, task.begin_time)
|
||||
} },
|
||||
onclick: function(event) {
|
||||
can.onimport._display(can, msg, task)
|
||||
} }, onclick: function(event) {
|
||||
can.onimport._profile(can, msg, task)
|
||||
}, oncontextmenu: function(event) { var target = event.target
|
||||
can.onappend.carte(can, can.ondetail, can.ondetail.list, function(event, item) {
|
||||
})
|
||||
}}
|
||||
}) }
|
||||
},
|
||||
_display: function(can, msg, task) { can.ui.display.innerHTML = ""
|
||||
_profile: function(can, msg, task) { can.ui.profile.innerHTML = ""
|
||||
can.Status(task)
|
||||
|
||||
can.page.Append(can, can.ui.display, [{th: ["key", "value"]}])
|
||||
can.page.Append(can, can.ui.profile, [{th: ["key", "value"]}])
|
||||
can.core.Item(task, function(key, value) {
|
||||
can.page.Append(can, can.ui.display, [{td: [key, value], ondblclick: function(event) {
|
||||
can.page.Append(can, can.ui.profile, [{td: [key, value], ondblclick: function(event) {
|
||||
can.onappend.modify(can, event.target, function(ev, value, old) {
|
||||
can.onaction.modifyTask(event, can, task, key, value)
|
||||
})
|
||||
@ -67,7 +106,7 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
var table = can.page.Append(can, can.ui.content, [{type: "table", list:
|
||||
can.core.List(list, function(hour, row) {
|
||||
if (row == 0) { return {type: "tr", list: can.core.List(head, function(head) { return {text: [head, "th"]} })} }
|
||||
return {type: "tr", list: [{text: [can.base.Number(hour), "td"]}, can.onimport._task(can, msg, set(hour), hash[hour], "detail")]}
|
||||
return {type: "tr", list: [{text: [can.base.Number(hour), "td"]}, can.onimport._task(can, msg, set(hour), hash[hour], "text")]}
|
||||
})
|
||||
}]).table
|
||||
},
|
||||
@ -108,7 +147,7 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
if (row == 0) { return {type: "tr", list: can.core.List(head, function(head) { return {text: [head, "th"]} })} }
|
||||
return {type: "tr", list: can.core.List(head, function(head, col) {
|
||||
var day = can.base.TimeAdd(last, (row-1)*7+col+1);
|
||||
var list = [{name: day.getDate()+""}].concat(hash[key(day)]||[])
|
||||
var list = [day.getDate()+""].concat(hash[key(day)]||[])
|
||||
return can.onimport._task(can, msg, key(day)+can.base.Time(" %H:%M:%S"), list)
|
||||
})}
|
||||
})
|
||||
@ -129,7 +168,7 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
if (row == 0) { return {type: "tr", list: can.core.List(head, function(head) { return {text: [head, "th"]} })} }
|
||||
return {type: "tr", list: can.core.List(head, function(head, col) {
|
||||
if (col == 0) { return {text: [row+"", "td"]} }
|
||||
return can.onimport._task(can, msg, set(row)+can.base.Time(begin_time, "-%d %H:%M:%S"), hash[set(row)])
|
||||
return can.onimport._task(can, msg, set(row)+can.base.Time(begin_time, "-%d %H:%M:%S"), hash[set(row)], "text")
|
||||
})}
|
||||
})
|
||||
}]).table
|
||||
@ -156,25 +195,27 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
|
||||
}]).table
|
||||
},
|
||||
}, ["/plugin/local/team/miss.css"])
|
||||
Volcanos("onaction", {help: "组件交互", list: ["添加",
|
||||
Volcanos("onaction", {help: "组件交互", list: ["统计","详情", "添加",
|
||||
["level", "all", "l1", "l2", "l3", "l4", "l5"],
|
||||
["status", "all", "prepare", "process", "cancel", "finish"],
|
||||
["score", "all", "s1", "s2", "s3", "s4", "s5"],
|
||||
["view", "name", "text"],
|
||||
["view", "", "name", "text", "level", "score"],
|
||||
],
|
||||
modifyTask: function(event, can, task, key, value) {
|
||||
var msg = can.request(event); msg.Option(task)
|
||||
can.run(event, ["action", "modify", key, value, task[key]], function(msg) {
|
||||
task[key] = value, can.onimport._display(can, can._msg, task)
|
||||
task[key] = value, can.onimport._profile(can, can._msg, task)
|
||||
can.onappend.toast(can, "修改成功")
|
||||
}, true)
|
||||
},
|
||||
|
||||
_filter: function(event, can, key, value) {
|
||||
_filter: function(event, can, key, value) { var count = 0
|
||||
if (value == "all") {
|
||||
can.page.Select(can, can.ui.content, "div.item", function(item) {
|
||||
can.page.ClassList.del(can, item, "hidden")
|
||||
count++
|
||||
})
|
||||
can.Status("count", count)
|
||||
return
|
||||
}
|
||||
can.page.Select(can, can.ui.content, "div.item", function(item) {
|
||||
@ -182,7 +223,9 @@ Volcanos("onaction", {help: "组件交互", list: ["添加",
|
||||
})
|
||||
can.page.Select(can, can.ui.content, "div."+value, function(item) {
|
||||
can.page.ClassList.del(can, item, "hidden")
|
||||
count++
|
||||
})
|
||||
can.Status("count", count)
|
||||
},
|
||||
level: function(event, can, key, value) { can.onaction._filter(event, can, key, value) },
|
||||
status: function(event, can, key, value) { can.onaction._filter(event, can, key, value) },
|
||||
@ -191,6 +234,12 @@ Volcanos("onaction", {help: "组件交互", list: ["添加",
|
||||
can.onimport[can.Option("scale")](can, can._msg)
|
||||
},
|
||||
|
||||
"统计": function(event, can, key) {
|
||||
can.page.Modify(can, can.ui.project, {style: {display: can.ui.project.style.display=="none"? "table": "none"}})
|
||||
},
|
||||
"详情": function(event, can, key) {
|
||||
can.page.Modify(can, can.ui.profile, {style: {display: can.ui.profile.style.display=="none"? "table": "none"}})
|
||||
},
|
||||
"添加": function(event, can, key) {
|
||||
can.require(["/plugin/input/date"], function(can) {
|
||||
console.log("waht")
|
||||
@ -212,15 +261,27 @@ Volcanos("onaction", {help: "组件交互", list: ["添加",
|
||||
})
|
||||
Volcanos("ondetail", {help: "菜单交互", list: ["prepare", "process", "finish", "cancel"],
|
||||
})
|
||||
Volcanos("onexport", {help: "导出数据", list: ["begin_time", "zone", "id", "type", "name"],
|
||||
Volcanos("onexport", {help: "导出数据", list: ["count", "begin_time", "zone", "id", "type", "name"],
|
||||
name: function(can, task) {
|
||||
return task.name
|
||||
},
|
||||
text: function(can, task) {
|
||||
return task.name+": "+(task.text||"")
|
||||
},
|
||||
level: function(can, task) {
|
||||
return "l-"+(task.level||3)+": "+(task.name||"")
|
||||
},
|
||||
score: function(can, task) {
|
||||
return "s-"+(task.level||3)+": "+(task.name||"")
|
||||
},
|
||||
title: function(can, task) {
|
||||
return task.zone+": "+(task.type||"")
|
||||
},
|
||||
|
||||
key: function(can, msg) {
|
||||
msg.Option("project", can.ui.project.style.display)
|
||||
msg.Option("profile", can.ui.profile.style.display)
|
||||
msg.Option("id", can.Status("id"))
|
||||
},
|
||||
})
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user