mirror of
https://github.com/wekan/wekan.git
synced 2025-04-24 14:08:31 -04:00
1358 lines
44 KiB
JavaScript
1358 lines
44 KiB
JavaScript
import { DataCache } from 'meteor-reactive-cache';
|
|
import { Jsons } from './jsons';
|
|
|
|
// Server isn't reactive, so search for the data always.
|
|
ReactiveCacheServer = {
|
|
getBoard(idOrFirstObjectSelector, options) {
|
|
const ret = Boards.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getBoards(selector, options, getQuery) {
|
|
let ret = Boards.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getList(idOrFirstObjectSelector, options) {
|
|
const ret = Lists.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getLists(selector, options, getQuery) {
|
|
let ret = Lists.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getSwimlane(idOrFirstObjectSelector, options) {
|
|
const ret = Swimlanes.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getSwimlanes(selector, options, getQuery) {
|
|
let ret = Swimlanes.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklist(idOrFirstObjectSelector, options) {
|
|
const ret = Checklists.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getChecklists(selector, options, getQuery) {
|
|
let ret = Checklists.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklistItem(idOrFirstObjectSelector, options) {
|
|
const ret = ChecklistItems.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getChecklistItems(selector, options, getQuery) {
|
|
let ret = ChecklistItems.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getCard(idOrFirstObjectSelector, options) {
|
|
const ret = Cards.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getCards(selector, options, getQuery) {
|
|
let ret = Cards.find(selector, options, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getCardComment(idOrFirstObjectSelector, options) {
|
|
const ret = CardComments.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getCardComments(selector, options, getQuery) {
|
|
let ret = CardComments.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getCardCommentReaction(idOrFirstObjectSelector, options) {
|
|
const ret = CardCommentReactions.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getCardCommentReactions(selector, options, getQuery) {
|
|
let ret = CardCommentReactions.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getCustomField(idOrFirstObjectSelector, options) {
|
|
const ret = CustomFields.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getCustomFields(selector, options, getQuery) {
|
|
let ret = CustomFields.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getAttachment(idOrFirstObjectSelector, options) {
|
|
const ret = Attachments.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getAttachments(selector, options, getQuery) {
|
|
let ret = Attachments.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getAvatar(idOrFirstObjectSelector, options) {
|
|
const ret = Avatars.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getAvatars(selector, options, getQuery) {
|
|
let ret = Avatars.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getUser(idOrFirstObjectSelector, options) {
|
|
const ret = Users.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getUsers(selector, options, getQuery) {
|
|
let ret = Users.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getOrg(idOrFirstObjectSelector, options) {
|
|
const ret = Org.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getOrgs(selector, options, getQuery) {
|
|
let ret = Org.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getTeam(idOrFirstObjectSelector, options) {
|
|
const ret = Team.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getTeams(selector, options, getQuery) {
|
|
let ret = Team.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getActivity(idOrFirstObjectSelector, options) {
|
|
const ret = Activities.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getActivities(selector, options, getQuery) {
|
|
let ret = Activities.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getRule(idOrFirstObjectSelector, options) {
|
|
const ret = Rules.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getRules(selector, options, getQuery) {
|
|
let ret = Rules.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getAction(idOrFirstObjectSelector, options) {
|
|
const ret = Actions.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getActions(selector, options, getQuery) {
|
|
let ret = Actions.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getTrigger(idOrFirstObjectSelector, options) {
|
|
const ret = Triggers.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getTriggers(selector, options, getQuery) {
|
|
let ret = Triggers.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getImpersonatedUser(idOrFirstObjectSelector, options) {
|
|
const ret = ImpersonatedUsers.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getImpersonatedUsers(selector, options, getQuery) {
|
|
let ret = ImpersonatedUsers.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getIntegration(idOrFirstObjectSelector, options) {
|
|
const ret = Integrations.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getIntegrations(selector, options, getQuery) {
|
|
let ret = Integrations.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getSessionData(idOrFirstObjectSelector, options) {
|
|
const ret = SessionData.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getSessionDatas(selector, options, getQuery) {
|
|
let ret = SessionData.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getInvitationCode(idOrFirstObjectSelector, options) {
|
|
const ret = InvitationCodes.findOne(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getInvitationCodes(selector, options, getQuery) {
|
|
let ret = InvitationCodes.find(selector, options);
|
|
if (getQuery !== true) {
|
|
ret = ret.fetch();
|
|
}
|
|
return ret;
|
|
},
|
|
getCurrentSetting() {
|
|
const ret = Settings.findOne();
|
|
return ret;
|
|
},
|
|
getCurrentUser() {
|
|
const ret = Meteor.user();
|
|
return ret;
|
|
},
|
|
}
|
|
|
|
// only the Client is reactive
|
|
// saving the result has a big advantage if the query is big and often searched for the same data again and again
|
|
// if the data is changed in the client, the data is saved to the server and depending code is reactive called again
|
|
ReactiveCacheClient = {
|
|
getBoard(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__board) {
|
|
this.__board = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Boards.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__board.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getBoards(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__boards) {
|
|
this.__boards = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Boards.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__boards.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getList(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__list) {
|
|
this.__list = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Lists.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__list.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getLists(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__lists) {
|
|
this.__lists = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Lists.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__lists.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getSwimlane(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__swimlane) {
|
|
this.__swimlane = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Swimlanes.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__swimlane.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getSwimlanes(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__swimlanes) {
|
|
this.__swimlanes = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Swimlanes.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__swimlanes.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getChecklist(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__checklist) {
|
|
this.__checklist = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Checklists.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__checklist.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getChecklists(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__checklists) {
|
|
this.__checklists = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Checklists.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__checklists.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getChecklistItem(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__checklistItem) {
|
|
this.__checklistItem = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = ChecklistItems.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__checklistItem.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getChecklistItems(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__checklistItems) {
|
|
this.__checklistItems = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = ChecklistItems.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__checklistItems.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getCard(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__card) {
|
|
this.__card = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Cards.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__card.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getCards(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__cards) {
|
|
this.__cards = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Cards.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__cards.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getCardComment(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__cardComment) {
|
|
this.__cardComment = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = CardComments.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__cardComment.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getCardComments(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__cardComments) {
|
|
this.__cardComments = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = CardComments.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__cardComments.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getCardCommentReaction(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__cardCommentReaction) {
|
|
this.__cardCommentReaction = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = CardCommentReactions.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__cardCommentReaction.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getCardCommentReactions(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__cardCommentReactions) {
|
|
this.__cardCommentReactions = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = CardCommentReactions.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__cardCommentReactions.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getCustomField(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__customField) {
|
|
this.__customField = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = CustomFields.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__customField.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getCustomFields(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__customFields) {
|
|
this.__customFields = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = CustomFields.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__customFields.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getAttachment(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__attachment) {
|
|
this.__attachment = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Attachments.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__attachment.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getAttachments(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__attachments) {
|
|
this.__attachments = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Attachments.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__attachments.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getAvatar(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__avatar) {
|
|
this.__avatar = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Avatars.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__avatar.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getAvatars(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__avatars) {
|
|
this.__avatars = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Avatars.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__avatars.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getUser(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__user) {
|
|
this.__user = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Users.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__user.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getUsers(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__users) {
|
|
this.__users = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Users.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__users.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getOrg(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__org) {
|
|
this.__org = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Org.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__org.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getOrgs(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__orgs) {
|
|
this.__orgs = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Org.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__orgs.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getTeam(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__team) {
|
|
this.__team = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Team.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__team.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getTeams(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__teams) {
|
|
this.__teams = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Team.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__teams.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getActivity(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__activity) {
|
|
this.__activity = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Activities.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__activity.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getActivities(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__activities) {
|
|
this.__activities = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Activities.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__activities.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getRule(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__rule) {
|
|
this.__rule = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Rules.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__rule.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getRules(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__rules) {
|
|
this.__rules = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Rules.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__rules.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getAction(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__action) {
|
|
this.__action = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Actions.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__action.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getActions(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__actions) {
|
|
this.__actions = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Actions.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__actions.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getTrigger(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__trigger) {
|
|
this.__trigger = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Triggers.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__trigger.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getTriggers(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__triggers) {
|
|
this.__triggers = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Triggers.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__triggers.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getImpersonatedUser(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__impersonatedUser) {
|
|
this.__impersonatedUser = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = ImpersonatedUsers.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__impersonatedUser.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getImpersonatedUsers(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__impersonatedUsers) {
|
|
this.__impersonatedUsers = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = ImpersonatedUsers.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__impersonatedUsers.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getIntegration(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__integration) {
|
|
this.__integration = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = Integrations.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__integration.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getIntegrations(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__integrations) {
|
|
this.__integrations = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = Integrations.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__integrations.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getInvitationCode(idOrFirstObjectSelector, options) {
|
|
const idOrFirstObjectSelect = {idOrFirstObjectSelector, options}
|
|
if (!this.__invitationCode) {
|
|
this.__invitationCode = new DataCache(_idOrFirstObjectSelect => {
|
|
const __select = Jsons.parse(_idOrFirstObjectSelect);
|
|
const _ret = InvitationCodes.findOne(__select.idOrFirstObjectSelector, __select.options);
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__invitationCode.get(Jsons.stringify(idOrFirstObjectSelect));
|
|
return ret;
|
|
},
|
|
getInvitationCodes(selector, options, getQuery) {
|
|
const select = {selector, options, getQuery}
|
|
if (!this.__invitationCodes) {
|
|
this.__invitationCodes = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
let _ret = InvitationCodes.find(__select.selector, __select.options);
|
|
if (__select.getQuery !== true) {
|
|
_ret = _ret.fetch();
|
|
}
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__invitationCodes.get(Jsons.stringify(select));
|
|
return ret;
|
|
},
|
|
getCurrentSetting() {
|
|
if (!this.__currentSetting || !this.__currentSetting.get()) {
|
|
this.__currentSetting = new DataCache(() => {
|
|
const _ret = Settings.findOne();
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__currentSetting.get();
|
|
return ret;
|
|
},
|
|
getCurrentUser() {
|
|
if (!this.__currentUser || !this.__currentUser.get()) {
|
|
this.__currentUser = new DataCache(() => {
|
|
const _ret = Meteor.user();
|
|
return _ret;
|
|
});
|
|
}
|
|
const ret = this.__currentUser.get();
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
// global Reactive Cache class to avoid big overhead while searching for the same data often again
|
|
// This class calls 2 implementation, for server and client code
|
|
//
|
|
// having this class here has several advantages:
|
|
// - The Programmer hasn't to care about in which context he call's this class
|
|
// - having all queries together in 1 class to make it possible to see which queries in Wekan happens, e.g. with console.log
|
|
ReactiveCache = {
|
|
getBoard(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getBoard(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getBoard(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getBoards(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getBoards(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getBoards(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getList(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getList(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getList(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getLists(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getLists(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getLists(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getSwimlane(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getSwimlane(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getSwimlane(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getSwimlanes(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getSwimlanes(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getSwimlanes(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklist(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getChecklist(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getChecklist(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklists(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getChecklists(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getChecklists(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklistItem(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getChecklistItem(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getChecklistItem(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklistItems(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getChecklistItems(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getChecklistItems(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getCard(idOrFirstObjectSelector, options, noCache = false) {
|
|
let ret;
|
|
if (Meteor.isServer || noCache === true) {
|
|
ret = ReactiveCacheServer.getCard(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCard(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getCards(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCards(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCards(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getCardComment(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCardComment(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCardComment(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getCardComments(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCardComments(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCardComments(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getCardCommentReaction(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCardCommentReaction(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCardCommentReaction(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getCardCommentReactions(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCardCommentReactions(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCardCommentReactions(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getCustomField(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCustomField(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCustomField(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getCustomFields(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCustomFields(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getCustomFields(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getAttachment(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getAttachment(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getAttachment(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getAttachments(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getAttachments(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getAttachments(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getAvatar(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getAvatar(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getAvatar(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getAvatars(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getAvatars(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getAvatars(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getUser(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getUser(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getUser(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getUsers(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getUsers(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getUsers(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getOrg(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getOrg(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getOrg(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getOrgs(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getOrgs(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getOrgs(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getTeam(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getTeam(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getTeam(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getTeams(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getTeams(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getTeams(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getActivity(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getActivity(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getActivity(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getActivities(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getActivities(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getActivities(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getRule(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getRule(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getRule(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getRules(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getRules(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getRules(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getAction(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getAction(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getAction(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getActions(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getActions(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getActions(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getTrigger(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getTrigger(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getTrigger(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getTriggers(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getTriggers(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getTriggers(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getImpersonatedUser(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getImpersonatedUser(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getImpersonatedUser(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getImpersonatedUsers(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getImpersonatedUsers(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getImpersonatedUsers(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getIntegration(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getIntegration(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getIntegration(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getIntegrations(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getIntegrations(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getIntegrations(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getSessionData(idOrFirstObjectSelector, options) {
|
|
// no reactive cache, otherwise global search will not work anymore
|
|
let ret = ReactiveCacheServer.getSessionData(idOrFirstObjectSelector, options);
|
|
return ret;
|
|
},
|
|
getSessionDatas(selector, options, getQuery) {
|
|
// no reactive cache, otherwise global search will not work anymore
|
|
let ret = ReactiveCacheServer.getSessionDatas(selector, options, getQuery);
|
|
return ret;
|
|
},
|
|
getInvitationCode(idOrFirstObjectSelector, options) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getInvitationCode(idOrFirstObjectSelector, options);
|
|
} else {
|
|
ret = ReactiveCacheClient.getInvitationCode(idOrFirstObjectSelector, options);
|
|
}
|
|
return ret;
|
|
},
|
|
getInvitationCodes(selector, options, getQuery) {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getInvitationCodes(selector, options, getQuery);
|
|
} else {
|
|
ret = ReactiveCacheClient.getInvitationCodes(selector, options, getQuery);
|
|
}
|
|
return ret;
|
|
},
|
|
getCurrentSetting() {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCurrentSetting();
|
|
} else {
|
|
ret = ReactiveCacheClient.getCurrentSetting();
|
|
}
|
|
return ret;
|
|
},
|
|
getCurrentUser() {
|
|
let ret;
|
|
if (Meteor.isServer) {
|
|
ret = ReactiveCacheServer.getCurrentUser();
|
|
} else {
|
|
ret = ReactiveCacheClient.getCurrentUser();
|
|
}
|
|
return ret;
|
|
},
|
|
}
|
|
|
|
// Client side little MiniMongo DB "Index"
|
|
ReactiveMiniMongoIndex = {
|
|
getSubTasksWithParentId(parentId, addSelect = {}, options) {
|
|
let ret = []
|
|
if (parentId) {
|
|
const select = {addSelect, options}
|
|
if (!this.__subTasksWithId) {
|
|
this.__subTasksWithId = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
const _subTasks = ReactiveCache.getCards(
|
|
{ parentId: { $exists: true },
|
|
...__select.addSelect,
|
|
}, __select.options);
|
|
const _ret = _.groupBy(_subTasks, 'parentId')
|
|
return _ret;
|
|
});
|
|
}
|
|
ret = this.__subTasksWithId.get(Jsons.stringify(select));
|
|
if (ret) {
|
|
ret = ret[parentId] || [];
|
|
}
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklistsWithCardId(cardId, addSelect = {}, options) {
|
|
let ret = []
|
|
if (cardId) {
|
|
const select = {addSelect, options}
|
|
if (!this.__checklistsWithId) {
|
|
this.__checklistsWithId = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
const _checklists = ReactiveCache.getChecklists(
|
|
{ cardId: { $exists: true },
|
|
...__select.addSelect,
|
|
}, __select.options);
|
|
const _ret = _.groupBy(_checklists, 'cardId')
|
|
return _ret;
|
|
});
|
|
}
|
|
ret = this.__checklistsWithId.get(Jsons.stringify(select));
|
|
if (ret) {
|
|
ret = ret[cardId] || [];
|
|
}
|
|
}
|
|
return ret;
|
|
},
|
|
getChecklistItemsWithChecklistId(checklistId, addSelect = {}, options) {
|
|
let ret = []
|
|
if (checklistId) {
|
|
const select = {addSelect, options}
|
|
if (!this.__checklistItemsWithId) {
|
|
this.__checklistItemsWithId = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
const _checklistItems = ReactiveCache.getChecklistItems(
|
|
{ checklistId: { $exists: true },
|
|
...__select.addSelect,
|
|
}, __select.options);
|
|
const _ret = _.groupBy(_checklistItems, 'checklistId')
|
|
return _ret;
|
|
});
|
|
}
|
|
ret = this.__checklistItemsWithId.get(Jsons.stringify(select));
|
|
if (ret) {
|
|
ret = ret[checklistId] || [];
|
|
}
|
|
}
|
|
return ret;
|
|
},
|
|
getCardCommentsWithCardId(cardId, addSelect = {}, options) {
|
|
let ret = []
|
|
if (cardId) {
|
|
const select = {addSelect, options}
|
|
if (!this.__cardCommentsWithId) {
|
|
this.__cardCommentsWithId = new DataCache(_select => {
|
|
const __select = Jsons.parse(_select);
|
|
const _cardComments = ReactiveCache.getCardComments(
|
|
{ cardId: { $exists: true },
|
|
...__select.addSelect,
|
|
}, __select.options);
|
|
const _ret = _.groupBy(_cardComments, 'cardId')
|
|
return _ret;
|
|
});
|
|
}
|
|
ret = this.__cardCommentsWithId.get(Jsons.stringify(select));
|
|
if (ret) {
|
|
ret = ret[cardId] || [];
|
|
}
|
|
}
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
export { ReactiveCache, ReactiveMiniMongoIndex };
|