convert.blade.php 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. @extends('admin.layouts')
  2. @section('content')
  3. <div class="page-content container-fluid">
  4. <div class="panel">
  5. <div class="panel-heading">
  6. <h2 class="panel-title">
  7. {!! trans('admin.tools.convert.title') !!}
  8. </h2>
  9. </div>
  10. <div class="panel-body">
  11. <div class="row">
  12. <div class="col-md-4 form-group">
  13. <label for="method">{{ trans('model.node.method') }}</label>
  14. <select class="form-control" name="method" id="method">
  15. @foreach (Helpers::methodList() as $method)
  16. <option value="{{$method->name}}" @if($method->is_default) selected @endif>
  17. {{$method->name}}
  18. </option>
  19. @endforeach
  20. </select>
  21. </div>
  22. <div class="col-md-4 form-group">
  23. <label for="transfer_enable">{{ trans('model.user.usable_traffic') }}</label>
  24. <div class="input-group">
  25. <input type="number" class="form-control" name="transfer_enable" value="1000" id="transfer_enable" placeholder="" required>
  26. <span class="input-group-text">GB</span>
  27. </div>
  28. </div>
  29. <div class="col-md-4 form-group">
  30. <label for="protocol">{{ trans('model.node.protocol') }}</label>
  31. <select class="form-control" name="protocol" id="protocol">
  32. @foreach (Helpers::protocolList() as $protocol)
  33. <option value="{{$protocol->name}}" @if($protocol->is_default) selected @endif>
  34. {{$protocol->name}}
  35. </option>
  36. @endforeach
  37. </select>
  38. </div>
  39. <div class="col-md-4 form-group">
  40. <label for="protocol_param">{{ trans('model.node.protocol_param') }}</label>
  41. <input type="text" class="form-control" name="protocol_param" id="protocol_param" placeholder="">
  42. </div>
  43. <div class="col-md-4 form-group">
  44. <label for="obfs">{{ trans('model.node.obfs') }}</label>
  45. <select class="form-control" name="obfs" id="obfs">
  46. @foreach (Helpers::obfsList() as $obfs)
  47. <option value="{{$obfs->name}}" @if($obfs->is_default) selected @endif>
  48. {{$obfs->name}}
  49. </option>
  50. @endforeach
  51. </select>
  52. </div>
  53. <div class="col-md-4 form-group">
  54. <label for="obfs_param">{{ trans('model.node.obfs_param') }}</label>
  55. <input type="text" class="form-control" name="obfs_param" id="obfs_param" placeholder="">
  56. </div>
  57. <div class="col-md-6">
  58. <textarea class="form-control" rows="22" name="content" id="content" placeholder="{{ trans('admin.tools.convert.content_placeholder') }}"
  59. autofocus></textarea>
  60. </div>
  61. <div class="col-md-6">
  62. <textarea class="form-control" rows="22" name="result" id="result" onclick="this.focus();this.select()" readonly="readonly"></textarea>
  63. </div>
  64. <div class="col-md-6">
  65. <button class="btn btn-block btn-primary" onclick="Convert()">{{ trans('common.convert') }}</button>
  66. </div>
  67. <div class="col-md-6">
  68. <a href="{{route('admin.tools.download', ['type' => 1])}}" class="btn btn-block btn-danger">{{ trans('common.download') }}</a>
  69. </div>
  70. </div>
  71. </div>
  72. </div>
  73. </div>
  74. @endsection
  75. @section('javascript')
  76. <script>
  77. // 转换
  78. function Convert() {
  79. const content = $('#content').val();
  80. if (content.trim() === '') {
  81. swal.fire({title: '{{ trans('admin.tools.convert.content_placeholder') }}', icon: 'warning', timer: 1000, showConfirmButton: false});
  82. return;
  83. }
  84. swal.fire({
  85. title: '{{ trans('admin.confirm.continues') }}',
  86. icon: 'question',
  87. allowEnterKey: false,
  88. showCancelButton: true,
  89. cancelButtonText: '{{ trans('common.close') }}',
  90. confirmButtonText: '{{ trans('common.confirm') }}',
  91. }).then((result) => {
  92. if (result.value) {
  93. $.ajax({
  94. method: 'POST',
  95. url: '{{route('admin.tools.convert')}}',
  96. dataType: 'json',
  97. data: {
  98. _token: '{{csrf_token()}}',
  99. method: $('#method').val(),
  100. transfer_enable: $('#transfer_enable').val(),
  101. protocol: $('#protocol').val(),
  102. protocol_param: $('#protocol_param').val(),
  103. obfs: $('#obfs').val(),
  104. obfs_param: $('#obfs_param').val(),
  105. content: content,
  106. },
  107. success: function(ret) {
  108. if (ret.status === 'success') {
  109. $('#result').val(ret.data);
  110. } else {
  111. $('#result').val(ret.message);
  112. }
  113. },
  114. });
  115. }
  116. });
  117. return false;
  118. }
  119. </script>
  120. @endsection