diff --git a/publish/client/mp/.cloudbase/container/debug.json b/publish/client/mp/.cloudbase/container/debug.json
new file mode 100644
index 00000000..0d444581
--- /dev/null
+++ b/publish/client/mp/.cloudbase/container/debug.json
@@ -0,0 +1 @@
+{"containers":[],"config":{}}
\ No newline at end of file
diff --git a/publish/client/mp/app.js b/publish/client/mp/app.js
index 7172d74b..4fae87cf 100644
--- a/publish/client/mp/app.js
+++ b/publish/client/mp/app.js
@@ -5,7 +5,7 @@ const page = require("utils/lib/page.js")
const user = require("utils/lib/user.js")
App({
- data: {}, conf: {serve: "https://2021.shylinux.com/chat"},
+ data: {}, conf: {serve: "https://2021.shylinux.com"},
base: base, core: core, misc: misc, page: page, user: user,
onLaunch: function() { console.log("app load", this.conf) },
})
diff --git a/publish/client/mp/pages/action/action.js b/publish/client/mp/pages/action/action.js
index 563f5b79..add7e495 100644
--- a/publish/client/mp/pages/action/action.js
+++ b/publish/client/mp/pages/action/action.js
@@ -1,5 +1,5 @@
const {shy, Volcanos} = require("../../utils/proto.js")
-const {html} = require("../../utils/const.js")
+const {ice, ctx, mdb, html} = require("../../utils/const.js")
Volcanos._page = {}
Volcanos("onimport", {
_init: function(can, msg) { can.db.list = []
@@ -20,6 +20,9 @@ Volcanos("onimport", {
if (input.type == "select") {
input.values = input.values || can.core.Split(input.value)
}
+ if (input.type == "button") {
+ input.value = {"list": "查看", "back": "返回", "create": "创建"}[input.value||input.name]||input.value||input.name
+ }
input.type == "button" && input.action == "auto" && can.core.Timer(100, function() {
can.run({}, [can.db.river, can.db.storm, value.id||value.index], function(msg) {
value.msg = msg, can.page.setData(can, can.db.list)
@@ -41,23 +44,24 @@ Volcanos("onaction", {list: ["刷新", "扫码", "清屏"],
can.onimport._init(can, msg)
})
},
- onaction: function(event, can, msg) { var name = msg.Option("name")
+ onaction: function(event, can, button, data) { var name = data.name
(can.onaction[name]||function(event) { can.run(event, [ctx.ACTION, name]) })(event, can)
},
- onInputs: function(event, can, msg) { var order = msg.Option("order")||0, index = msg.Option("index")||0
+ onInputs: function(event, can, button, data) { var order = data.order, index = data.index
var input = can.ui.data.list[order||0].inputs[index||0]
input.value = event.detail.value
},
- onChange: function(event, can, msg) { var order = msg.Option("order")||0, index = msg.Option("index")||0
+ onChange: function(event, can, button, data) { var order = data.order, index = data.index
var input = can.ui.data.list[order||0].inputs[index||0]
input.value = input.values[parseInt(event.detail.value)]
},
- onAction: function(event, can, msg) { var order = msg.Option("order")||0, name = msg.Option("name")
+ onAction: function(event, can, button, data) { var order = data.order, name = data.name
var field = can.ui.data.list[order||0]
if (field.feature[name]) {
can.data.insert = {field: field, name: name, list: field.feature[name], cb: function(res) {
+ debugger
can.run(event, can.base.Simple([can.db.river, can.db.storm, field.id||field.index, ctx.ACTION, name], res), function(msg) {
- can.onaction.onAction(event, can, order)
+ can.onaction.onAction(event, can, ice.LIST, {order: order, name: ice.LIST})
})
}}
can.user.jumps("/pages/insert/insert", {river: can.db.river, storm: can.db.storm, index: field.id||field.index, title: field.name})
@@ -65,20 +69,16 @@ Volcanos("onaction", {list: ["刷新", "扫码", "清屏"],
}
field._history = field._history||[]
switch (name) {
- case "back":
- var ls = field._history.pop()
- var ls = field._history.pop()||[]
- var i = 0
+ case ice.BACK: field._history.pop()
+ var ls = field._history.pop()||[], i = 0
can.core.List(field.inputs, function(input, index) {
- if (input.type != html.BUTTON) {
- input.value = ls[i++]||""
- }
+ if (input.type != html.BUTTON) { input.value = ls[i++]||"" }
})
can.page.setData(can)
- can.onaction.onAction(event, can, order, "list")
+ can.onaction.onAction(event, can, order, ice.LIST)
break
case "run":
- case "list":
+ case ice.LIST:
case "refresh":
break
default:
@@ -96,12 +96,12 @@ Volcanos("onaction", {list: ["刷新", "扫码", "清屏"],
for (var i = cmds.length-1; i > 0; i--) { if (cmds[i] === "") { cmds.pop() } else { break } }
can.run(event, cmds, function(msg) { field.msg = msg, can.page.setData(can) })
},
- onDetail: function(event, can, msg) { var order = msg.Option("order")||0, name = msg.Option("name"), value = msg.Option("value")
+ onDetail: function(event, can, button, data) { var order = data.order, name = data.name, value = data.value
var field = can.ui.data.list[order||0]
can.core.List(field.inputs, function(input) {
if (input.name == name) {
input.value = value, can.page.setData(can)
- can.onaction.onAction(event, can, order, "list")
+ can.onaction.onAction(event, can, order, ice.LIST)
}
})
},
diff --git a/publish/client/mp/pages/insert/insert.js b/publish/client/mp/pages/insert/insert.js
index b8ed86b4..dcd2faaf 100644
--- a/publish/client/mp/pages/insert/insert.js
+++ b/publish/client/mp/pages/insert/insert.js
@@ -1,56 +1,37 @@
-const app = getApp()
-var kit = {}
-
-Page({
- name: "insert",
- data: {
- action: ["扫码"],
- list: [],
- },
- action: {
- "扫码": function(event, page) { app.scans(function(res) {
- switch (res.type) {
- case "button": res.name && page.onaction(event, res); break
- default: return false
- } return true
- }) },
- },
- onaction: function(event, data) { data = data || event.target.dataset
- console.log("action", this.name, data.name)
- this.action[data.name](event, this)
- },
-
- onInput: function(event) { var page = this, data = event.target.dataset
- page.data.list[data.index].value = event.detail.value
- },
- onChange: function(event) { var page = this, data = event.target.dataset
- var input = page.data.list[data.index]
- input.value = input.values[parseInt(event.detail.value)]
- },
- onConfirm: function (event) { var page = this
- var res = {}; kit.List(page.data.list, function(item) { res[item.name] = item.value })
- app.data.insert.cb(res), wx.navigateBack()
- },
-
- onLoad: function (options) {
- console.log("page", this.name, options)
- app.title(options.title)
-
- kit.List(app.data.insert.list, function(input) {
- input.action = input.action || input.value
- input.value == "auto" && (input.value = "")
-
- if (input.value && input.value.indexOf("@") == 0) {
- input.action = input.value.slice(1), input.value = ""
- }
- })
-
- this.setData({list: this.data.list = app.data.insert.list})
- },
- onReady: function () {},
- onShow: function () {},
- onHide: function () {},
- onUnload: function () {},
- onReachBottom: function () {},
- onPullDownRefresh: function () {},
+const {shy, Volcanos} = require("../../utils/proto.js")
+const {mdb, html} = require("../../utils/const.js")
+Volcanos._page = {}
+Volcanos("onimport", {
+ _init: function(can, msg) {},
})
+
+Volcanos("onaction", {list: ["刷新", "扫码"],
+ "刷新": function(event, can) { can.onaction.refresh(event, can) },
+ "扫码": function(event, can) { can.user.agent.scanQRCode(can) },
+ refresh: function(event, can) {
+ can.core.List(can.data.insert.list, function(input) {
+ input.action = input.action || input.value
+ input.value == "auto" && (input.value = "")
+ if (input.value && input.value.indexOf("@") == 0) {
+ input.action = input.value.slice(1), input.value = ""
+ }
+ })
+ can.page.setData(can, can.data.insert.list)
+ },
+ onaction: function(event, can, button, data) { var name = data.name
+ (can.onaction[name]||function(event) { can.run(event, [ctx.ACTION, name]) })(event, can)
+ },
+ onInputs: function(event, can, button, data) { var index = data.index
+ var input = can.data.insert.list[index]
+ input.value = event.detail.value
+ },
+ onChange: function(event, can, button, data) { var index = data.index
+ var input = can.data.insert.list[index]
+ input.value = input.values[parseInt(event.detail.value)]
+ },
+ onConfirm: function (event, can, button, data) {
+ var res = {}; can.core.List(can.data.insert.list, function(item) { res[item.name] = item.value||"" })
+ can.data.insert.cb(res), wx.navigateBack()
+ },
+})
+Volcanos._init()
diff --git a/publish/client/mp/pages/insert/insert.wxml b/publish/client/mp/pages/insert/insert.wxml
index d36f09cd..7d8b23dd 100644
--- a/publish/client/mp/pages/insert/insert.wxml
+++ b/publish/client/mp/pages/insert/insert.wxml
@@ -1,27 +1,21 @@
-
-
-
-
-
-
-
-
-
-
- {{item.values[item.index||0]}}
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+ {{item.values[item.index||0]}}
+
+
+
+
+
+
+
+
diff --git a/publish/client/mp/pages/river/river.js b/publish/client/mp/pages/river/river.js
index 3694be08..08e4ce98 100644
--- a/publish/client/mp/pages/river/river.js
+++ b/publish/client/mp/pages/river/river.js
@@ -12,20 +12,20 @@ Volcanos("onaction", {list: ["刷新", "扫码", "登录"],
can.user.userinfo(can, function() { can.onaction.refresh(event, can) })
},
refresh: function(event, can) { can.run(event, [], function(msg) { can.onimport._init(can, msg) }) },
- onaction: function(event, can, msg) { var name = msg.Option("name")
+ onaction: function(event, can, button, data) { var name = data.name;
(can.onaction[name]||function(event) { can.run(event, [ctx.ACTION, name]) })(event, can)
},
- ondetail: function(event, can, msg) { var index = msg.Option("index")||"0"
+ ondetail: function(event, can, button, data) { var index = data.index
var item = can.ui.data.list[index]; item._show = !item._show
if (item.list) { return can.page.setData(can) }
can.run(event, [item.hash, chat.STORM], function(msg) {
item.list = msg.Table(), can.page.setData(can)
})
},
- onchange: function(event, can, msg) { var index = msg.Option("index")||0, i = msg.Option("i")||0
+ onchange: function(event, can, button, data) { var index = data.index, i = data.i
var river = can.ui.data.list[index], storm = river.list[i]
can.user.jumps(can.base.MergeURL("/pages/action/action", {river: river.hash, storm: storm.hash, title: river.name+"."+storm.name}))
},
- _name: "river/",
+ _name: "/chat/river/",
})
Volcanos._init()
diff --git a/publish/client/mp/utils/const.js b/publish/client/mp/utils/const.js
index b271df7e..4089fdb0 100644
--- a/publish/client/mp/utils/const.js
+++ b/publish/client/mp/utils/const.js
@@ -11,6 +11,7 @@ var kit = {proto: function(sub, sup) { return sub.__proto__ = sup, sub },
}
var ice = {
TB: "\t", SP: " ", DF: ":", EQ: "=", AT: "@", QS: "?", PS: "/", PT: ".", FS: ",", NL: "\n", LT: "<", GT: ">",
+ LIST: "list", BACK: "back",
MSG_FIELDS: "fields", MSG_SESSID: "sessid",
MSG_DETAIL: "detail", MSG_OPTION: "option", MSG_APPEND: "append", MSG_RESULT: "result",
@@ -22,7 +23,9 @@ var ctx = {
}
var mdb = {
EQ: ice.EQ, FS: ice.FS,
+ TYPE: "type", NAME: "name", TEXT: "text", ICON: "icon", ICONS: "icons",
KEY: "key", VALUE: "value", STATUS: "status", EXPIRE: "expire", EXTRA: "extra",
+ DATA: "data", VIEW: "view", ORDER: "order",
}
var nfs = {
DF: ice.DF, PS: ice.PS, PT: ice.PT,
diff --git a/publish/client/mp/utils/lib/misc.js b/publish/client/mp/utils/lib/misc.js
index b365d8c6..a8747a1e 100644
--- a/publish/client/mp/utils/lib/misc.js
+++ b/publish/client/mp/utils/lib/misc.js
@@ -74,8 +74,10 @@ Volcanos("misc", {
wx.showLoading(), can.misc.request(can, msg, cmd, data, function(msg) { wx.hideLoading(), cb && cb(msg) })
},
request: function(can, msg, cmd, data, cb) { data.sessid = can.conf.sessid
- wx.request({method: http.POST, url: can.conf.serve+nfs.PS+cmd, data: data, success: function(res) {
- if (res.statusCode == 401) { return can.user.login(can, function() { can.misc.request(can, msg, cmd, data, cb) }) }
+ wx.request({method: http.POST, url: can.conf.serve+cmd, data: data, success: function(res) {
+ if (res.statusCode == 401) {
+ can.user.info = {}, can.misc.localStorage(can, ice.MSG_SESSID, can.conf.sessid = "")
+ return can.user.login(can, function() { can.misc.request(can, msg, cmd, data, cb) }) }
msg.Copy(res.data), console.log("request", cmd, data.cmds||data, msg)
msg.Data = function(item, index) {
var text = msg[item]&&msg[item][index]||""
diff --git a/publish/client/mp/utils/lib/user.js b/publish/client/mp/utils/lib/user.js
index 56d5effd..0022c950 100644
--- a/publish/client/mp/utils/lib/user.js
+++ b/publish/client/mp/utils/lib/user.js
@@ -24,13 +24,13 @@ Volcanos("user", {
case "auth":
can.user.userinfo(can, function() {
can.user.modal(can, "授权登录", data.name, function(res) {
- res.confirm && can.misc.request(can, can.request(), "mp/login/action/scan", data, function(msg) {
+ res.confirm && can.misc.request(can, can.request(), "/chat/wx/login/action/scan", data, function(msg) {
can.user.toast(can, "授权成功")
})
})
})
break
- default: can.misc.request(can, can.request(), "mp/login/action/scan", data)
+ default: can.misc.request(can, can.request(), "/chat/wx/login/action/scan", data)
}
}})
},
@@ -50,16 +50,16 @@ Volcanos("user", {
login: function(can, cb) {
can.conf.sessid = can.conf.sessid||can.misc.localStorage(can, ice.MSG_SESSID)
if (can.conf.sessid) { return cb && cb() }
- wx.login({success: function(res) { can.misc.request(can, can.request(), "mp/login/action/sess", {code: res.code}, function(msg) {
+ wx.login({success: function(res) { can.misc.request(can, can.request(), "/chat/wx/login/action/sess", {code: res.code}, function(msg) {
wx.setStorage({key: ice.MSG_SESSID, data: can.conf.sessid = msg.Result()}), cb && cb()
}) }})
},
userinfo: function(can, cb) {
- can.user.info.userNick? can.misc.request(can, can.request(), "mp/login/action/user", {}, function(msg) {
+ can.user.info.userNick? can.misc.request(can, can.request(), "/chat/wx/login/action/user", {}, function(msg) {
cb && cb(can.user.info)
}): can.user.login(can, function() { wx.getSetting({success: function(res) {
res.authSetting['scope.userInfo'] && wx.getUserInfo({success: function(res) {
- can.misc.request(can, can.request(), "mp/login/action/user", can.user.info = res.userInfo, function(msg) {
+ can.misc.request(can, can.request(), "/chat/wx/login/action/user", can.user.info = res.userInfo, function(msg) {
cb && cb(can.user.info)
})
}})
diff --git a/publish/client/mp/utils/proto.js b/publish/client/mp/utils/proto.js
index 8ab93458..27984169 100644
--- a/publish/client/mp/utils/proto.js
+++ b/publish/client/mp/utils/proto.js
@@ -25,7 +25,7 @@ Volcanos._init = function() {
}); return msg
},
run: function(event, cmds, cb) {
- can.misc.requests(can, can.request(event), can.onaction._name||"action/", {cmds: cmds}, function(msg) {
+ can.misc.requests(can, can.request(event), can.onaction._name||"/chat/action/", {cmds: cmds}, function(msg) {
msg.Dump = function() { can.ui.setData({list: msg.Table()}) }, cb(msg)
})
},
@@ -33,7 +33,7 @@ Volcanos._init = function() {
var page = {data: {action: can.onaction.list, list: []},
onLoad: function(options) { can.ui = this, can.db = options
console.log(can.ui.route, options)
- can.user.title(options.title||"")
+ can.user.title(decodeURIComponent(options.title||""))
can.user.login(can, function() {
if (can.onaction.refresh) {
can.onaction.refresh({}, can)
@@ -52,7 +52,7 @@ Volcanos._init = function() {
}
can.core.ItemCB(can.onaction, function(key, cb) { page[key] = function(event) {
// can.core.CallFunc(cb, {event: event, can: can, msg: can.request(event, event.target.dataset)})
- can.core.CallFunc(cb, [event, can, can.request(event, event.target.dataset)])
+ can.core.CallFunc(cb, [event, can, key, event.target.dataset])
} }), Page(page)
}