1
0
mirror of https://shylinux.com/x/volcanos synced 2025-04-25 08:48:06 +08:00
This commit is contained in:
shaoying 2020-06-09 21:09:53 +08:00
parent 7398cd8917
commit a26c236c29
6 changed files with 143 additions and 57 deletions

View File

@ -116,7 +116,7 @@ Volcanos("onappend", { _init: function(can, meta, list, cb, target, field) { met
_target: field, _inputs: {}, _outputs: [], _history: [], _target: field, _inputs: {}, _outputs: [], _history: [],
_option: option, _action: action, _output: output, _option: option, _action: action, _output: output,
Option: function(key, value) { Option: function(key, value) {
if (typeof key == "object") { return sub.core.Item(key, can.Option), key } if (typeof key == "object") { return sub.core.Item(key, sub.Option), key }
if (key == undefined) { value = {} if (key == undefined) { value = {}
sub.page.Select(sub, option, "select.args,input.args", function(item) { sub.page.Select(sub, option, "select.args,input.args", function(item) {
value[item.name] = item.value value[item.name] = item.value
@ -229,8 +229,7 @@ Volcanos("onappend", { _init: function(can, meta, list, cb, target, field) { met
_option: option, _action: action, _output: output, _option: option, _action: action, _output: output,
}, Volcanos.meta.libs.concat(["/frame.js", display]), function(table) { table.Conf(sub.Conf()) }, Volcanos.meta.libs.concat(["/frame.js", display]), function(table) { table.Conf(sub.Conf())
table.onimport && table.onimport._init && table.onimport._init(table, msg, msg.result||[], function() {}, output) table.onimport && table.onimport._init && table.onimport._init(table, msg, msg.result||[], function() {}, output)
table._msg = msg, table.run = function(event, cmds, cb, silent) { cmds = cmds || []
table.run = function(event, cmds, cb, silent) { cmds = cmds || []
var last = sub._history[sub._history.length-1]; !can.core.Eq(last, cmds) && !silent && sub._history.push(cmds) var last = sub._history[sub._history.length-1]; !can.core.Eq(last, cmds) && !silent && sub._history.push(cmds)
return run(event, cmds, cb, silent) return run(event, cmds, cb, silent)
} }
@ -263,7 +262,7 @@ Volcanos("onappend", { _init: function(can, meta, list, cb, target, field) { met
typeof item == "string"? can.onappend.input(can, action, "input", {type: "button", value: item, onclick: function(event) { typeof item == "string"? can.onappend.input(can, action, "input", {type: "button", value: item, onclick: function(event) {
(can.onaction[item] || can.onkeymap && can.onkeymap._remote)(event, can, item) (can.onaction[item] || can.onkeymap && can.onkeymap._remote)(event, can, item)
}}): item.length > 0? can.onappend.input(can, action, "input", {type: "select", values: item.slice(1), name: item[0], onchange: function(event) { }}): item.length > 0? can.onappend.input(can, action, "input", {type: "select", values: item.slice(1), name: item[0], onchange: function(event) {
can.onaction[item[0]](event, can, msg, item[event.target.selectedIndex+1]) can.onaction[item[0]](event, can, item[0], item[event.target.selectedIndex+1])
}}): typeof item == "object" && can.onappend.input(can, action, "input", item) }}): typeof item == "object" && can.onappend.input(can, action, "input", item)
}) })
}, },

View File

@ -227,6 +227,7 @@ div.upload div.item {
} }
fieldset.input { fieldset.input {
background-color:black;
position:absolute; position:absolute;
left:0; top:0; left:0; top:0;
} }

View File

@ -40,6 +40,9 @@ var base = Volcanos("base", {help: "基础模块",
fmt = fmt.replace("%S", this.Number(now.getSeconds(), 2)) fmt = fmt.replace("%S", this.Number(now.getSeconds(), 2))
return fmt return fmt
}), }),
TimeAdd: shy("时间格式化", function(t, d) {
return new Date(t - t%(24*3600*1000) - 8*3600*1000 + d*24*3600*1000)
}),
Duration: function(n) {var res = "", h = 0; Duration: function(n) {var res = "", h = 0;
h = parseInt(n/3600000/24), h > 0 && (res += h+"d"), n = n % (3600000*24); h = parseInt(n/3600000/24), h > 0 && (res += h+"d"), n = n % (3600000*24);
h = parseInt(n/3600000), h > 0 && (res += h+"h"), n = n % 3600000; h = parseInt(n/3600000), h > 0 && (res += h+"h"), n = n % 3600000;

View File

@ -51,6 +51,7 @@ Volcanos("onimport", {help: "导入数据", _init: function(can, msg, list, cb,
msg.Option({path: can.Option("path"), name: can.Option("name")}) msg.Option({path: can.Option("path"), name: can.Option("name")})
can.page.Append(can, can._action, [{view: ["file", "div", name], onclick: function(event) { can.page.Append(can, can._action, [{view: ["file", "div", name], onclick: function(event) {
can.onsyntax._init(can, can.tabview[path+name] = msg) can.onsyntax._init(can, can.tabview[path+name] = msg)
can.Option({path: path, name: name, key: ""})
}, oncontextmenu: function(event) { }, oncontextmenu: function(event) {
can.onappend.carte(can, null, ["保存", "运行"]) can.onappend.carte(can, null, ["保存", "运行"])
}}]).first.click() }}]).first.click()

View File

@ -3,7 +3,7 @@ Volcanos("onfigure", {help: "控件详情", list: [],
can._figure && can.page.Remove(can, can._figure.fieldset) can._figure && can.page.Remove(can, can._figure.fieldset)
can._figure = can.onappend.field(can, can._target, "input date", {}) can._figure = can.onappend.field(can, can._target, "input date", {})
// 设置输入 // 设置输入
target.style.width = "120px"; function set(now) { function set(now) {
target.value = can.base.Time(now); target.value = can.base.Time(now);
item.action == "auto" && can.run({}); item.action == "auto" && can.run({});
} }
@ -16,7 +16,7 @@ Volcanos("onfigure", {help: "控件详情", list: [],
// 添加控件 // 添加控件
var now = target.value? new Date(target.value): new Date(); var now = target.value? new Date(target.value): new Date();
var control = can.page.AppendAction(can, figure.action, ["今天", "随机", var control = can.page.AppendAction(can, figure.action, ["今天",
["hour"].concat(can.core.List(24)), ["minute"].concat(can.core.List(0, 60, 5)), ["second"].concat(can.core.List(0, 60, 5)), {view: ["", "br"]}, ["hour"].concat(can.core.List(24)), ["minute"].concat(can.core.List(0, 60, 5)), ["second"].concat(can.core.List(0, 60, 5)), {view: ["", "br"]},
"关闭", {type: "hr", style: {margin: 0}}, "关闭", {type: "hr", style: {margin: 0}},
"上一月", ["year"].concat(can.core.List(now.getFullYear() - 20, now.getFullYear() + 20)), "上一月", ["year"].concat(can.core.List(now.getFullYear() - 20, now.getFullYear() + 20)),

View File

@ -17,24 +17,14 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
can.drop(event, event.target, time) can.drop(event, event.target, time)
}, },
list: can.core.List(list, function(task) { list: can.core.List(list, function(task) {
return {view: [task.status, "div", view!="detail"? task.name: task.name+": "+task.text], title: task.text, draggable: true, 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,
ondragstart: function(event) { var target = event.target; can.drop = function(event, td, time) { ondragstart: function(event) { var target = event.target; can.drop = function(event, td, time) { td.append(target)
var msg = can.request(event); msg.Option(task) can.onaction.modifyTask(event, can, task, "begin_time", time, task.begin_time)
td.append(target), can.run(event, ["action", "modify", "begin_time", time, task.begin_time], function(msg) {
task.begin_time = time, can.onimport._display(can, msg, task)
can.onappend.toast(can, "修改成功")
}, true)
} }, } },
onclick: function(event) { onclick: function(event) {
can.onimport._display(can, msg, task) can.onimport._display(can, msg, task)
}, oncontextmenu: function(event) { var target = event.target }, oncontextmenu: function(event) { var target = event.target
can.onappend.carte(can, can.ondetail, can.ondetail.list, function(event, item) { can.onappend.carte(can, can.ondetail, can.ondetail.list, function(event, item) {
var msg = can.request(event); msg.Option(task)
can.run(event, ["action", "modify", "status", item, task.status], function(msg) {
target.className = task.status = item
can.onimport._display(can, msg, task)
can.onappend.toast(can, "修改成功")
}, true)
}) })
}} }}
}) } }) }
@ -44,80 +34,163 @@ Volcanos("onimport", {help: "导入数据", list: [], _init: function(can, msg,
can.page.Append(can, can.ui.display, [{th: ["key", "value"]}]) can.page.Append(can, can.ui.display, [{th: ["key", "value"]}])
can.core.Item(task, function(key, value) { can.core.Item(task, function(key, value) {
can.page.Append(can, can.ui.display, [{td: [key, value], oncontextmenu: function(event) { var target = event.target can.page.Append(can, can.ui.display, [{td: [key, value], ondblclick: function(event) {
can.onappend.modify(can, event.target, function(ev, value, old) {
can.onaction.modifyTask(event, can, task, key, value)
})
}, oncontextmenu: function(event) { var target = event.target
can.onappend.carte(can, can.ondetail, ["编辑"].concat(can.ondetail.list), function(event, item, meta) { can.onappend.carte(can, can.ondetail, ["编辑"].concat(can.ondetail.list), function(event, item, meta) {
var res = can.request(event); res.Option(task)
switch (item) { switch (item) {
case "编辑": case "编辑":
can.onappend.modify(can, target, function(ev, value, old) { can.onappend.modify(can, target, function(ev, value, old) {
can.run(event, ["action", "modify", key, value, old], function(res) { can.onaction.modifyTask(event, can, task, key, value)
task[key] = value
can.onimport._display(can, msg, task)
can.onappend.toast(can, "修改成功")
}, true)
}) })
break break
default: default:
can.run(event, ["action", "modify", "status", item, task.status], function(res) { can.onaction.modifyTask(event, can, task, "status", item)
task.status = item
can.onimport._display(can, msg, task)
can.onappend.toast(can, "修改成功")
}, true)
} }
}) })
}}]) }}])
}) })
}, },
day: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
function set(hour) {
return can.base.Time(new Date(begin_time-((begin_time.getHours()-hour))*60*60*1000))
}
var hash = {}; msg.Table(function(value) { var time = new Date(value.begin_time) day: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
var key = time.getHours(); hash[key] = (hash[key]||[]).concat([value]) function key(time) { return time.getHours() }
var hash = {}; msg.Table(function(value) {
var k = key(new Date(value.begin_time)); hash[k] = (hash[k]||[]).concat([value])
}) })
var head = ["hour", "task"]
var list = [0]; for (var i = 6; i < 24; i++) { list.push(i) } var list = [0]; for (var i = 6; i < 24; i++) { list.push(i) }
function set(hour) { return can.base.Time(can.base.TimeAdd(begin_time, hour/24)) }
var table = can.page.Append(can, can.ui.content, [{type: "table", list: var table = can.page.Append(can, can.ui.content, [{type: "table", list:
can.core.List(list, function(hour, index) { can.core.List(list, function(hour, row) {
if (index == 0) { return {type: "tr", list: [{text: ["time", "th"]}, {text: ["text", "th"]}]} } 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], "detail")]}
}) })
}]).table }]).table
}, },
week: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time"))) week: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
function set(week, hour) { function key(time) { return time.getDay()+" "+time.getHours() }
return can.base.Time(new Date(begin_time-((begin_time.getDay()-week)*24+(begin_time.getHours()-hour))*60*60*1000)) var hash = {}; msg.Table(function(value) {
} var k = key(new Date(value.begin_time)); hash[k] = (hash[k]||[]).concat([value])
var hash = {}; msg.Table(function(value) { var time = new Date(value.begin_time)
var key = time.getDay()+" "+time.getHours()
hash[key] = (hash[key]||[]).concat([value])
}) })
var head = ["time"].concat(["周日", "周一", "周二", "周三", "周四", "周五", "周六"]); var head = ["hour"].concat(["周日", "周一", "周二", "周三", "周四", "周五", "周六"]);
var list = [0]; for (var i = 6; i < 24; i++) { list.push(i) } var list = [0]; for (var i = 6; i < 24; i++) { list.push(i) }
function set(week, hour) { return can.base.Time(can.base.TimeAdd(begin_time, week-begin_time.getDay()+hour/24)) }
var table = can.page.Append(can, can.ui.content, [{type: "table", list: var table = can.page.Append(can, can.ui.content, [{type: "table", list:
can.core.List(list, function(hour, index) { can.core.List(list, function(hour, row) {
if (index == 0) { return {type: "tr", list: can.core.List(head, function(head) { return {text: [head, "th"]} })} } 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, index) { if (index == 0) { return {text: [hour, "td"]} } return {type: "tr", list: can.core.List(head, function(head, index) {
if (index == 0) { return {text: [hour, "td"]} }
return can.onimport._task(can, msg, set(index-1, hour), hash[index-1+" "+hour]) return can.onimport._task(can, msg, set(index-1, hour), hash[index-1+" "+hour])
})} })}
}) })
}]).table }]).table
}, },
month: function(can, msg) { month: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
function key(time) { return can.base.Time(time, "%y-%m-%d") }
var hash = {}; msg.Table(function(value) {
var k = key(new Date(value.begin_time)); hash[k] = (hash[k]||[]).concat([value])
})
var head = ["周日", "周一", "周二", "周三", "周四", "周五", "周六"]
var list = [0]; for (var i = 1; i < 6; i++) { list.push(i) }
var begin = can.base.TimeAdd(begin_time, -(begin_time.getDate()-1))
var last = can.base.TimeAdd(begin_time, -(begin_time.getDate()-1)-begin.getDay())
var table = can.page.Append(can, can.ui.content, [{type: "table", list:
can.core.List(list, function(date, row) {
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)]||[])
return can.onimport._task(can, msg, key(day)+can.base.Time(" %H:%M:%S"), list)
})}
})
}]).table
}, },
months: function(can, msg) { year: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
function key(time) { return can.base.Time(time, "%y-%m") }
var hash = {}; msg.Table(function(value) {
var k = key(new Date(value.begin_time)); hash[k] = (hash[k]||[]).concat([value])
})
var head = ["month", "task"]
var list = [0]; for (var i = 1; i < 13; i++) { list.push(i) }
function set(month) { return begin_time.getFullYear()+"-"+can.base.Number(month, 2) }
var table = can.page.Append(can, can.ui.content, [{type: "table", list:
can.core.List(list, function(date, row) {
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)])
})}
})
}]).table
}, },
year: function(can, msg) { long: function(can, msg) { var begin_time = new Date(can.base.Time(can.Option("begin_time")))
}, function key(time) { return can.base.Time(time, "%y-%m") }
long: function(can, msg) { var hash = {}; msg.Table(function(value) {
var k = key(new Date(value.begin_time)); hash[k] = (hash[k]||[]).concat([value])
})
var head = ["month"]; for (var i = -5; i < 5; i++) { head.push(begin_time.getFullYear()+i) }
var list = [0]; for (var i = 1; i < 13; i++) { list.push(i) }
function set(month) { return begin_time.getFullYear()+"-"+can.base.Number(month, 2) }
var table = can.page.Append(can, can.ui.content, [{type: "table", list:
can.core.List(list, function(date, row) {
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"]} }
var key = head+"-"+can.base.Number(row, 2)
return can.onimport._task(can, msg, key+can.base.Time(begin_time, "-%d %H:%M:%S"), hash[key])
})}
})
}]).table
}, },
}, ["/plugin/local/team/miss.css"]) }, ["/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"],
],
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)
can.onappend.toast(can, "修改成功")
}, true)
},
_filter: function(event, can, key, value) {
if (value == "all") {
can.page.Select(can, can.ui.content, "div.item", function(item) {
can.page.ClassList.del(can, item, "hidden")
})
return
}
can.page.Select(can, can.ui.content, "div.item", function(item) {
can.page.ClassList.add(can, item, "hidden")
})
can.page.Select(can, can.ui.content, "div."+value, function(item) {
can.page.ClassList.del(can, item, "hidden")
})
},
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) },
score: function(event, can, key, value) { can.onaction._filter(event, can, key, value) },
view: function(event, can, key, value) { can.ui.content.innerHTML = ""
can.onimport[can.Option("scale")](can, can._msg)
},
"添加": function(event, can, key) { "添加": function(event, can, key) {
can.require(["/plugin/input/date"], function(can) { can.require(["/plugin/input/date"], function(can) {
console.log("waht") console.log("waht")
@ -126,7 +199,7 @@ Volcanos("onaction", {help: "组件交互", list: ["添加"],
can.onfigure.date.onclick(event, can, {}, event.target) can.onfigure.date.onclick(event, can, {}, event.target)
} }
can.user.input(event, can, [ can.user.input(event, can, [
"zone", "type", "name", "text", ["zone", "工作", "学习"], ["type", "项目开发", "项目测试"], "name", "text",
{name: "begin_time", type: "input", value: can.base.Time(), onclick: time}, {name: "begin_time", type: "input", value: can.base.Time(), onclick: time},
{name: "end_timem", type: "input", value: can.base.Time(), onclick: time}, {name: "end_timem", type: "input", value: can.base.Time(), onclick: time},
], function(event, button, data, list) { ], function(event, button, data, list) {
@ -140,5 +213,14 @@ Volcanos("onaction", {help: "组件交互", list: ["添加"],
Volcanos("ondetail", {help: "菜单交互", list: ["prepare", "process", "finish", "cancel"], Volcanos("ondetail", {help: "菜单交互", list: ["prepare", "process", "finish", "cancel"],
}) })
Volcanos("onexport", {help: "导出数据", list: ["begin_time", "zone", "id", "type", "name"], Volcanos("onexport", {help: "导出数据", list: ["begin_time", "zone", "id", "type", "name"],
name: function(can, task) {
return task.name
},
text: function(can, task) {
return task.name+": "+(task.text||"")
},
title: function(can, task) {
return task.zone+": "+(task.type||"")
},
}) })