| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- Blaze.registerHelper('currentBoard', () => {
- const boardId = Session.get('currentBoard');
- if (boardId) {
- return Boards.findOne(boardId);
- }
- });
- Blaze.registerHelper('currentCard', () => {
- const cardId = Session.get('currentCard');
- if (cardId) {
- return Cards.findOne(cardId);
- }
- });
- Blaze.registerHelper('getUser', (userId) => Users.findOne(userId));
- // XXX I believe we should compute a HTML rendered field on the server that
- // would handle markdown, emojies and user mentions. We can simply have two
- // fields, one source, and one compiled version (in HTML) and send only the
- // compiled version to most users -- who don't need to edit.
- // In the meantime, all the transformation are done on the client using the
- // Blaze API.
- const at = HTML.CharRef({html: '@', str: '@'});
- Blaze.Template.registerHelper('mentions', new Template('mentions', function() {
- const view = this;
- const currentBoard = Session.get('currentBoard');
- const knowedUsers = _.map(currentBoard.members, (member) => {
- member.username = Users.findOne(member.userId).username;
- return member;
- });
- const mentionRegex = /\B@(\w*)/gi;
- let content = Blaze.toHTML(view.templateContentBlock);
- let currentMention, knowedUser, href, linkClass, linkValue, link;
- while (Boolean(currentMention = mentionRegex.exec(content))) {
- knowedUser = _.findWhere(knowedUsers, { username: currentMention[1] });
- if (!knowedUser)
- continue;
- linkValue = [' ', at, knowedUser.username];
- // XXX We need to convert to flow router
- href = Router.url('Profile', { username: knowedUser.username });
- linkClass = 'atMention';
- if (knowedUser.userId === Meteor.userId())
- linkClass += ' me';
- link = HTML.A({ href, 'class': linkClass }, linkValue);
- content = content.replace(currentMention[0], Blaze.toHTML(link));
- }
- return HTML.Raw(content);
- }));
|