创建公会
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
import BaseModel from './BaseModel';
|
||||
import { index, getModelForClass, prop, DocumentType, Ref } from '@typegoose/typegoose';
|
||||
import Role from './Role';
|
||||
import { genCode } from '../pubUtils/util';
|
||||
import { GUILD_STRUCTURE, GUILD_STATUS } from '../consts';
|
||||
|
||||
class Structure {
|
||||
@prop({ required: true })
|
||||
@@ -11,8 +13,9 @@ class Structure {
|
||||
|
||||
@index({ roleId: 1 })
|
||||
export default class Guild extends BaseModel {
|
||||
|
||||
@prop({ required: true })
|
||||
code: string;
|
||||
code: string;
|
||||
|
||||
@prop({ required: true })
|
||||
name: string;
|
||||
@@ -27,10 +30,10 @@ export default class Guild extends BaseModel {
|
||||
peopleNum: number;
|
||||
|
||||
@prop({ required: true })
|
||||
leader: Ref<Role>;
|
||||
leader: Ref<Role>;
|
||||
|
||||
@prop({ required: true, default: true })
|
||||
isAuto: boolean;
|
||||
isAuto: boolean;
|
||||
|
||||
@prop({ required: true, default: 0 })
|
||||
ceCondition: number;
|
||||
@@ -59,15 +62,42 @@ export default class Guild extends BaseModel {
|
||||
@prop({ required: true, type: String, default: [] })
|
||||
members: string[]; // 军团成员的roleId,用于增加战力的时候加入总战力
|
||||
|
||||
@prop({ required: true, type: Structure, default: [] })
|
||||
@prop({ required: true, type: Structure, default: getInitStructure(), _id: false })
|
||||
structure: Structure[]
|
||||
|
||||
@prop({ required: true })
|
||||
status:number;
|
||||
|
||||
@prop({ required: true, default: GUILD_STATUS.RUNNING, enum: GUILD_STATUS })
|
||||
status: number;
|
||||
|
||||
public static async createGuild(params: CreateParam) {
|
||||
const doc = new GuildModel();
|
||||
const update = Object.assign(doc.toJSON(), params);
|
||||
delete update._id;
|
||||
const code = genCode(6);
|
||||
const result: GuildType = await GuildModel.findOneAndUpdate({ code }, update, { upsert: true, new: true })
|
||||
.select('code name icon notice introduce lv fund peopleNum manageNum activeDaily activeWeekly ceCondition isAuto leader structure')
|
||||
.populate('leader', 'name sHid headHid lv updatedAt', 'Role')
|
||||
.lean();
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
public static async checkName(name: string) {
|
||||
const result = await GuildModel.findOne({ name, status: 1 }).lean();
|
||||
return !!result;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
export const GuildModel = getModelForClass(Guild);
|
||||
|
||||
export interface GuildType extends Pick<DocumentType<Guild>, keyof Guild> { };
|
||||
export type GuildUpdateParam = Partial<GuildType>; // 将所有字段变成可选项
|
||||
export type GuildUpdateParam = Partial<GuildType>; // 将所有字段变成可选项
|
||||
type CreateParam = Pick<GuildType, 'name'|'icon'|'notice'|'leader'|'members'|'ce'>
|
||||
|
||||
function getInitStructure() {
|
||||
let structure = new Array<Structure>();
|
||||
for (let id = GUILD_STRUCTURE.START; id < GUILD_STRUCTURE.END; id++) {
|
||||
structure.push({ id, lv: 1 });
|
||||
}
|
||||
return structure;
|
||||
}
|
||||
Reference in New Issue
Block a user