file.blade.php 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. <style>
  2. .webuploader-pick {
  3. background-color: @primary;
  4. }
  5. .web-uploader .placeholder .flashTip a {
  6. color: @primary(-10);
  7. }
  8. .web-uploader .statusBar .upload-progress span.percentage,
  9. .web-uploader .filelist li p.upload-progress span {
  10. background: @primary(-8);
  11. }
  12. </style>
  13. <div class="{{$viewClass['form-group']}} {{ $class }}">
  14. <label for="{{$column}}" class="{{$viewClass['label']}} control-label">{!! $label !!}</label>
  15. <div class="{{$viewClass['field']}}">
  16. @include('admin::form.error')
  17. <input name="{{ $name }}" class="file-input" type="hidden" />
  18. <div class="web-uploader {{ $fileType }}">
  19. <div class="queueList">
  20. <div class="placeholder dnd-area">
  21. <div class="file-picker"></div>
  22. <p>{{trans('admin.uploader.drag_file')}}</p>
  23. </div>
  24. </div>
  25. <div class="statusBar" style="display:none;">
  26. <div class="upload-progress progress progress-bar-primary pull-left">
  27. <div class="progress-bar progress-bar-striped active" style="line-height:18px">0%</div>
  28. </div>
  29. <div class="info"></div>
  30. <div class="btns">
  31. <div class="add-file-button"></div>
  32. @if($showUploadBtn)
  33. &nbsp;
  34. <div class="upload-btn btn btn-primary"><i class="feather icon-upload"></i> &nbsp;{{trans('admin.upload')}}</div>
  35. @endif
  36. </div>
  37. </div>
  38. </div>
  39. @include('admin::form.help-block')
  40. </div>
  41. </div>
  42. <script require="@webuploader" init="{!! $selector !!}">
  43. var uploader,
  44. newPage,
  45. options = {!! $options !!};
  46. var events = {!!$events??'[]'!!};
  47. init();
  48. function init() {
  49. var opts = $.extend({
  50. selector: $this,
  51. addFileButton: $this.find('.add-file-button'),
  52. inputSelector: $this.find('.file-input'),
  53. }, options);
  54. opts.upload = $.extend({
  55. pick: {
  56. id: $this.find('.file-picker'),
  57. name: '_file_',
  58. label: '<i class="feather icon-folder"></i>&nbsp; {!! trans('admin.uploader.add_new_media') !!}'
  59. },
  60. dnd: $this.find('.dnd-area'),
  61. paste: $this.find('.web-uploader')
  62. }, opts);
  63. uploader = Dcat.Uploader(opts);
  64. uploader.build();
  65. uploader.preview();
  66. /* register events */
  67. for (i = 0; i < events.length; i++) {
  68. var evt = events[i]
  69. if (evt.event && evt.script) {
  70. uploader.uploader.on(evt.event, (new Function('return ' + evt.script)()).bind(uploader))
  71. }
  72. }
  73. function resize() {
  74. setTimeout(function () {
  75. if (! uploader) return;
  76. uploader.refreshButton();
  77. resize();
  78. if (! newPage) {
  79. newPage = 1;
  80. $(document).one('pjax:complete', function () {
  81. uploader = null;
  82. });
  83. }
  84. }, 250);
  85. }
  86. resize();
  87. }
  88. </script>