dowload.blade.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. @extends('user.layouts')
  2. @section('css')
  3. <link href="/assets/global/fonts/themify/themify.min.css" rel="stylesheet">
  4. @endsection
  5. @section('content')
  6. <div class="row" data-by-row="true">
  7. <div class="col-xl-4 col-md-4">
  8. <div class="card">
  9. <div class="card-body">
  10. <!--<h5 class="card-title">我的账号: {{$username}} 到期时间:{{$expireTime}} <br>剩余流量{{$unusedTraffic}}/套餐总流量{{$totalTransfer}}</h5>-->
  11. <div style="display: grid; grid-template-columns: 1fr 1fr; gap: 10px; font-size: 14px;">
  12. <div id="accountInfo" style="border: 1px solid #6B8E23; padding: 5px; line-height: 1.2; color: #008000; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; cursor: pointer; grid-column: span 2;">
  13. <span style="font-weight: bold; margin-right: 5px;">账号</span>{{ $username }} <a href="/profile#tab_2" >修改邮箱</a>
  14. </div>
  15. <div style="border: 1px solid #6B8E23; padding: 5px; line-height: 1.2; color: #008000;">
  16. <span style="font-weight: bold; margin-right: 5px;">到期时间</span>
  17. <script>
  18. var expireDate = new Date('{{$expireTime}}');
  19. if (expireDate < new Date()) {
  20. document.write('<span style="color: #FF0000;">已过期</span>');
  21. } else {
  22. document.write(expireDate.toLocaleDateString());
  23. }
  24. </script>
  25. </div>
  26. <div style="border: 1px solid #6B8E23; padding: 5px; line-height: 1.2; color: #008000;">
  27. <span style="font-weight: bold; margin-right: 5px;">剩余</span>{{$unusedTraffic}}/
  28. <span style="font-weight: bold; margin-right: 5px;">总流量</span>{{$totalTransfer}}
  29. </div>
  30. </div>
  31. <p></p>
  32. <p class="card-text">
  33. <a href="/userinfo" class="btn btn-light text-success border-success">账号状态</a>
  34. <a href="/services" class="btn btn-light text-danger border-danger">购买套餐</a>
  35. <!--<a href="/services" class="btn btn-light text-success border-success">购买VIP</a>-->
  36. <a href="/services2" class="btn btn-light text-success border-success">加油包</a>
  37. <a href="/tickets" class="btn btn-light text-danger border-danger">客服</a>
  38. <a href="/invoices" class="btn btn-light text-success border-success">账单</a>
  39. <a href="/referral" class="btn btn-light text-success border-success">推广</a>
  40. <a href="/nodeList" class="btn btn-light text-success border-success">我的节点</a>
  41. </p>
  42. </div>
  43. </div>
  44. </div>
  45. <div class="col-xl-4 col-md-4">
  46. <div class="card">
  47. <div class="card-body">
  48. <!--<h4 class="card-title cyan-600"><i class="icon wb-link"></i>一键添加订阅地址</h4>-->
  49. <div class="content-text text-md-left mb-20">
  50. <button class="btn btn-outline-success btn-block" data-toggle="collapse" data-target="#subscriptionOptions" aria-expanded="false" aria-controls="subscriptionOptions">
  51. 一键导入订阅
  52. </button>
  53. <div class="collapse" id="subscriptionOptions">
  54. <!--<h5><a href="{{$Clash_linkB}}" class="btn btn-primary">备用2一键导入Clash_meta</a></h5>-->
  55. <!--<h5><a href="{{$Clash_linkC}}" class="btn btn-primary">备用3一键导入Clash_meta</a></h5>-->
  56. <!--<h3>提示:(过期账号无法订阅)</h3>-->
  57. <!--<h5>Clash_pro和Clash_原版请手动添加订阅</h5>-->
  58. <!--<h5><a href="{{$Clash_link}}" class="btn btn-primary">一键导入Clash_Meta</a></h5>-->
  59. <!--<h5><a href="{{$Clash_linkA}}" class="btn btn-primary">备用1Clash_Meta</a></h5>-->
  60. <!--<h5><a href="{{$Clash_linkB}}" class="btn btn-primary">备用2Clash_Meta</a></h5>-->
  61. <!--<h5><a href="{{$Clash_linkC}}" class="btn btn-primary">备用3Clash_Meta( )</a></h5>-->
  62. <!-- <h5><a href="{{$Clash_linkD}}" class="btn btn-primary">一键导入Clash_pro和Clash_原版</a></h5>-->
  63. <!--<h5><a href="{{$Clash_linkF}}" class="btn btn-primary">备用1导入Clash_pro和原版( )</a></h5>-->
  64. <h5><a href="{{$Shadowrocket_link}}" class="btn btn-primary">一键导入Shadowrocket</a></h5>
  65. <h5><a href="{{$Shadowrocket_linkA}}" class="btn btn-primary">备用1导入Shadowrocket</a></h5>
  66. <h5><a href="{{$karing}}" class="btn btn-primary">一键导入karing</a></h5>
  67. <h5><a href="{{$karingA}}" class="btn btn-primary">备用一键导入karing</a></h5>
  68. <h5><a href="{{$singBoxA}}" class="btn btn-primary">一键导入sing-box </a></h5>
  69. <h5><a href="{{$singBox}}" class="btn btn-primary">备用一键导入sing-box</a></h5>
  70. <h5><a href="{{$hiddify}}" class="btn btn-primary">一键导入hiddify</a></h5>
  71. <h5><a href="{{$hiddifya}}" class="btn btn-primary">备用一键导入hiddify</a></h5>
  72. <h5><a href="{{$Clash_link}}" class="btn btn-primary">一键导入clash meta(不支持clash原版)</a></h5>
  73. <h5><a href="{{$Clash_linkA}}" class="btn btn-primary">备用一键导入clash meta(不支持clash原版)</a></h5>
  74. <p>一键导入必须在导入的设备安装了软件!</p>
  75. </div>
  76. </div>
  77. </div>
  78. </div>
  79. </div>
  80. <div class="col-xl-4 col-md-4">
  81. <div class="card">
  82. <div class="card-body">
  83. <!--<h4 class="card-title cyan-600"><i class="icon wb-link"></i>一键添加订阅地址</h4>-->
  84. <div class="content-text text-md-left mb-20">
  85. <button class="btn btn-outline-success btn-block" data-toggle="collapse" data-target="#subscriptionOptions1" aria-expanded="false" aria-controls="subscriptionOptions">
  86. 我的订阅地址
  87. </button>
  88. <div class="collapse" id="subscriptionOptions1">
  89. <h5>通用订阅地址:(复制订阅地址,粘贴到软件上面)</h5>
  90. <!--<input type="text" class="form-control" id="sub_link" value="{{$link}}"/>-->
  91. <div class="input-group">
  92. <input type="text" class="form-control" id="sub_link" value="{{$link}}" readonly>
  93. <div class="input-group-append">
  94. <button class="btn btn-outline-secondary" type="button" id="copyButton" data-clipboard-target="#sub_link">复制</button>
  95. </div>
  96. </div>
  97. <h5>通用备用订阅地址</h5>
  98. <!--<input type="text" class="form-control" id="sub_link5" value="{{$link5}}"/>-->
  99. <div class="input-group">
  100. <input type="text" class="form-control" id="sub_link5" value="{{$link5}}" readonly>
  101. <div class="input-group-append">
  102. <button class="btn btn-outline-secondary" type="button" id="copyButton" data-clipboard-target="#sub_link5">复制</button>
  103. </div>
  104. </div>
  105. <h5>sing-box或者dittify订阅地址</h5>
  106. <!--<input type="text" class="form-control" id="sub_link6" value="{{$link6}}"/>-->
  107. <div class="input-group">
  108. <input type="text" class="form-control" id="sub_link6" value="{{$link6}}" readonly>
  109. <div class="input-group-append">
  110. <button class="btn btn-outline-secondary" type="button" id="copyButton" data-clipboard-target="#sub_link6">复制</button>
  111. </div>
  112. </div>
  113. <!-- <h5>支持Clash.pro 和Clash原版(设置为系统代理” 先把勾去掉)</h5>-->
  114. <!--<input type="text" class="form-control" id="sub_link4" value="{{$link4}}"/>-->
  115. <!-- <h5>备用地址</h5>-->
  116. <!--<input type="text" class="form-control" id="sub_link3" value="{{$link3}}"/>-->
  117. <P>以上订阅地址不支持 spectre clash原版.请使用我们推荐的软件</P>
  118. </div>
  119. </div>
  120. </div>
  121. </div>
  122. </div>
  123. <div class="card full-screen-card">
  124. <div class="card-body">
  125. @include('down.help')
  126. </div>
  127. </div>
  128. <script src="https://cdnjs.cloudflare.com/ajax/libs/clipboard.js/2.0.8/clipboard.min.js"></script>
  129. <script>
  130. document.addEventListener('DOMContentLoaded', function() {
  131. var clipboard = new ClipboardJS('#copyButton');
  132. clipboard.on('success', function(e) {
  133. alert('已复制到剪贴板');
  134. e.clearSelection();
  135. });
  136. clipboard.on('error', function(e) {
  137. alert('复制失败,请手动复制');
  138. });
  139. });
  140. </script>
  141. </div>
  142. @endsection
  143. @section('javascript')
  144. <script src="/assets/custom/clipboardjs/clipboard.min.js"></script>
  145. <script src="/assets/global/js/Plugin/responsive-tabs.js"></script>
  146. <script src="/assets/global/js/Plugin/tabs.js"></script>
  147. <script src="/assets/custom/jump-tab.js"></script>
  148. <script src="/assets/global/vendor/aspieprogress/jquery-asPieProgress.min.js"></script>
  149. <script src="/assets/global/vendor/matchheight/jquery.matchHeight-min.js"></script>
  150. <script src="/assets/global/vendor/chart-js/Chart.min.js"></script>
  151. <script src="/assets/global/vendor/bootstrap-select/bootstrap-select.min.js"></script>
  152. <script src="/assets/global/js/Plugin/aspieprogress.js"></script>
  153. <script src="/assets/global/js/Plugin/matchheight.js"></script>
  154. <script src="/assets/global/js/Plugin/bootstrap-select.js"></script>
  155. <script>
  156. // var ifr = document.querySelector('iframe');
  157. // ifr.onload = function () {
  158. // var oHeight = Math.max(ifr.contentWindow.document.documentElement.offsetHeight, ifr.contentWindow.document.body.offsetHeight);
  159. // var cHeight = Math.max(ifr.contentWindow.document.documentElement.clientHeight, ifr.contentWindow.document.body.clientHeight);
  160. // var height = Math.max(oHeight, cHeight);
  161. // ifr.style.height = height + 'px'
  162. // }
  163. // function calcPageHeight(doc) {
  164. // var cHeight = Math.max(doc.body.clientHeight, doc.documentElement.clientHeight)
  165. // var sHeight = Math.max(doc.body.scrollHeight, doc.documentElement.scrollHeight)
  166. // var height = Math.max(cHeight, sHeight)
  167. // return height
  168. // }
  169. // window.onload = function() {
  170. // var height = calcPageHeight(document)
  171. // parent.document.getElementById('ifr').style.height = height + 'px'
  172. // }
  173. {{--function linkManager($type) {--}}
  174. {{-- $('#sub_link').val('{{$link}}?type=' + $type);--}}
  175. {{-- return false;--}}
  176. {{--}--}}
  177. // 更换订阅地址
  178. function exchangeSubscribe() {
  179. swal.fire({
  180. title: '{{trans('common.warning')}}',
  181. text: '{{trans('user.subscribe.exchange_warning')}}',
  182. icon: 'warning',
  183. showCancelButton: true,
  184. cancelButtonText: '{{trans('common.close')}}',
  185. confirmButtonText: '{{trans('common.confirm')}}',
  186. }).then((result) => {
  187. if (result.value) {
  188. $.post('{{route('changeSub')}}', {_token: '{{csrf_token()}}'}, function(ret) {
  189. if (ret.status === 'success') {
  190. swal.fire({title: ret.message, icon: 'success', timer: 1000, showConfirmButton: false}).then(() => window.location.reload());
  191. } else {
  192. swal.fire({title: ret.message, icon: 'error'}).then(() => window.location.reload());
  193. }
  194. });
  195. }
  196. });
  197. }
  198. const clipboard = new ClipboardJS('.mt-clipboard', {
  199. text: function(trigger) {
  200. let base = @json($subUrl);
  201. const client = $('#client').val();
  202. const subType = $('#subType').val();
  203. if (subType && client) {
  204. base += '?target=' + client + '&type=' + subType;
  205. } else if (subType) {
  206. base += '?type=' + subType;
  207. } else if (client) {
  208. base += '?target=' + client;
  209. }
  210. return base;
  211. },
  212. });
  213. clipboard.on('success', function() {
  214. swal.fire({
  215. title: '{{trans('common.copy.success')}}',
  216. icon: 'success',
  217. timer: 1300,
  218. showConfirmButton: false,
  219. });
  220. });
  221. clipboard.on('error', function() {
  222. swal.fire({
  223. title: '{{trans('common.copy.failed')}}',
  224. icon: 'error',
  225. timer: 1500,
  226. showConfirmButton: false,
  227. });
  228. });
  229. </script>
  230. @endsection