Вот мой сценарий:
У меня есть шаблон макета, который должен проверить, принадлежит ли пользователь хотя бы к одной команде. Если нет, то отображать div по всему сайту. Пользователь может видеть только команды, к которым он принадлежит, поэтому я создал простую публикацию, которая работает: (примеры кода — CoffeeScript)
Meteor.publish 'teams', ->
return null if !@userId
Teams.find {'members._id': @userId}
Это прекрасно работает, и Teams.find().fetch() в консоли дает ожидаемые результаты.
Однако, если я вставлю этот код, скажем, в Template.layout.rendered, он не сработает.
Template.layout.rendered = ->
teams = Teams.find().fetch()
hasTeams = teams.length > 0
if !hasTeams
...do stuff..
Очевидно, это не работает, потому что поиск Teams является асинхронным и не загружается, когда ему нужно принять решение. С обычным шаблоном/страницей я бы просто использовал IronRouter waitOn(), но что мне делать с макетом?
Я мог бы сделать waitOn на своем маршрутизаторе, но, поскольку данные являются «глобальными» и будут использоваться везде, а также поскольку пользователь может использовать глубокие ссылки на сайт повсюду, я не хочу добавлять это ожидание КАЖДОМУ. единый маршрут.
Итак, каков правильный шаблон? Как заставить клиент метеора загружать глобальные данные и ждать их перед запуском маршрута?