2019-07-15 19:39:30 +03:00
|
|
|
Org = new Mongo.Collection('org');
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A Organization in wekan
|
|
|
|
*/
|
|
|
|
Org.attachSchema(
|
|
|
|
new SimpleSchema({
|
2019-07-15 23:50:30 +03:00
|
|
|
_id: {
|
2019-07-15 19:39:30 +03:00
|
|
|
/**
|
|
|
|
* the organization id
|
|
|
|
*/
|
|
|
|
type: Number,
|
|
|
|
optional: true,
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
|
|
autoValue() {
|
|
|
|
if (this.isInsert && !this.isSet) {
|
2019-07-15 23:36:29 +03:00
|
|
|
return incrementCounter('counters', 'orgId', 1);
|
2019-07-15 19:39:30 +03:00
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
version: {
|
|
|
|
/**
|
|
|
|
* the version of the organization
|
|
|
|
*/
|
|
|
|
type: Number,
|
|
|
|
optional: true,
|
|
|
|
},
|
|
|
|
name: {
|
|
|
|
/**
|
|
|
|
* name of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 190,
|
|
|
|
},
|
|
|
|
address1: {
|
|
|
|
/**
|
|
|
|
* address1 of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
|
|
|
address2: {
|
|
|
|
/**
|
|
|
|
* address2 of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
|
|
|
city: {
|
|
|
|
/**
|
|
|
|
* city of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
|
|
|
state: {
|
|
|
|
/**
|
|
|
|
* state of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
2019-07-15 23:36:29 +03:00
|
|
|
zipCode: {
|
2019-07-15 19:39:30 +03:00
|
|
|
/**
|
2019-07-15 23:36:29 +03:00
|
|
|
* zipCode of the organization
|
2019-07-15 19:39:30 +03:00
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 50,
|
|
|
|
},
|
|
|
|
country: {
|
|
|
|
/**
|
|
|
|
* country of the organization
|
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
2019-07-15 23:36:29 +03:00
|
|
|
billingEmail: {
|
2019-07-15 19:39:30 +03:00
|
|
|
/**
|
2019-07-15 23:36:29 +03:00
|
|
|
* billingEmail of the organization
|
2019-07-15 19:39:30 +03:00
|
|
|
*/
|
|
|
|
type: String,
|
|
|
|
optional: true,
|
|
|
|
max: 255,
|
|
|
|
},
|
|
|
|
createdAt: {
|
|
|
|
/**
|
|
|
|
* creation date of the organization
|
|
|
|
*/
|
|
|
|
type: Date,
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
|
|
autoValue() {
|
|
|
|
if (this.isInsert) {
|
|
|
|
return new Date();
|
|
|
|
} else {
|
|
|
|
this.unset();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
modifiedAt: {
|
|
|
|
type: Date,
|
|
|
|
denyUpdate: false,
|
|
|
|
// eslint-disable-next-line consistent-return
|
|
|
|
autoValue() {
|
|
|
|
if (this.isInsert || this.isUpsert || this.isUpdate) {
|
|
|
|
return new Date();
|
|
|
|
} else {
|
|
|
|
this.unset();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}),
|
|
|
|
);
|
|
|
|
|
2019-07-15 22:47:30 +03:00
|
|
|
if (Meteor.isServer) {
|
|
|
|
// Index for Organization name.
|
|
|
|
Meteor.startup(() => {
|
|
|
|
Org._collection._ensureIndex({ name: -1 });
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2019-07-15 19:39:30 +03:00
|
|
|
export default Org;
|