profile.tmpl 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258
  1. {{template "base/head" .}}
  2. {{if not .IsLogged}}
  3. {{template "misc/signup_prompt" .}}
  4. {{end}}
  5. <div class="mobile-card">
  6. <div class="content">
  7. <img class="right floated mini ui image" src="{{AppendAvatarSize .Owner.RelAvatarLink 300}}" title="{{.Owner.Name}}">
  8. <div class="header">
  9. {{if .Owner.FullName}}
  10. <span class="mobile-name">{{.Owner.FullName}}</span>
  11. {{if .Owner.IsVerified}}<a class="poping up" target="_blank" href="/verified" data-content="Verified" data-variation="inverted tiny" data-position="right center"><i class="verified octicon octicon-verified"></i></a>{{end}}
  12. {{end}}
  13. </div>
  14. <div class="meta">
  15. @{{.Owner.Name}}
  16. </div>
  17. {{if .Owner.Status}}
  18. <div><p class="status" style="font-weight:500">{{.Owner.Status}}</p></div>
  19. {{end}}
  20. <div class="profile-card meta">
  21. {{if .Owner.Description}}
  22. <span class="user description">
  23. <p>{{.Owner.Description}}</p>
  24. </span>
  25. {{end}}
  26. {{if .Owner.Location}}
  27. <br/>
  28. <i class="menu-icon octicon">📍</i> {{.Owner.Location}}
  29. {{end}}
  30. {{if .Owner.Company}}
  31. <br/>
  32. <i class="menu-icon octicon">🏢</i> {{.Owner.Company}}
  33. {{if .Owner.IsStaff}}<span class="staff">Staff</span>{{end}}
  34. {{end}}
  35. {{if and .Owner.Email .IsLogged}}
  36. {{if not .Owner.PrivateEmail}}
  37. <br/>
  38. <i class="menu-icon octicon">📧</i>
  39. <a href="mailto:{{.Owner.Email}}" rel="nofollow">{{.Owner.Email}}</a>
  40. {{end}}
  41. {{else}}
  42. <br/>
  43. <i class="menu-icon octicon">📧</i>
  44. <a class="pro-truncate" href="{{AppURL}}login" rel="nofollow">{{.i18n.Tr "user.hide_email"}}</a>
  45. {{end}}
  46. {{if .Owner.Website}}
  47. <br/>
  48. <i class="menu-icon octicon">🔗</i>
  49. <a target="_blank" rel="noopener noreferrer me nofollow" href="{{.Owner.Website}}">{{.Owner.Website}}</a>
  50. {{end}}
  51. <br/>
  52. <i class="menu-icon octicon">🕒</i> {{.i18n.Tr "user.join_on"}} {{DateFmtShort .Owner.Created}}
  53. {{if .Owner.NumStars}}
  54. <br/>
  55. <i class="menu-icon octicon">⭐</i>
  56. {{.Owner.NumStars}} {{.i18n.Tr "user.starred"}}
  57. {{end}}
  58. <div>
  59. <i class="menu-icon octicon">🤵</i>
  60. <a href="{{.Owner.HomeLink}}/followers">
  61. {{.Owner.NumFollowers}} {{.i18n.Tr "user.followers"}}
  62. </a>
  63. -
  64. <a href="{{.Owner.HomeLink}}/following">
  65. {{.Owner.NumFollowing}} {{.i18n.Tr "user.following"}}
  66. </a>
  67. </div>
  68. </div>
  69. {{if or .Owner.GitoteDeveloper .Owner.IsBeta}}
  70. <div style="margin-top:1rem" class="ui mini images">
  71. {{if .Owner.GitoteDeveloper}}<img class="ui image" src="https://gitote-cdn.netlify.com/img/badges/gitotedeveloper.png">{{end}}
  72. {{if .Owner.IsBeta}}<img class="ui image" src="https://gitote-cdn.netlify.com/img/badges/beta.png">{{end}}
  73. </div>
  74. {{end}}
  75. {{if and .IsLogged (ne .LoggedUserName .Owner.Name)}}
  76. <div class="follow">
  77. {{if .LoggedUser.IsFollowing .Owner.ID}}
  78. <form action="{{.Link}}/action/unfollow?redirect_to={{$.Link}}" method="POST">
  79. {{.CSRFTokenHTML}}
  80. <button class="ui basic red button mobile-card follow">
  81. <i class="menu-icon octicon">👦🏽</i> {{.i18n.Tr "user.unfollow"}}
  82. </button>
  83. </form>
  84. {{else}}
  85. <form action="{{.Link}}/action/follow?redirect_to={{$.Link}}" method="POST">
  86. {{.CSRFTokenHTML}}
  87. <button class="ui basic green button mobile-card follow">
  88. <i class="menu-icon octicon">👦</i> {{.i18n.Tr "user.follow"}}
  89. </button>
  90. </form>
  91. {{end}}
  92. </div>
  93. {{end}}
  94. </div>
  95. </div>
  96. <div class="user profile">
  97. <div class="ui container">
  98. <div class="ui grid">
  99. <div class="ui five wide column">
  100. <div class="ui card" style="border: 2px solid {{.Owner.ThemeColor}};box-shadow: 5px 6px 0px {{.Owner.ThemeColor}}">
  101. {{if eq .LoggedUserName .Owner.Name}}
  102. <a class="image poping up" href="{{AppSubURL}}/user/settings/avatar" id="profile-avatar" data-content="{{.i18n.Tr "user.change_avatar"}}" data-variation="inverted tiny" data-position="bottom center">
  103. <img src="{{AppendAvatarSize .Owner.RelAvatarLink 400}}" title="{{.Owner.Name}}"/>
  104. </a>
  105. {{else}}
  106. <span class="image">
  107. <img src="{{AppendAvatarSize .Owner.RelAvatarLink 400}}" title="{{.Owner.Name}}"/>
  108. </span>
  109. {{end}}
  110. <div class="content">
  111. {{if .Owner.FullName}}
  112. <span class="header text center">
  113. {{.Owner.FullName}}
  114. {{if .Owner.IsVerified}}<a class="poping up" target="_blank" href="/verified" data-content="Verified" data-variation="inverted tiny" data-position="right center"><i class="verified octicon octicon-verified"></i></a>{{end}}
  115. {{if .Owner.IsStaff}}<a class="poping up" target="_blank" href="/jobs" data-content="Staff" data-variation="inverted tiny" data-position="right center"><i class="isstaff octicon octicon-tools"></i></a>{{end}}
  116. </span>
  117. {{end}}
  118. <center>
  119. <span class="username text center">
  120. <i style="font-size:12px" class="menu-icon octicon">👨‍💻</i> {{.Owner.Name}} <i style="font-size:12px" class="menu-icon octicon">👨‍💻</i>
  121. </span>
  122. {{if .IsAdmin}}
  123. <a class="poping up" href="{{AppURL}}admin/users/{{.Owner.ID}}" data-content="Settings" data-variation="inverted tiny" data-position="right center">⚙️</a>
  124. {{end}}
  125. <center>
  126. </div>
  127. <div class="extra content">
  128. <ul class="text black">
  129. {{if .Owner.Status}}
  130. <li class="ui center">
  131. <p style="font-weight:500">{{.Owner.Status}}</p>
  132. </li>
  133. {{end}}
  134. {{if or .Owner.Twitter .Owner.Linkedin .Owner.Github .Owner.Stackoverflow .Owner.Twitch .Owner.Telegram .Owner.Codepen}}
  135. <li class="ui center">
  136. {{if .Owner.Twitter}}<a href="https://twitter.com/{{.Owner.Twitter}}" target="_blank"><i class="twitter icon"></i></a>{{end}}
  137. {{if .Owner.Linkedin}}<a href="https://linkedin.com/in/{{.Owner.Linkedin}}" target="_blank"><i class="linkedin icon"></i></a>{{end}}
  138. {{if .Owner.Github}}<a href="https://github.com/{{.Owner.Github}}" target="_blank"><i class="github icon"></i></a>{{end}}
  139. {{if .Owner.Stackoverflow}}<a href="https://stackoverflow.com/users/{{.Owner.Stackoverflow}}" target="_blank"><i class="stack overflow icon"></i></a>{{end}}
  140. {{if .Owner.Twitch}}<a href="https://www.twitch.tv/{{.Owner.Twitch}}" target="_blank"><i class="twitch icon"></i></a>{{end}}
  141. {{if .Owner.Telegram}}<a href="https://t.me/{{.Owner.Telegram}}" target="_blank"><i class="telegram icon"></i></a>{{end}}
  142. {{if .Owner.Codepen}}<a href="https://codepen.io/{{.Owner.Codepen}}" target="_blank"><i class="codepen icon"></i></a>{{end}}
  143. {{if .Owner.Gitlab}}<a href="https://gitlab.com/{{.Owner.Gitlab}}" target="_blank"><i class="gitlab icon"></i></a>{{end}}
  144. </li>
  145. {{end}}
  146. {{if .Owner.Description}}
  147. <li class="user description">
  148. <p>{{.Owner.Description}}</p>
  149. </li>
  150. {{end}}
  151. {{if .Owner.Location}}
  152. <li><i class="menu-icon octicon">📍</i> <span class="pro-truncate">{{.Owner.Location}}</span></li>
  153. {{end}}
  154. {{if .Owner.Company}}
  155. <li>
  156. <i class="menu-icon octicon">🏢</i>
  157. <span class="pro-truncate">
  158. {{.Owner.Company}}
  159. {{if .Owner.IsStaff}}<span class="staff">Staff</span>{{end}}
  160. </span>
  161. </li>
  162. {{end}}
  163. {{if and .Owner.Email .IsLogged}}
  164. {{if not .Owner.PrivateEmail}}
  165. <li>
  166. <i class="menu-icon octicon">📧</i>
  167. <a class="pro-truncate" href="mailto:{{.Owner.Email}}" rel="nofollow">{{.Owner.Email}}</a>
  168. </li>
  169. {{end}}
  170. {{else}}
  171. <li>
  172. <i class="menu-icon octicon">📧</i>
  173. <a class="pro-truncate" href="{{AppURL}}login" rel="nofollow">{{.i18n.Tr "user.hide_email"}}</a>
  174. </li>
  175. {{end}}
  176. {{if .Owner.Website}}
  177. <li>
  178. <i class="menu-icon octicon">🔗</i>
  179. <a class="pro-truncate" target="_blank" rel="noopener noreferrer me nofollow" href="{{.Owner.Website}}">{{.Owner.Website}}</a>
  180. </li>
  181. {{end}}
  182. <li><i class="menu-icon octicon">🕒</i> {{.i18n.Tr "user.join_on"}} {{DateFmtShort .Owner.Created}}</li>
  183. {{if .Owner.NumStars}}
  184. <li>
  185. <i class="menu-icon octicon">⭐</i>
  186. {{.Owner.NumStars}} {{.i18n.Tr "user.starred"}}
  187. </li>
  188. {{end}}
  189. <li>
  190. <i class="menu-icon octicon">🤵</i>
  191. <a href="{{.Owner.HomeLink}}/followers">
  192. {{.Owner.NumFollowers}} {{.i18n.Tr "user.followers"}}
  193. </a>
  194. -
  195. <a href="{{.Owner.HomeLink}}/following">
  196. {{.Owner.NumFollowing}} {{.i18n.Tr "user.following"}}
  197. </a>
  198. </li>
  199. {{if or .Owner.GitoteDeveloper .Owner.IsBeta .Owner.Twitch}}
  200. <li>
  201. <div class="ui tiny images">
  202. {{if .Owner.GitoteDeveloper}}
  203. <a class="poping up" target="_blank" href="/jobs" data-content="Gitote Developer" data-variation="inverted tiny" data-position="left center">
  204. <img class="ui image" src="https://gitote-cdn.netlify.com/img/badges/gitotedeveloper.png">
  205. </a>
  206. {{end}}
  207. {{if .Owner.IsBeta}}
  208. <a class="poping up" target="_blank" href="/beta" data-content="Beta Member" data-variation="inverted tiny" data-position="left center">
  209. <img class="ui image" src="https://gitote-cdn.netlify.com/img/badges/beta.png">
  210. </a>
  211. {{end}}
  212. {{if .Owner.Twitch}}
  213. <a class="poping up" target="_blank" href="/streamer" data-content="Streamer" data-variation="inverted tiny" data-position="left center">
  214. <img class="ui image" src="https://gitote-cdn.netlify.com/img/badges/streamer.png">
  215. </a>
  216. {{end}}
  217. </div>
  218. </li>
  219. {{end}}
  220. {{if .Orgs}}
  221. <li>
  222. {{range .Orgs}}
  223. <a href="{{.HomeLink}}"><img class="org-grid ui mini image poping up" src="{{.RelAvatarLink}}" data-content="{{.Name}}" data-position="top center" data-variation="tiny inverted"></a>
  224. {{end}}
  225. </li>
  226. {{end}}
  227. {{if and .IsLogged (ne .LoggedUserName .Owner.Name)}}
  228. <li class="follow">
  229. {{if .LoggedUser.IsFollowing .Owner.ID}}
  230. <form action="{{.Link}}/action/unfollow?redirect_to={{$.Link}}" method="POST">
  231. {{.CSRFTokenHTML}}
  232. <button class="ui basic red button">
  233. <i class="menu-icon octicon">👦🏽</i> {{.i18n.Tr "user.unfollow"}}
  234. </button>
  235. </form>
  236. {{else}}
  237. <form action="{{.Link}}/action/follow?redirect_to={{$.Link}}" method="POST">
  238. {{.CSRFTokenHTML}}
  239. <button class="ui basic green button">
  240. <i class="menu-icon octicon">👦</i> {{.i18n.Tr "user.follow"}}
  241. </button>
  242. </form>
  243. {{end}}
  244. </li>
  245. {{end}}
  246. </ul>
  247. </div>
  248. </div>
  249. </div>
  250. {{template "user/activity" .}}
  251. </div>
  252. </div>
  253. </div>
  254. {{template "base/footer" .}}