cut-image.blade.php 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  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. .web-uploader .dnd-area.webuploader-dnd-over {
  13. border: 3px dashed #999 !important;
  14. }
  15. .web-uploader .dnd-area.webuploader-dnd-over .placeholder {
  16. border: none;
  17. }
  18. </style>
  19. <div class="{{$viewClass['form-group']}} {{ $class }}">
  20. <label for="{{$column}}" class="{{$viewClass['label']}} control-label">{!! $label !!}</label>
  21. <div class="{{$viewClass['field']}}">
  22. @include('admin::form.error')
  23. <input name="{{ $name }}" class="file-input" type="hidden" {!! $attributes !!}/>
  24. <div class="web-uploader {{ $fileType }}">
  25. <div class="queueList dnd-area" @if(!empty($upimgdemo)) style="width: 220px;float: left;" @endif>
  26. <div class="placeholder">
  27. <div class="file-picker">
  28. <div class="cropper-pick btn btn-primary" style="margin: 0 auto 15px;"><i class="feather icon-folder"></i>&nbsp; {{trans('admin.uploader.add_new_media')}}</div>
  29. <input type="file" name="_file_" id="cropperFileInput" style="display: none" />
  30. </div>
  31. {{-- <p>{{trans('admin.uploader.drag_file')}}</p>--}}
  32. </div>
  33. </div>
  34. {{-- 上传图片示例--}}
  35. @include('admin::form.upload-img-demo')
  36. <div class="statusBar" style="display:none;">
  37. <div class="upload-progress progress progress-bar-primary pull-left">
  38. <div class="progress-bar progress-bar-striped active" style="line-height:18px">0%</div>
  39. </div>
  40. <div class="info"></div>
  41. <div class="btns">
  42. <div class="new-add-file-button">
  43. <div class="cropper-pick-new btn btn-primary"><i class="feather icon-folder"></i> &nbsp;{{trans('admin.uploader.go_on_add')}}</div>
  44. </div>
  45. @if($showUploadBtn)
  46. &nbsp;
  47. <div class="upload-btn btn btn-primary"><i class="feather icon-upload"></i> &nbsp;{{trans('admin.upload')}}</div>
  48. @endif
  49. </div>
  50. </div>
  51. </div>
  52. @include('admin::form.help-block')
  53. </div>
  54. </div>
  55. <!-- 模态框(Modal)的HTML结构 -->
  56. <div class="modal" id="cropperImageModal" tabindex="-1" role="dialog" aria-labelledby="cropperImageModal-labelledby" data-backdrop="static" data-keyboard="false">
  57. <div class="modal-dialog modal-xl" >
  58. <div class="modal-content">
  59. <div class="modal-header">
  60. <h5 class="modal-title" id="myModalLabel">{{trans('admin.crop_the_image')}}</h5>
  61. </div>
  62. <div class="modal-body" style="height: 75vh;padding: 0;">
  63. <img src="" id="cropperImage" style="max-width: 100%"/>
  64. </div>
  65. <div class="modal-footer">
  66. <button type="button" class="btn btn-default" data-dismiss="modal" id="modalClose">{{trans('admin.close')}}</button>
  67. <button type="button" class="btn btn-primary" id="modalSubmit">{{trans('admin.submit')}}</button>
  68. </div>
  69. </div>
  70. </div>
  71. </div>
  72. <link href="/vendor/cropper/cropper.min.css" rel="stylesheet">
  73. <script src="/vendor/cropper/cropper.min.js"></script>
  74. <script require="@webuploader" init="{!! $selector !!}">
  75. var uploader,
  76. newPage,
  77. options = {!! $options !!},
  78. events = options.events;
  79. init();
  80. function init() {
  81. var opts = $.extend({
  82. selector: $this,
  83. // addFileButton: $this.find('.add-file-button'),
  84. inputSelector: $this.find('.file-input'),
  85. }, options);
  86. opts.upload = $.extend({
  87. {{--pick: {--}}
  88. {{-- id: $this.find('.file-picker'),--}}
  89. {{-- name: '_file_',--}}
  90. {{-- label: '<i class="feather icon-folder"><\/i>&nbsp; {!! trans('admin.uploader.add_new_media') !!}'--}}
  91. {{--},--}}
  92. // dnd: $this.find('.dnd-area'),
  93. paste: $this.find('.web-uploader')
  94. }, opts);
  95. uploader = Dcat.Uploader(opts);
  96. uploader.build();
  97. uploader.preview();
  98. for (var i = 0; i < events.length; i++) {
  99. var evt = events[i];
  100. if (evt.event && evt.script) {
  101. if (evt.once) {
  102. uploader.uploader.once(evt.event, evt.script.bind(uploader))
  103. } else {
  104. uploader.uploader.on(evt.event, evt.script.bind(uploader))
  105. }
  106. }
  107. }
  108. function resize() {
  109. setTimeout(function () {
  110. if (! uploader) return;
  111. uploader.refreshButton();
  112. resize();
  113. if (! newPage) {
  114. newPage = 1;
  115. $(document).one('pjax:complete', function () {
  116. uploader = null;
  117. });
  118. }
  119. }, 250);
  120. }
  121. resize();
  122. }
  123. $this.find(".cropper-pick").on('click', function () {
  124. $this.find("#cropperFileInput").trigger("click");
  125. });
  126. $this.find(".cropper-pick-new").on('click', function () {
  127. $this.find("#cropperFileInput").trigger("click");
  128. });
  129. if (options.fileNumLimit == 1) {
  130. $this.find(".cropper-pick-new").hide();
  131. }
  132. $this.find("#cropperFileInput").on('change', function () {
  133. var file = this.files[0];
  134. //定义读文件对象
  135. var reader = new FileReader();
  136. reader.onload = function () {
  137. imageOnload(reader.result);
  138. };
  139. reader.readAsDataURL(file);//File对象转换为dataURL
  140. });
  141. let cropper; // 全局变量,用于保存 Cropper 实例
  142. //图片对象加载方法
  143. function imageOnload(url) {
  144. //弹窗裁剪
  145. $('#cropperImageModal').modal();
  146. const image = document.getElementById('cropperImage');
  147. image.src = url;
  148. if (cropper) {
  149. cropper.destroy(); // 如果已经存在实例,销毁之前的裁剪器
  150. }
  151. aspectRatio = options.aspectRatio || 1/1; // 默认裁剪框比例为 1/1
  152. cropper = new Cropper(image, {
  153. aspectRatio: aspectRatio, // 设置裁剪框的宽高比(可调整)
  154. viewMode: 1, // 设置裁剪框的视图模式
  155. autoCropArea: 0.95, // 设置自动裁剪区域占比
  156. dragMode: 'none',
  157. background: '#fff',
  158. });
  159. $("#modalClose").one('click', function () {
  160. $("#cropperFileInput").val('');
  161. $('#cropperImageModal').modal('hide');
  162. });
  163. $("#modalSubmit").one('click', function () {
  164. const canvas = cropper.getCroppedCanvas();
  165. canvas.toBlob(function(blob) {
  166. fileFromBlob = new File([blob], 'cropperImage.jpg', { type: "image/jpeg" });
  167. $('#cropperImageModal').modal('hide');
  168. $("#cropperFileInput").val('');
  169. uploader.uploader.addFile(fileFromBlob);
  170. },"image/jpeg", 0.8);
  171. });
  172. }
  173. </script>