summaryrefslogtreecommitdiffstats
path: root/client/components/main/helpers.js
blob: 7ad602f180ec22d4f2c2dd64f8420676100af967 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
var Helpers = {
  error: function() {
    return Session.get('error');
  },

  toLowerCase: function(text) {
    return text && text.toLowerCase();
  },

  toUpperCase: function(text) {
    return text && text.toUpperCase();
  },

  firstChar: function(text) {
    return text && text[0].toUpperCase();
  },

  session: function(prop) {
    return Session.get(prop);
  },

  getUser: function(userId) {
    return Users.findOne(userId);
  }
};

// Register all Helpers
_.each(Helpers, function(fn, name) { Blaze.registerHelper(name, fn); });

// 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.
var at = HTML.CharRef({html: '@', str: '@'});
Blaze.Template.registerHelper('mentions', new Template('mentions', function() {
  var view = this;
  var content = Blaze.toHTML(view.templateContentBlock);
  var currentBoard = Session.get('currentBoard');
  var knowedUsers = _.map(currentBoard.members, function(member) {
    member.username = Users.findOne(member.userId).username;
    return member;
  });

  var mentionRegex = /\B@(\w*)/gi;
  var currentMention, knowedUser, href, linkClass, linkValue, link;
  while (currentMention = mentionRegex.exec(content)) {

    knowedUser = _.findWhere(knowedUsers, { username: currentMention[1] });
    if (! knowedUser)
      continue;

    linkValue = [' ', at, knowedUser.username];
    href = Router.url('Profile', { username: knowedUser.username });
    linkClass = 'atMention' + (knowedUser.userId === Meteor.userId() ? ' me' : '');
    link = HTML.A({ href: href, 'class': linkClass }, linkValue);

    content = content.replace(currentMention[0], Blaze.toHTML(link));
  }

  return HTML.Raw(content);
}));