# 背景
校园跑腿小程序: 在帮助学生和教职员工解决日常生活中的琐事,提供便利、快捷的服务.解决学生和教职员工日常生活中的燃眉之急,促进了校园内的互助和共享文化,提升了校园生活的便利性和舒适度。
# 功能规划
- 公告资讯:提供校园内的新闻、通知、课程表等信息,让用户及时了解校园动态。
- 任务发布: 用户可以发布各种生活任务,如代购食物、快递取送、打印文件等,描述任务需求、地点、时间等信息。
- 任务接单: 其他用户(跑腿者)可以浏览并接受发布的任务,承接后负责完成任务,并与发布者协商具体细节。
- 分类管理:小程序可以按照不同的任务类型进行分类管理,如代购、快递、搬运等,方便用户快速找到所需服务。
# 数据库设计
```bash
FollowModel.DB_STRUCTURE = {
_pid: 'string|true',
FOLLOW_ID: 'string|true',
FOLLOW_STATUS: 'int|true|default=0|comment=状态 0=待处理,1=在处理,9=已完成',
FOLLOW_END_TIME: 'int|false|default=0|comment=截止时间',
FOLLOW_CATE_ID: 'string|true|default=0|comment=分类',
FOLLOW_CATE_NAME: 'string|false|comment=分类冗余',
FOLLOW_ORDER: 'int|true|default=9999',
FOLLOW_VOUCH: 'int|true|default=0',
FOLLOW_USER_ID: 'string|true|comment=发布用户ID',
FOLLOW_USER_NAME: 'string|false',
FOLLOW_ACCEPT_USER_ID: 'string|false|comment=接单用户ID',
FOLLOW_ACCEPT_USER_NAME: 'string|false|comment=接单用户名',
FOLLOW_ACCEPT_TIME: 'int|true|default=0',
FOLLOW_OVER_TIME: 'int|true|default=0',
FOLLOW_DAY: 'string|false|comment=日期',
FOLLOW_FORMS: 'array|true|default=[]',
FOLLOW_OBJ: 'object|true|default={}',
FOLLOW_FAV_CNT: 'int|true|default=0',
FOLLOW_FAV_LIST: 'array|true|default=[]',
FOLLOW_VIEW_CNT: 'int|true|default=0',
FOLLOW_QR: 'string|false',
FOLLOW_ADD_TIME: 'int|true',
FOLLOW_EDIT_TIME: 'int|true',
FOLLOW_ADD_IP: 'string|false',
FOLLOW_EDIT_IP: 'string|false',
ThingModel.DB_STRUCTURE = {
_pid: 'string|true',
THING_ID: 'string|true',
THING_STATUS: 'int|true|default=0|comment=状态 0=待处理,1=在处理,9=已完成',
THING_END_TIME: 'int|false|default=0|comment=截止时间',
THING_CATE_ID: 'string|true|default=0|comment=分类',
THING_CATE_NAME: 'string|false|comment=分类冗余',
THING_ORDER: 'int|true|default=9999',
THING_VOUCH: 'int|true|default=0',
THING_USER_ID: 'string|true|comment=发布用户ID',
THING_USER_NAME: 'string|false',
THING_ACCEPT_USER_ID: 'string|false|comment=接单用户ID',
THING_ACCEPT_USER_NAME: 'string|false|comment=接单用户名',
THING_ACCEPT_TIME: 'int|true|default=0',
THING_OVER_TIME: 'int|true|default=0',
THING_DAY: 'string|false|comment=日期',
THING_FORMS: 'array|true|default=[]',
THING_OBJ: 'object|true|default={}',
THING_FAV_CNT: 'int|true|default=0',
THING_FAV_LIST: 'array|true|default=[]',
THING_VIEW_CNT: 'int|true|default=0',
THING_QR: 'string|false',
THING_ADD_TIME: 'int|true',
THING_EDIT_TIME: 'int|true',
THING_ADD_IP: 'string|false',
THING_EDIT_IP: 'string|false',
};
```
# 核心代码
```bash
// 注册
async register(userId, {
mobile,
name,
pic,
forms,
status
}) {
// 判断是否存在
let where = {
USER_MINI_OPENID: userId
}
let cnt = await UserModel.count(where);
if (cnt > 0)
return await this.login(userId);
where = {
USER_MOBILE: mobile
}
cnt = await UserModel.count(where);
if (cnt > 0) this.AppError('该手机已注册');
// 入库
let data = {
USER_MINI_OPENID: userId,
USER_MOBILE: mobile,
USER_NAME: name,
USER_PIC: pic,
USER_OBJ: dataUtil.dbForms2Obj(forms),
USER_FORMS: forms,
USER_STATUS: Number(status)
}
await UserModel.insert(data);
return await this.login(userId);
}
/** 获取手机号码 */
async getPhone(cloudID) {
let cloud = cloudBase.getCloud();
let res = await cloud.getOpenData({
list: [cloudID], // 假设 event.openData.list 是一个 CloudID 字符串列表
});
if (res && res.list && res.list[0] && res.list[0].data) {
let phone = res.list[0].data.phoneNumber;
return phone;
} else
return '';
}
/** 取得我的用户信息 */
async getMyDetail(userId) {
let where = {
USER_MINI_OPENID: userId
}
let fields = 'USER_PIC,USER_MOBILE,USER_NAME,USER_FORMS,USER_OBJ,USER_STATUS,USER_CHECK_REASON'
return await UserModel.getOne(where, fields);
}
/** 修改用户资料 */
async editBase(userId, {
mobile,
name,
pic,
forms
}) {
let whereMobile = {
USER_MOBILE: mobile,
USER_MINI_OPENID: ['<>', userId]
}
let cnt = await UserModel.count(whereMobile);
if (cnt > 0) this.AppError('该手机已注册');
let where = {
USER_MINI_OPENID: userId
}
let user = await UserModel.getOne(where);
if (!user) return;
let data = {
USER_MOBILE: mobile,
USER_NAME: name,
USER_PIC: pic,
USER_OBJ: dataUtil.dbForms2Obj(forms),
USER_FORMS: forms,
};
if (user.USER_STATUS == UserModel.STATUS.UNCHECK)
data.USER_STATUS = UserModel.STATUS.UNUSE;
await UserModel.edit(where, data);
}
/** 登录 */
async login(userId) {
let where = {
'USER_MINI_OPENID': userId
};
let fields = 'USER_ID,USER_MINI_OPENID,USER_NAME,USER_PIC,USER_STATUS';
let user = await UserModel.getOne(where, fields);
let token = {};
if (user) {
// 正常用户
token.id = user.USER_MINI_OPENID;
token.key = user.USER_ID;
token.name = user.USER_NAME;
token.pic = user.USER_PIC;
token.status = user.USER_STATUS;
// 异步更新最近更新时间
let dataUpdate = {
USER_LOGIN_TIME: this._timestamp
};
UserModel.edit(where, dataUpdate);
UserModel.inc(where, 'USER_LOGIN_CNT', 1);
} else
token = null;
return {
token
};
}
```