45 lines
972 B
JavaScript
45 lines
972 B
JavaScript
import { DataTypes, sequelize } from '../sequelize';
|
|
import Atlas from './Atlas';
|
|
import Document from './Document';
|
|
import User from './User';
|
|
|
|
const Team = sequelize.define(
|
|
'team',
|
|
{
|
|
id: {
|
|
type: DataTypes.UUID,
|
|
defaultValue: DataTypes.UUIDV4,
|
|
primaryKey: true,
|
|
},
|
|
name: DataTypes.STRING,
|
|
slackId: { type: DataTypes.STRING, allowNull: true },
|
|
slackData: DataTypes.JSONB,
|
|
},
|
|
{
|
|
instanceMethods: {
|
|
async createFirstAtlas(userId) {
|
|
const atlas = await Atlas.create({
|
|
name: this.name,
|
|
description: 'Your first Atlas',
|
|
type: 'atlas',
|
|
teamId: this.id,
|
|
creatorId: userId,
|
|
});
|
|
return atlas;
|
|
},
|
|
},
|
|
indexes: [
|
|
{
|
|
unique: true,
|
|
fields: ['slackId'],
|
|
},
|
|
],
|
|
}
|
|
);
|
|
|
|
Team.hasMany(Atlas, { as: 'atlases' });
|
|
Team.hasMany(Document, { as: 'documents' });
|
|
Team.hasMany(User, { as: 'users' });
|
|
|
|
export default Team;
|