layouts.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. BlazeLayout.setRoot('body');
  2. const i18nTagToT9n = (i18nTag) => {
  3. // t9n/i18n tags are same now, see: https://github.com/softwarerero/meteor-accounts-t9n/pull/129
  4. // but we keep this conversion function here, to be aware that that they are different system.
  5. return i18nTag;
  6. };
  7. Template.userFormsLayout.onRendered(() => {
  8. const i18nTag = navigator.language;
  9. if (i18nTag) {
  10. T9n.setLanguage(i18nTagToT9n(i18nTag));
  11. }
  12. EscapeActions.executeAll();
  13. });
  14. Template.userFormsLayout.helpers({
  15. languages() {
  16. return _.map(TAPi18n.getLanguages(), (lang, code) => {
  17. const tag = code;
  18. let name = lang.name;
  19. if (lang.name === 'br') {
  20. name = 'Brezhoneg';
  21. } else if (lang.name === 'ig') {
  22. name = 'Igbo';
  23. }
  24. return { tag, name };
  25. }).sort(function(a, b) {
  26. if (a.name === b.name) {
  27. return 0;
  28. } else {
  29. return a.name > b.name ? 1 : -1;
  30. }
  31. });
  32. },
  33. isCurrentLanguage() {
  34. const t9nTag = i18nTagToT9n(this.tag);
  35. const curLang = T9n.getLanguage() || 'en';
  36. return t9nTag === curLang;
  37. },
  38. isCas() {
  39. return Meteor.settings.public &&
  40. Meteor.settings.public.cas &&
  41. Meteor.settings.public.cas.loginUrl
  42. },
  43. casSignInLabel() {
  44. return TAPi18n.__('casSignIn', {}, T9n.getLanguage() || 'en');
  45. },
  46. });
  47. Template.userFormsLayout.events({
  48. 'change .js-userform-set-language'(evt) {
  49. const i18nTag = $(evt.currentTarget).val();
  50. T9n.setLanguage(i18nTagToT9n(i18nTag));
  51. evt.preventDefault();
  52. },
  53. 'click button#cas'() {
  54. Meteor.loginWithCas(function() {
  55. if (FlowRouter.getRouteName() == 'atSignIn') {
  56. FlowRouter.go('/');
  57. }
  58. });
  59. },
  60. });
  61. Template.defaultLayout.events({
  62. 'click .js-close-modal': () => {
  63. Modal.close();
  64. },
  65. });