userHeader.jade 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. template(name="headerUserBar")
  2. #header-user-bar
  3. a.header-user-bar-name.js-open-header-member-menu(title="{{_ 'memberMenuPopup-title'}}")
  4. .header-user-bar-avatar
  5. +userAvatar(userId=currentUser._id)
  6. unless isMiniScreen
  7. unless isSandstorm
  8. if currentUser.profile.fullname
  9. = currentUser.profile.fullname
  10. else
  11. = currentUser.username
  12. template(name="memberMenuPopup")
  13. ul.pop-over-list
  14. with currentUser
  15. li
  16. a.js-my-cards(href="{{pathFor 'my-cards'}}")
  17. i.fa.fa-list
  18. | {{_ 'my-cards'}}
  19. li
  20. a.js-due-cards(href="{{pathFor 'due-cards'}}")
  21. i.fa.fa-calendar
  22. | {{_ 'dueCards-title'}}
  23. li
  24. a.js-global-search(href="{{pathFor 'global-search'}}")
  25. i.fa.fa-search
  26. | {{_ 'globalSearch-title'}}
  27. li
  28. a(href="{{pathFor 'home'}}")
  29. span.fa.fa-home
  30. | {{_ 'all-boards'}}
  31. li
  32. a(href="{{pathFor 'public'}}")
  33. span.fa.fa-globe
  34. | {{_ 'public'}}
  35. li
  36. a.board-header-btn.js-open-archived-board
  37. i.fa.fa-archive
  38. span {{_ 'archives'}}
  39. unless currentUser.isWorker
  40. ul.pop-over-list
  41. li
  42. a(href="{{pathFor 'board' id=templatesBoardId slug=templatesBoardSlug}}")
  43. i.fa.fa-clone
  44. | {{_ 'templates'}}
  45. if currentUser.isAdmin
  46. li
  47. a.js-go-setting(href="{{pathFor 'setting'}}")
  48. i.fa.fa-lock
  49. | {{_ 'admin-panel'}}
  50. hr
  51. if isNotOAuth2AuthenticationMethod
  52. li
  53. a.js-edit-profile
  54. i.fa.fa-user
  55. | {{_ 'edit-profile'}}
  56. li
  57. a.js-change-settings
  58. i.fa.fa-cog
  59. | {{_ 'change-settings'}}
  60. li
  61. a.js-change-avatar
  62. i.fa.fa-picture-o
  63. | {{_ 'edit-avatar'}}
  64. unless isSandstorm
  65. if isNotOAuth2AuthenticationMethod
  66. li
  67. a.js-change-password
  68. i.fa.fa-key
  69. | {{_ 'changePasswordPopup-title'}}
  70. li
  71. a.js-change-language
  72. i.fa.fa-flag
  73. | {{_ 'changeLanguagePopup-title'}}
  74. unless isSandstorm
  75. hr
  76. ul.pop-over-list
  77. li
  78. a.js-logout
  79. i.fa.fa-sign-out
  80. | {{_ 'log-out'}}
  81. template(name="editProfilePopup")
  82. form
  83. label
  84. | {{_ 'fullname'}}
  85. input.js-profile-fullname(type="text" value=profile.fullname autofocus)
  86. label
  87. | {{_ 'username'}}
  88. span.error.hide.username-taken
  89. | {{_ 'error-username-taken'}}
  90. if allowUserNameChange
  91. input.js-profile-username(type="text" value=username)
  92. else
  93. input.js-profile-username(type="text" value=username readonly)
  94. label
  95. | {{_ 'initials'}}
  96. input.js-profile-initials(type="text" value=profile.initials)
  97. label
  98. | {{_ 'email'}}
  99. span.error.hide.email-taken
  100. | {{_ 'error-email-taken'}}
  101. if allowEmailChange
  102. input.js-profile-email(type="email" value="{{emails.[0].address}}")
  103. else
  104. input.js-profile-email(type="email" value="{{emails.[0].address}}" readonly)
  105. div.buttonsContainer
  106. input.primary.wide(type="submit" value="{{_ 'save'}}")
  107. if allowUserDelete
  108. div
  109. input#deleteButton.primary.wide(type="button" value="{{_ 'delete'}}")
  110. template(name="changePasswordPopup")
  111. +atForm(state='changePwd')
  112. template(name="changeLanguagePopup")
  113. ul.pop-over-list
  114. each languages
  115. li(class="{{# if isCurrentLanguage}}active{{/if}}")
  116. a.js-set-language
  117. = name
  118. if isCurrentLanguage
  119. i.fa.fa-check
  120. template(name="changeSettingsPopup")
  121. ul.pop-over-list
  122. //li
  123. // a.js-toggle-system-messages
  124. // i.fa.fa-comments-o
  125. // | {{_ 'hide-system-messages'}}
  126. // if hiddenSystemMessages
  127. // i.fa.fa-check
  128. li
  129. a.js-toggle-desktop-drag-handles
  130. i.fa.fa-arrows
  131. | {{_ 'show-desktop-drag-handles'}}
  132. if showDesktopDragHandles
  133. i.fa.fa-check
  134. unless currentUser.isWorker
  135. li
  136. label.bold.clear
  137. i.fa.fa-sort-numeric-asc
  138. | {{_ 'show-cards-minimum-count'}}
  139. input#show-cards-count-at.inline-input.left(type="number" value="#{showCardsCountAt}" min="-1")
  140. label.bold.clear
  141. i.fa.fa-calendar
  142. | {{_ 'start-day-of-week'}}
  143. select#start-day-of-week.inline-input.left
  144. each day in weekDays startDayOfWeek
  145. if day.isSelected
  146. option(selected="true", value="#{day.value}") #{day.name}
  147. else
  148. option(value="#{day.value}") #{day.name}
  149. input.js-apply-user-settings.left(type="submit" value="{{_ 'apply'}}")
  150. template(name="userDeletePopup")
  151. unless currentUser.isWorker
  152. p {{_ 'delete-user-confirm-popup'}}
  153. button.js-confirm.negate.full(type="submit") {{_ 'delete'}}