user.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. <?php include ('header.php'); ?>
  2. <main id="main">
  3. <?php include dirname(__FILE__).('/widgets/user_header.php'); ?>
  4. <div class="article_wrap">
  5. <aside class="left_column">
  6. <div class="profile_icon_box">
  7. <img id="js_profile_image" src="/assets/images/missing.png" mediaaccess="true">
  8. </div>
  9. <section class="profile_section_wrap">
  10. <h1 class="profile_displayname">
  11. <a id="js_profile_displayname" href="#"></a>
  12. </h1>
  13. <h2 class="profile_username">
  14. @<a id="js_profile_username" href="#"></a><span class="profile_followed_by invisible"><?=_('FOLLOWS YOU')?></span>
  15. </h2>
  16. <p id="js_profile_bio" class="profile_bio"></p>
  17. <div id="js_profile_public_link" class="profile_with_icon invisible" style="margin-bottom:5px">
  18. <a target="_blank"><i class="fa fa-fw fa-link" aria-hidden="true"></i><span><?=_('Open public profile')?></span></a>
  19. </div>
  20. <div id="js_profile_joined_date" class="profile_with_icon" style="margin-bottom:5px">
  21. <span><i class="fa fa-fw fa-calendar" aria-hidden="true"></i><span></span></span>
  22. </div>
  23. <div id="profile_toot_buttons" style="height:31px;margin-bottom:5px;display:none">
  24. <button class="toot_button profile_sendto" style="width:calc(50% - 3px)"><div class="toot_button_label"><i class="fa fa-fw fa-pencil-square-o"></i><span><?=_('Toot to')?></span></div></button>
  25. <button class="toot_button profile_sendto" style="width:calc(50% - 3px)" privacy="direct"><div class="toot_button_label"><i class="fa fa-fw fa-envelope"></i><span><?=_('Message')?></span></div></button>
  26. </div>
  27. <?php include dirname(__FILE__).('/widgets/user_recent_images.php'); ?>
  28. </section>
  29. </aside>
  30. <article class="center_column">
  31. <header class="timeline_header">
  32. <ul class="header_items">
  33. <li class="item toots view">
  34. <a id="toots_link">
  35. <?=_('Toots')?>
  36. </a>
  37. </li>
  38. <li class="item wreplies">
  39. <a id="with_replies_link">
  40. <?=_('Toots')?> &amp; <?=_('replies')?>
  41. </a>
  42. </li>
  43. <li class="item media">
  44. <a id="media_link">
  45. <?=_('Media')?>
  46. </a>
  47. </li>
  48. </ul>
  49. </header>
  50. <div id="js-stream_update">
  51. <button>
  52. <?=_('View ')?><span></span><?=_(' new Toots')?>
  53. </button>
  54. </div>
  55. <ul id="js-timeline" class="timeline">
  56. </ul>
  57. <footer id="js-timeline_footer" class="timeline_footer">
  58. <i class="fa fa-spin fa-circle-o-notch" aria-hidden="true"></i>
  59. </footer>
  60. </article>
  61. <aside class="right_column">
  62. <section class="side_widgets_wrap">
  63. <?php include dirname(__FILE__).('/widgets/side_who_to_follow.php'); ?>
  64. </section>
  65. <?php include dirname(__FILE__).('/widgets/side_footer.php'); ?>
  66. </aside>
  67. </div>
  68. </main>
  69. <script>
  70. current_file = "/user";
  71. $("#toots_link").attr('href', location.pathname+location.search);
  72. $("#with_replies_link").attr('href', location.pathname+'/with_replies'+location.search);
  73. $("#media_link").attr('href', location.pathname+'/media'+location.search);
  74. $("#js-profile_nav_toots").toggleClass("view");
  75. $("#js-profile_nav_toots > a").attr('href', location.pathname+location.search);
  76. $("#js-profile_nav_following > a").attr('href', location.pathname+'/following'+location.search);
  77. $("#js-profile_nav_followers > a").attr('href', location.pathname+'/followers'+location.search);
  78. $("#js-profile_nav_favourites > a").attr('href', location.pathname+'/favourites'+location.search);
  79. $(function() {
  80. <?php if(isset($_GET['mid'])) { ?>
  81. const account_id = <?= htmlspecialchars((string)filter_input(INPUT_GET,'mid'),ENT_QUOTES) ?>;
  82. api.get('accounts/'+account_id, function(userprofile) {
  83. if(userprofile !== null) {
  84. <?php } else if(isset($_GET['user'])) {
  85. $name = preg_split("/@/",$_GET['user'])[1];
  86. $domain = preg_split("/@/",$_GET['user'])[2];
  87. $url= "https://$domain/@$name";
  88. ?>
  89. const query = '<?= htmlspecialchars((string)filter_input(INPUT_GET, 'user'), ENT_QUOTES) ?>';
  90. api.get('search',[{name:'q',data:query},{name:'resolve',data:'true'}],function(search) {
  91. if(!search.accounts.length) {
  92. location.href = "/404.php";
  93. }
  94. else if("@"+search.accounts[0].acct === query || "@"+search.accounts[0].acct+"@"+localStorage.current_instance === query) {
  95. userprofile = search.accounts[0];
  96. <?php } ?>
  97. $('title').text(replaced_emoji_return(userprofile.display_name)+' (@'+userprofile.acct+') | Halcyon');
  98. setAccount(userprofile);
  99. $(".profile_sendto").attr("acct","@"+userprofile.acct);
  100. $(".profile_sendto").attr("display_name",userprofile.display_name);
  101. api.get("accounts/"+userprofile.id+"/statuses",[{name:'pinned',data:'true'},{name:'limit',data:'40'}],function(statuses) {
  102. for(var i=0;i<statuses.length;i++) {
  103. timeline_pinned_template(statuses[i]).appendTo("#js-timeline");
  104. }
  105. replaceInternalLink();
  106. replace_emoji();
  107. setTimeline("accounts/"+userprofile.id+"/statuses",[{name:'exclude_replies',data:'true'}],"false",true);
  108. });
  109. setRecentImages(userprofile.id)
  110. }
  111. else {
  112. location.href = "/404.php";
  113. }
  114. });
  115. })
  116. </script>
  117. <?php include ('footer.php'); ?>