华清大学特普通奖学金初选报名系统
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

141 lines
6.5 KiB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
  6. <meta property="og:title" content="华清特奖报名" />
  7. <meta property="og:description" content="华清大学特普通奖学金" />
  8. <link href="https://cdn.bootcss.com/twitter-bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet">
  9. <script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
  10. <script src="https://cdn.bootcss.com/twitter-bootstrap/4.3.1/js/bootstrap.min.js"></script>
  11. <script src="https://cdn.bootcdn.net/ajax/libs/jquery-timeago/1.6.7/jquery.timeago.min.js"></script>
  12. <script src="https://cdn.bootcdn.net/ajax/libs/jquery-timeago/1.6.7/locales/jquery.timeago.zh-CN.js"></script>
  13. <title>华清特奖报名</title>
  14. <style>
  15. .qbox {
  16. background:#e8e8e8;
  17. padding:5px;
  18. color:black;
  19. box-shadow: 2px 2px 10px 2px rgb(219 219 220);
  20. border-radius: .5rem;
  21. margin: 25px 0;
  22. }
  23. .qbox .inner {
  24. margin: 15px 0 0 15px;
  25. white-space: pre-wrap;
  26. }
  27. .timeago {
  28. font-size: 0.5em;
  29. text-align: right;
  30. }
  31. .display_name {
  32. margin: 0;
  33. }
  34. .card-body {
  35. padding: 0.75em;
  36. }
  37. </style>
  38. </head>
  39. <body style="background-color: #001a37;color:#e8e8e8">
  40. <div style="max-width:700px;" class="container">
  41. <div style="background-color:rgba(230,230,250,0.5);margin-bottom:40px">
  42. <div align='center' style='background-color:rgba(180,180,250,0.5);padding:10px;color:#ffffff;'>
  43. <h1 align='center'>华清大学<br/>特普通奖学金</h1>
  44. </div>
  45. </div>
  46. <form action="new" method="post">
  47. <div class="form-group qbox">
  48. <label>自荐提名</label>
  49. <textarea class="form-control" name="text" rows="5" maxlength="400" placeholder="简单介绍一下普通的自己,禁止内卷,限400字" required="required"></textarea>
  50. <div class="form-group row">
  51. <label for="url" class="col-sm-3 col-form-label">补充材料(可选)</label>
  52. <div class="col-sm-9">
  53. <input type="url" class="form-control" id="url" name="url" placeholder="链接,如:https://closed.social/safeShare/1xxxxxx" pattern="https://closed\.social/safeShare/\d([a-zA-Z]+)?">
  54. </div>
  55. </div>
  56. {% for v in vs %}
  57. <div class="form-group row">
  58. <label for="{{v.name}}" class="col-sm-4 col-form-label">{{v.ques}}</label>
  59. <div class="col-sm-8">
  60. <input type="text" class="form-control" id="{{v.name}}" name="{{v.name}}" placeholder="{{v.hint}}">
  61. </div>
  62. </div>
  63. {% endfor %}
  64. <button type="submit" class="btn btn-primary">报名!</button>
  65. </div>
  66. </form>
  67. <div style="font-size:80%">
  68. <p>提示:</p>
  69. <ol>
  70. <li>初选报名不需要登陆任何帐号,你可以留下联系方式或可验证身份的信息(如公钥/数字签名),也可以不留。</li>
  71. <li>如果需要附上补充材料,请使用清华云盘。为了避免泄露姓名请使用<a href="/safeShare" target="_blank">safeShare</a>,我们不接受其他云盘。</li>
  72. <li>下方的评论来自闭社用户。如需删除自己发布的介绍请让任意一位工作人员评论“删除”。</li>
  73. <li>需要回答几个简单的问题以初步验证清华身份。入围后需要用清华邮箱注册闭社以正式验证清华身份。</li>
  74. <li>建议在电脑上操作以免丢失未保存的内容。如果出错(例如验证问题答错了),请回退,多数浏览器都会恢复之前填写的内容。</li>
  75. </ol>
  76. </div>
  77. <hr/>
  78. <h3>已有的报名</h3>
  79. {% for c in cans %}
  80. <div class="qbox">
  81. <pre class="inner">{{c.content}}</pre>
  82. {% if c.url %}
  83. <p class="inner"><a href="{{c.url}}" target="_black">补充材料</a></p>
  84. {% endif %}
  85. <div style="text-align:right">
  86. <time class="timeago" datetime="{{c.time}}"></time>
  87. <a class="btn btn-link request-answer" data-toggle="collapse" href="#collapse-{{c.toot}}" role="button" aria-expanded="false" aria-controls="collapse-{{c.toot}}">
  88. 查看评论
  89. <span><svg fill="#007bff" viewBox="0 0 24 24" width="24" height="24" ><path d="M12 13L8.285 9.218a.758.758 0 0 0-1.064 0 .738.738 0 0 0 0 1.052l4.249 4.512a.758.758 0 0 0 1.064 0l4.246-4.512a.738.738 0 0 0 0-1.052.757.757 0 0 0-1.063 0L12.002 13z" style="animation: downn 1.5s infinite;"></path></svg></span>
  90. </a>
  91. </div>
  92. <div class="collapse" id="collapse-{{c.toot}}">
  93. <div class="card card-body">
  94. 加载中...
  95. </div>
  96. </div>
  97. </div>
  98. {% endfor %}
  99. <script>
  100. $('.timeago').timeago();
  101. $('.collapse').on('show.bs.collapse', (e) => {
  102. let self = e.target;
  103. let toot = self.id.split('-')[1];
  104. $.ajax({
  105. type:'GET',
  106. url:toot,
  107. success:(result,status,xhr) => {
  108. console.log(result+' : '+status);
  109. if(result.replies.length) {
  110. $(self).empty();
  111. result.replies.forEach((rp) => {
  112. $(self).append(`<div class="card card-body"><p class="display_name"><a href="${rp.url}">${rp.disp}</a>:</p><pre>${rp.content}</pre><time class="timeago" datetime="${rp.time}"></time></div>`)
  113. });
  114. console.log($(self).find('.timeago'));
  115. $(self).find('.timeago').timeago();
  116. }else {
  117. $(self).empty();
  118. $(self).append(`<div class="card card-body">(暂无回复)</div>`)
  119. }
  120. },
  121. error:(xhr,status,error) => {
  122. console.log(error, status, xhr.status, xhr.responseText);
  123. $(self).empty();
  124. $(self).append(`<div class="card card-body"><p style="color:red">${xhr.status} ${xhr.responseText}</p></div>`);
  125. if(xhr.status == 404)
  126. setTimeout(()=>{$(self).parent().remove()}, 3000);
  127. }
  128. });
  129. });
  130. </script>
  131. </div>
  132. </body>
  133. </html>