profile.tmpl 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  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 290}}" 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. {{if .Owner.IsMaker}}<a class="poping up" target="_blank" href="/maker" data-content="Maker" data-variation="inverted tiny" data-position="right center"><i class="maker octicon octicon-paintcan"></i></a>{{end}}
  13. {{if .Owner.IsBugHunter}}<a class="poping up" target="_blank" href="/security" data-content="Bug Hunter" data-variation="inverted tiny" data-position="right center"><i class="bughunter octicon octicon-gist-secret"></i></a>{{end}}
  14. {{if .Owner.IsBeta}}<a class="poping up" target="_blank" href="/developer" data-content="Beta Member" data-variation="inverted tiny" data-position="right center"><i class="developer octicon octicon-circuit-board"></i></a>{{end}}
  15. {{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}}
  16. {{end}}
  17. </div>
  18. <div class="meta">
  19. @{{.Owner.Name}}
  20. </div>
  21. <div class="profile-card meta">
  22. {{if .Owner.Description}}
  23. <span class="user description">
  24. <p>{{.Owner.Description}}</p>
  25. </span>
  26. {{end}}
  27. {{if .Owner.Location}}
  28. <br/>
  29. <i class="menu-icon octicon">📍</i> {{.Owner.Location}}
  30. {{end}}
  31. {{if .Owner.Company}}
  32. <br/>
  33. <i class="menu-icon octicon">🏢</i> {{.Owner.Company}}
  34. {{if .Owner.IsStaff}}<span class="staff">Staff</span>{{end}}
  35. {{end}}
  36. {{if and .Owner.Email .IsLogged}}
  37. <br/>
  38. <i class="menu-icon octicon">📧</i>
  39. <a href="mailto:{{.Owner.Email}}" rel="nofollow">{{.Owner.Email}}</a>
  40. {{end}}
  41. {{if .Owner.Website}}
  42. <br/>
  43. <i class="menu-icon octicon">🔗</i>
  44. <a target="_blank" rel="noopener noreferrer me nofollow" href="{{.Owner.Website}}">{{.Owner.Website}}</a>
  45. {{end}}
  46. <br/>
  47. <i class="menu-icon octicon">🕒</i> {{.i18n.Tr "user.join_on"}} {{DateFmtShort .Owner.Created}}
  48. {{if .Owner.NumStars}}
  49. <br/>
  50. <i class="menu-icon octicon">⭐</i>
  51. {{.Owner.NumStars}} {{.i18n.Tr "user.starred"}}
  52. {{end}}
  53. <div>
  54. <i class="menu-icon octicon">🤵</i>
  55. <a href="{{.Owner.HomeLink}}/followers">
  56. {{.Owner.NumFollowers}} {{.i18n.Tr "user.followers"}}
  57. </a>
  58. -
  59. <a href="{{.Owner.HomeLink}}/following">
  60. {{.Owner.NumFollowing}} {{.i18n.Tr "user.following"}}
  61. </a>
  62. </div>
  63. </div>
  64. {{if and .IsLogged (ne .LoggedUserName .Owner.Name)}}
  65. <div class="follow">
  66. {{if .LoggedUser.IsFollowing .Owner.ID}}
  67. <a class="ui basic red button mobile-card follow" href="{{.Link}}/action/unfollow?redirect_to={{$.Link}}"><i class="menu-icon octicon">👦🏽</i>{{.i18n.Tr "user.unfollow"}}</a>
  68. {{else}}
  69. <a class="ui basic green button mobile-card follow" href="{{.Link}}/action/follow?redirect_to={{$.Link}}"><i class="menu-icon octicon">👦</i>{{.i18n.Tr "user.follow"}}</a>
  70. {{end}}
  71. </div>
  72. {{end}}
  73. </div>
  74. </div>
  75. <div class="user profile">
  76. <div class="ui container">
  77. <div class="ui grid">
  78. <div class="ui five wide column">
  79. <div class="ui card" style="border: 2px solid {{.Owner.ThemeColor}};box-shadow: 5px 6px 0px {{.Owner.ThemeColor}}">
  80. {{if eq .LoggedUserName .Owner.Name}}
  81. <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">
  82. <img src="{{AppendAvatarSize .Owner.RelAvatarLink 290}}" title="{{.Owner.Name}}"/>
  83. </a>
  84. {{else}}
  85. <span class="image">
  86. <img src="{{AppendAvatarSize .Owner.RelAvatarLink 290}}" title="{{.Owner.Name}}"/>
  87. </span>
  88. {{end}}
  89. <div class="content">
  90. {{if .Owner.FullName}}
  91. <span class="header text center">
  92. {{.Owner.FullName}}
  93. {{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}}
  94. {{if .Owner.IsMaker}}<a class="poping up" target="_blank" href="/maker" data-content="Maker" data-variation="inverted tiny" data-position="right center"><i class="maker octicon octicon-paintcan"></i></a>{{end}}
  95. {{if .Owner.IsBugHunter}}<a class="poping up" target="_blank" href="/security" data-content="Bug Hunter" data-variation="inverted tiny" data-position="right center"><i class="bughunter octicon octicon-gist-secret"></i></a>{{end}}
  96. {{if .Owner.IsBeta}}<a class="poping up" target="_blank" href="/developer" data-content="Beta Member" data-variation="inverted tiny" data-position="right center"><i class="developer octicon octicon-circuit-board"></i></a>{{end}}
  97. {{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}}
  98. </span>
  99. {{end}}
  100. <center>
  101. <span class="username text center">
  102. <i style="font-size:12px" class="menu-icon octicon">👨‍💻</i> {{.Owner.Name}} <i style="font-size:12px" class="menu-icon octicon">👨‍💻</i>
  103. </span>
  104. {{if .IsAdmin}}
  105. <a class="poping up" href="{{AppURL}}admin/users/{{.Owner.ID}}" data-content="Settings" data-variation="inverted tiny" data-position="right center">⚙️</a>
  106. {{end}}
  107. <center>
  108. </div>
  109. <div class="extra content">
  110. <ul class="text black">
  111. {{if or .Owner.Twitter .Owner.Linkedin .Owner.Github .Owner.Devto .Owner.Stackoverflow .Owner.Reddit .Owner.Telegram .Owner.Codepen}}
  112. <li class="ui center">
  113. {{if .Owner.Twitter}}<a href="https://twitter.com/{{.Owner.Twitter}}" target="_blank"><i class="twitter icon"></i></a>{{end}}
  114. {{if .Owner.Linkedin}}<a href="https://linkedin.com/in/{{.Owner.Linkedin}}" target="_blank"><i class="linkedin icon"></i></a>{{end}}
  115. {{if .Owner.Github}}<a href="https://github.com/{{.Owner.Github}}" target="_blank"><i class="github icon"></i></a>{{end}}
  116. {{if .Owner.Devto}}<a href="https://dev.to/{{.Owner.Devto}}" target="_blank"><i class="code icon"></i></a>{{end}}
  117. {{if .Owner.Stackoverflow}}<a href="https://stackoverflow.com/users/{{.Owner.Stackoverflow}}" target="_blank"><i class="stack overflow icon"></i></a>{{end}}
  118. {{if .Owner.Reddit}}<a href="https://reddit.com/user/{{.Owner.Reddit}}" target="_blank"><i class="reddit icon"></i></a>{{end}}
  119. {{if .Owner.Telegram}}<a href="https://t.me/{{.Owner.Telegram}}" target="_blank"><i class="telegram icon"></i></a>{{end}}
  120. {{if .Owner.Codepen}}<a href="https://codepen.io/{{.Owner.Codepen}}" target="_blank"><i class="codepen icon"></i></a>{{end}}
  121. </li>
  122. {{end}}
  123. {{if .Owner.Description}}
  124. <li class="user description">
  125. <p>{{.Owner.Description}}</p>
  126. </li>
  127. {{end}}
  128. {{if .Owner.Location}}
  129. <li><i class="menu-icon octicon">📍</i> <span class="pro-truncate">{{.Owner.Location}}</span></li>
  130. {{end}}
  131. {{if .Owner.Company}}
  132. <li>
  133. <i class="menu-icon octicon">🏢</i>
  134. <span class="pro-truncate">
  135. {{.Owner.Company}}
  136. {{if .Owner.IsStaff}}<span class="staff">Staff</span>{{end}}
  137. </span>
  138. </li>
  139. {{end}}
  140. {{if and .Owner.Email .IsLogged}}
  141. {{if not .Owner.PrivateEmail}}
  142. <li>
  143. <i class="menu-icon octicon">📧</i>
  144. <a class="pro-truncate" href="mailto:{{.Owner.Email}}" rel="nofollow">{{.Owner.Email}}</a>
  145. </li>
  146. {{end}}
  147. {{else}}
  148. <li>
  149. <i class="menu-icon octicon">📧</i>
  150. <a class="pro-truncate" href="{{AppURL}}login" rel="nofollow">Login to view email</a>
  151. </li>
  152. {{end}}
  153. {{if .Owner.Website}}
  154. <li>
  155. <i class="menu-icon octicon">🔗</i>
  156. <a target="_blank" rel="noopener noreferrer me nofollow" href="{{.Owner.Website}}">{{.Owner.Website}}</a>
  157. </li>
  158. {{end}}
  159. <li><i class="menu-icon octicon">🕒</i> {{.i18n.Tr "user.join_on"}} {{DateFmtShort .Owner.Created}}</li>
  160. {{if .Owner.NumStars}}
  161. <li>
  162. <i class="menu-icon octicon">⭐</i>
  163. {{.Owner.NumStars}} {{.i18n.Tr "user.starred"}}
  164. </li>
  165. {{end}}
  166. <li>
  167. <i class="menu-icon octicon">🤵</i>
  168. <a href="{{.Owner.HomeLink}}/followers">
  169. {{.Owner.NumFollowers}} {{.i18n.Tr "user.followers"}}
  170. </a>
  171. -
  172. <a href="{{.Owner.HomeLink}}/following">
  173. {{.Owner.NumFollowing}} {{.i18n.Tr "user.following"}}
  174. </a>
  175. </li>
  176. {{if .Orgs}}
  177. <li>
  178. {{range .Orgs}}
  179. <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>
  180. {{end}}
  181. </li>
  182. {{end}}
  183. {{if and .IsLogged (ne .LoggedUserName .Owner.Name)}}
  184. <li class="follow">
  185. {{if .LoggedUser.IsFollowing .Owner.ID}}
  186. <a class="ui basic red button" href="{{.Link}}/action/unfollow?redirect_to={{$.Link}}"><i class="menu-icon octicon">👦🏽</i>{{.i18n.Tr "user.unfollow"}}</a>
  187. {{else}}
  188. <a class="ui basic green button" href="{{.Link}}/action/follow?redirect_to={{$.Link}}"><i class="menu-icon octicon">👦</i>{{.i18n.Tr "user.follow"}}</a>
  189. {{end}}
  190. </li>
  191. {{end}}
  192. </ul>
  193. </div>
  194. </div>
  195. </div>
  196. <div class="ui eleven wide column">
  197. <div class="ui secondary pointing menu">
  198. <a class="{{if ne .TabName "activity"}}active{{end}} item" href="{{.Owner.HomeLink}}">
  199. <i class="menu-icon octicon">📁</i>&nbsp;{{.i18n.Tr "user.repositories"}} <span class="ui grey label mobile-count">{{.Owner.NumRepos}}</span>
  200. </a>
  201. <a class="item">
  202. <a class="{{if eq .TabName "activity"}}active{{end}} item" href="{{.Owner.HomeLink}}?tab=activity">
  203. <i class="menu-icon octicon">🔊</i>&nbsp;{{.i18n.Tr "user.activity"}}
  204. </a>
  205. </a>
  206. </div>
  207. {{if ne .TabName "activity"}}
  208. {{template "explore/repo_list" .}}
  209. {{template "explore/page" .}}
  210. {{else}}
  211. <br>
  212. <div class="feeds">
  213. {{template "user/dashboard/feeds" .}}
  214. </div>
  215. {{end}}
  216. </div>
  217. </div>
  218. </div>
  219. </div>
  220. {{template "base/footer" .}}