atr-components 0.2.403 → 0.2.404

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -270,4 +270,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
270
270
  }], onBeforeUpload: [{
271
271
  type: Output
272
272
  }] } });
273
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/upload/upload.component.ts","../../../../../../projects/components/src/lib/shared/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, Output, EventEmitter, Injector, ViewChild} from '@angular/core';\r\nimport {Observable} from 'rxjs';\r\nimport {HttpRequest, HttpEvent, HttpEventType, HttpResponse, HttpClient, HttpHeaders} from '@angular/common/http';\r\nimport {NzModalRef, NzModalService} from 'ng-zorro-antd/modal';\r\nimport {NzUploadChangeParam, NzUploadFile, NzUploadXHRArgs} from 'ng-zorro-antd/upload';\r\nimport {environment} from \"ng-zorro-antd/core/environments\";\r\nimport {atr_static_datas, ImageOpts} from \"../../../core/base/atr-common\";\r\nimport {HttpService} from \"../../../core/services/http.service\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\nimport {NzImageService} from 'ng-zorro-antd/image';\r\n\r\n@Component({\r\n  selector: 'atr-img-upload',\r\n  templateUrl: './upload.component.html',\r\n  styleUrls: ['./upload.component.less']\r\n})\r\nexport class UploadComponent implements OnInit {\r\n\r\n  @Input() opts: ImageOpts | any;\r\n  @Input() isEdit = true;\r\n  @Input() allowChangSeq = false;\r\n  tplModal: NzModalRef | any;\r\n  uploadUrl: any = \"\";\r\n\r\n  uploadData: any = {}\r\n\r\n  @Input()showUploadList = {\r\n    showPreviewIcon: true,\r\n    showRemoveIcon: true,\r\n    hidePreviewIconInNonImage: true\r\n  };\r\n\r\n  @Output()\r\n  afterChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output()\r\n  optsChange: EventEmitter<any> = new EventEmitter();\r\n  @Output()\r\n  onBeforeUpload: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  previewImage: string | any = '';\r\n  previewVisible = false;\r\n  changeVisible = false;\r\n\r\n  constructor(private injector: Injector, private nzImageService: NzImageService,\r\n              private httpClient: HttpClient, private modalService: NzModalService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  getFileTyeIcon(fileType: string, fileName: string) {\r\n    let thumbUrl = this.getFileThumbUrl(fileType);\r\n    if (thumbUrl === '') {\r\n      thumbUrl = this.getThumbUrl(fileName);\r\n    }\r\n    return thumbUrl;\r\n  }\r\n\r\n  getThumbUrl(path: string): string {\r\n\r\n    if (!path) {\r\n      return '';\r\n    }\r\n    // 后缀获取\r\n    if (path.endsWith('.mp4')) {\r\n      return '../../../assets/video.jpg';\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  getFileThumbUrl(type: string): string {\r\n    let thumbUrl = '';\r\n    if (type === 'video/mp4' || type === 'mp4') {\r\n      thumbUrl = '../../../assets/video.jpg';\r\n    }\r\n    return thumbUrl;\r\n  }\r\n\r\n  onChange(params: NzUploadChangeParam) {\r\n    console.log(params);\r\n    if (params.type == \"success\" || params.type == \"removed\") {\r\n\r\n      this.opts.imageList = [];\r\n      setTimeout(() => {\r\n        this.opts.imageList = params.fileList.map((file: any) => {\r\n\r\n          if (file.type == 'video/mp4' && file.uid === params.file.uid) {\r\n            let thumbUrl = this.getFileTyeIcon(file.type, file.name);\r\n            file.thumbUrl = thumbUrl ? thumbUrl : file.thumbUrl;\r\n            file.url = file.originFileObj ? atr_static_datas.OSS_URL + file.originFileObj['key'] : file['path'];\r\n          }\r\n          return file;\r\n        });\r\n      }, 50);\r\n      let fileUrls: any[] = [];\r\n      for (let file of params.fileList) {\r\n        if (file[\"key\"] != undefined) {\r\n          fileUrls.push(file[\"key\"]);\r\n          continue;\r\n        }\r\n        if (file.originFileObj) {\r\n          let originFileObj: any = file.originFileObj\r\n          if (originFileObj[\"key\"] != undefined) {\r\n            fileUrls.push(originFileObj[\"key\"])\r\n          }\r\n        }\r\n      }\r\n\r\n      this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n      this.optsChange.emit(this.opts)\r\n    }\r\n  }\r\n\r\n  private get httpService(): HttpService {\r\n    return this.injector.get(HttpService);\r\n  }\r\n\r\n  handlePreview = (file: NzUploadFile) => {\r\n    this.previewImage = file.url || file.thumbUrl;\r\n    this.previewVisible = true;\r\n  };\r\n\r\n  remove = (file: NzUploadFile) => {\r\n    if (!this.isEdit) {\r\n      return false;\r\n    }\r\n    console.log(file);\r\n    if (this.opts && this.opts.removeAction) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  beforeUpload = (file: NzUploadFile, fileList: NzUploadFile[]) => {\r\n    return new Observable<boolean>(observe => {\r\n      let fileName;\r\n      if (this.opts.keepName) {\r\n        fileName = file.name;\r\n      } else {\r\n        fileName = ToolsUtil.getRandomFileName() + \".\" + ToolsUtil.getFileExt(file.name);\r\n      }\r\n      this.onBeforeUpload.emit({code: 'getFile', data: {file: file, fileList: fileList}})\r\n      this.httpService.post(atr_static_datas.OSS_POLICY, {\r\n        dir: this.opts.uploadDir,\r\n        fileName: fileName,\r\n        'success_action_status': '200'\r\n      }, ToolsUtil.getHttpOptions()).subscribe(\r\n        result => {\r\n\r\n          if (result.status == 200) {\r\n            this.uploadData[file.uid] = result.data;\r\n            observe.next(true);\r\n          } else\r\n            observe.next(false);\r\n          observe.unsubscribe()\r\n        },\r\n        error => {\r\n          observe.next(false);\r\n          observe.unsubscribe()\r\n        }\r\n      )\r\n    })\r\n\r\n  }\r\n  customReq = (item: NzUploadXHRArgs) => {\r\n    const formData = new FormData();\r\n    let uploadData = this.uploadData[item.file.uid];\r\n    for (let key in uploadData) {\r\n      if (key != 'host')\r\n        formData.append(key, uploadData[key])\r\n    }\r\n    formData.append('file', item.file as any);\r\n    const req = new HttpRequest('POST', uploadData.host!, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    return this.httpClient.request(req).subscribe(\r\n      (event: HttpEvent<any>) => {\r\n        if (event.type === HttpEventType.UploadProgress) {\r\n          if (event.total! > 0) {\r\n            (event as any).percent = (event.loaded / event.total!) * 100;\r\n          }\r\n          item.onProgress!(event, item.file!);\r\n        } else if (event instanceof HttpResponse) {\r\n          item.file[\"key\"] = uploadData.key;\r\n          item.onSuccess!(event.body, item.file!, event);\r\n        }\r\n      },\r\n      err => {\r\n        item.onError!(err, item.file!);\r\n      }\r\n    );\r\n  };\r\n\r\n  openBannerSeq(tplContent: any, tplFooter: any) {\r\n    this.tplModal = this.modalService.create({\r\n      nzTitle: \"修改图片顺序\",\r\n      nzContent: tplContent,\r\n      nzFooter: tplFooter,\r\n      nzMaskClosable: false,\r\n      nzClosable: false,\r\n      nzOnOk: () => console.log('Click ok')\r\n    });\r\n    console.log(this.opts.imageList);\r\n    this.changeVisible = true;\r\n  }\r\n\r\n  destroyTplModal(): void {\r\n    if (this.tplModal)\r\n      this.tplModal.destroy();\r\n  }\r\n\r\n  arrowUp(index: any) {\r\n    let img = this.opts.imageList[index];\r\n    this.opts.imageList[index] = this.opts.imageList[index - 1];\r\n    this.opts.imageList[index - 1] = img;\r\n  }\r\n\r\n  arrowDown(index: any) {\r\n    let img = this.opts.imageList[index];\r\n    this.opts.imageList[index] = this.opts.imageList[index + 1];\r\n    this.opts.imageList[index + 1] = img;\r\n  }\r\n\r\n  saveSeq() {\r\n    this.destroyTplModal();\r\n    let imgs = this.opts.imageList;\r\n    this.opts.imageList = [];\r\n    setTimeout(() => {\r\n      this.opts.imageList = imgs;\r\n      console.log(this.opts.imageList);\r\n      let fileUrls: any = [];\r\n      for (let file of this.opts.imageList) {\r\n        if (file[\"key\"] != undefined) {\r\n          fileUrls.push(file[\"key\"]);\r\n          continue;\r\n        }\r\n        if (file.originFileObj && file.originFileObj[\"key\"] != undefined)\r\n          fileUrls.push(file.originFileObj[\"key\"])\r\n      }\r\n\r\n      this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n    }, 50)\r\n\r\n  }\r\n\r\n  dragnumber(numer: any) {\r\n    console.log(numer);\r\n    console.log('or', this.opts.imageList)\r\n    console.log('new', numer)\r\n    this.saveSeq();\r\n    // this.opts.imageList = numer\r\n  }\r\n\r\n  delImg(numer: any) {\r\n    console.log(numer);\r\n    this.opts.imageList = this.opts.imageList.filter((v: any, i: any) => i != numer)\r\n    let fileUrls: any = [];\r\n    for (let file of this.opts.imageList) {\r\n      if (file[\"key\"] != undefined) {\r\n        fileUrls.push(file[\"key\"]);\r\n        continue;\r\n      }\r\n      if (file.originFileObj && file.originFileObj[\"key\"] != undefined)\r\n        fileUrls.push(file.originFileObj[\"key\"])\r\n    }\r\n    this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n  }\r\n\r\n  priviewImg(img: any) {\r\n    let url = ToolsUtil.getOssUrl(this.getImgUrl(img))\r\n    console.log(url)\r\n    this.nzImageService.preview([{\r\n      src: url,\r\n      alt: 'ng-zorro'\r\n    }], {nzZoom: 1.5, nzRotate: 0});\r\n  }\r\n\r\n  getImgUrl(img: any) {\r\n    if (img.originFileObj && img.originFileObj.key) {\r\n      return img.originFileObj.key\r\n    }\r\n    return (img.url || img.thumbUrl)\r\n  }\r\n}\r\n","<div class=\"clearfix\">\r\n  <nz-upload\r\n    *ngIf=\"opts && opts?.uploadType == 'drag'\"\r\n    nzType=\"drag\"\r\n    nzAction=\"\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzRemove]=\"remove\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzLimit]=\"'1'\"\r\n  >\r\n    <p class=\"ant-upload-drag-icon\">\r\n      <i nz-icon nzType=\"inbox\"></i>\r\n    </p>\r\n    <p class=\"ant-upload-text\">单击或拖动文件到此区域上传</p>\r\n  </nz-upload>\r\n  <nz-upload\r\n    *ngIf=\"opts && opts?.uploadType == 'button'\"\r\n    nzType=\"drag\"\r\n    nzAction=\"\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [nzShowUploadList]=\"showUploadList\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzRemove]=\"remove\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzLimit]=\"'1'\"\r\n  >\r\n    <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\" style=\"font-size: 16px\"></i><span> {{opts.btnName}}</span></button>\r\n  </nz-upload>\r\n  <nz-upload\r\n    *ngIf=\"opts && !opts?.uploadType \"\r\n    nzAction=\"\"\r\n    nzListType=\"picture-card\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [(nzFileList)]=\"opts.imageList\"\r\n    [nzShowButton]=\"opts.imageList.length < opts.limit\"\r\n    [nzShowUploadList]=\"showUploadList\"\r\n    [nzPreview]=\"handlePreview\"\r\n    [nzRemove]=\"remove\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzDisabled]=\"!isEdit\"\r\n    [nzLimit]=\"'1'\"\r\n    [nzFileListRender]=\"opts && isEdit && allowChangSeq && opts.imageList.length > 0 ? fileListTmp : null\"\r\n  >\r\n    <i nz-icon nzType=\"plus\"></i>\r\n    <div class=\"ant-upload-text\">上传图片</div>\r\n  </nz-upload>\r\n  <!-- <a *ngIf=\"allowChangSeq && isEdit && opts.imageList.length > 1\" (click)=\"openBannerSeq(imgsContent, tplFooter)\"\r\n      style=\"margin-left: 10px; \"\r\n   ><i nz-icon nzType=\"plus\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>调整图片顺序</a>-->\r\n  <nz-modal\r\n    [nzVisible]=\"previewVisible\"\r\n    [nzContent]=\"modalContent\"\r\n    [nzFooter]=\"null\"\r\n    (nzOnCancel)=\"previewVisible = false\"\r\n  >\r\n    <ng-template #modalContent>\r\n      <img *ngIf=\"!previewImage.endsWith('.mp4')\" [src]=\"previewImage\" [ngStyle]=\"{ width: '100%' }\"/>\r\n      <div style=\"width: 100%;margin-top: 15px\">\r\n        <app-video *ngIf=\"previewImage.endsWith('.mp4')\" [url]=\"previewImage\"></app-video>\r\n      </div>\r\n    </ng-template>\r\n  </nz-modal>\r\n  <ng-template #imgsContent>\r\n    <ng-container *ngIf=\"opts && opts.imageList\">\r\n      <ng-container *ngFor=\"let imgs of opts.imageList;let i = index\">\r\n        <div class=\"img-div\">\r\n          <img [src]=\"imgs.url || imgs.thumbUrl\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'10px' }\"/>\r\n          <div style=\"margin-right: 20px\">\r\n            <a title=\"上移\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\"><i nz-icon nzType=\"arrow-up\"\r\n                                                                                         nzTheme=\"outline\"\r\n                                                                                         style=\"color: #1890ff; font-size: 15px;\"></i>\r\n              上移</a>\r\n            <a title=\"下移\" *ngIf=\" i < opts.imageList.length - 1\" (click)=\"arrowDown(i)\"><i nz-icon nzType=\"arrow-down\"\r\n                                                                                           nzTheme=\"outline\"\r\n                                                                                           style=\"color: #1890ff; font-size: 15px\"></i>\r\n              下移</a>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n\r\n  </ng-template>\r\n  <!--  </nz-modal>-->\r\n</div>\r\n<ng-template #fileListTmp>\r\n  <div dragula=\"dragulaBag\" [(dragulaModel)]=\"opts.imageList\" (dragulaModelChange)=\"dragnumber($event)\">\r\n    <ng-container *ngFor=\"let imgs of opts.imageList;let i = index\">\r\n      <div class=\"img-div img-pre\" style=\"\">\r\n        <img [src]=\"getImgUrl(imgs) |ossImg\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'10px' }\"/>\r\n        <div>\r\n          <span (click)=\"priviewImg(imgs)\" nz-icon nzType=\"eye\" nzTheme=\"outline\"></span>\r\n          <span (click)=\"delImg(i)\" nz-icon nzType=\"delete\" nzTheme=\"outline\"></span>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n</ng-template>\r\n<ng-template #tplFooter>\r\n  <button nz-button nzType=\"default\" (click)=\"destroyTplModal()\">\r\n    取消\r\n  </button>\r\n  <button nz-button nzType=\"primary\" (click)=\"saveSeq()\">\r\n    保存顺序\r\n  </button>\r\n</ng-template>\r\n\r\n\r\n"]}
273
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/upload/upload.component.ts","../../../../../../projects/components/src/lib/shared/upload/upload.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, Output, EventEmitter, Injector, ViewChild} from '@angular/core';\r\nimport {Observable} from 'rxjs';\r\nimport {HttpRequest, HttpEvent, HttpEventType, HttpResponse, HttpClient, HttpHeaders} from '@angular/common/http';\r\nimport {NzModalRef, NzModalService} from 'ng-zorro-antd/modal';\r\nimport {NzUploadChangeParam, NzUploadFile, NzUploadXHRArgs} from 'ng-zorro-antd/upload';\r\nimport {environment} from \"ng-zorro-antd/core/environments\";\r\nimport {atr_static_datas, ImageOpts} from \"../../../core/base/atr-common\";\r\nimport {HttpService} from \"../../../core/services/http.service\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\nimport {NzImageService} from 'ng-zorro-antd/image';\r\n\r\n@Component({\r\n  selector: 'atr-img-upload',\r\n  templateUrl: './upload.component.html',\r\n  styleUrls: ['./upload.component.less']\r\n})\r\nexport class UploadComponent implements OnInit {\r\n\r\n  @Input() opts: ImageOpts | any;\r\n  @Input() isEdit = true;\r\n  @Input() allowChangSeq = false;\r\n  tplModal: NzModalRef | any;\r\n  uploadUrl: any = \"\";\r\n\r\n  uploadData: any = {}\r\n\r\n  @Input() showUploadList: boolean | { showPreviewIcon?: boolean, showRemoveIcon?: boolean, showDownloadIcon?: boolean, hidePreviewIconInNonImage?: boolean } = {\r\n    showPreviewIcon: true,\r\n    showRemoveIcon: true,\r\n    hidePreviewIconInNonImage: true\r\n  };\r\n\r\n  @Output()\r\n  afterChange: EventEmitter<any> = new EventEmitter();\r\n\r\n  @Output()\r\n  optsChange: EventEmitter<any> = new EventEmitter();\r\n  @Output()\r\n  onBeforeUpload: EventEmitter<any> = new EventEmitter();\r\n\r\n\r\n  previewImage: string | any = '';\r\n  previewVisible = false;\r\n  changeVisible = false;\r\n\r\n  constructor(private injector: Injector, private nzImageService: NzImageService,\r\n              private httpClient: HttpClient, private modalService: NzModalService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  getFileTyeIcon(fileType: string, fileName: string) {\r\n    let thumbUrl = this.getFileThumbUrl(fileType);\r\n    if (thumbUrl === '') {\r\n      thumbUrl = this.getThumbUrl(fileName);\r\n    }\r\n    return thumbUrl;\r\n  }\r\n\r\n  getThumbUrl(path: string): string {\r\n\r\n    if (!path) {\r\n      return '';\r\n    }\r\n    // 后缀获取\r\n    if (path.endsWith('.mp4')) {\r\n      return '../../../assets/video.jpg';\r\n    } else {\r\n      return '';\r\n    }\r\n  }\r\n\r\n  getFileThumbUrl(type: string): string {\r\n    let thumbUrl = '';\r\n    if (type === 'video/mp4' || type === 'mp4') {\r\n      thumbUrl = '../../../assets/video.jpg';\r\n    }\r\n    return thumbUrl;\r\n  }\r\n\r\n  onChange(params: NzUploadChangeParam) {\r\n    console.log(params);\r\n    if (params.type == \"success\" || params.type == \"removed\") {\r\n\r\n      this.opts.imageList = [];\r\n      setTimeout(() => {\r\n        this.opts.imageList = params.fileList.map((file: any) => {\r\n\r\n          if (file.type == 'video/mp4' && file.uid === params.file.uid) {\r\n            let thumbUrl = this.getFileTyeIcon(file.type, file.name);\r\n            file.thumbUrl = thumbUrl ? thumbUrl : file.thumbUrl;\r\n            file.url = file.originFileObj ? atr_static_datas.OSS_URL + file.originFileObj['key'] : file['path'];\r\n          }\r\n          return file;\r\n        });\r\n      }, 50);\r\n      let fileUrls: any[] = [];\r\n      for (let file of params.fileList) {\r\n        if (file[\"key\"] != undefined) {\r\n          fileUrls.push(file[\"key\"]);\r\n          continue;\r\n        }\r\n        if (file.originFileObj) {\r\n          let originFileObj: any = file.originFileObj\r\n          if (originFileObj[\"key\"] != undefined) {\r\n            fileUrls.push(originFileObj[\"key\"])\r\n          }\r\n        }\r\n      }\r\n\r\n      this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n      this.optsChange.emit(this.opts)\r\n    }\r\n  }\r\n\r\n  private get httpService(): HttpService {\r\n    return this.injector.get(HttpService);\r\n  }\r\n\r\n  handlePreview = (file: NzUploadFile) => {\r\n    this.previewImage = file.url || file.thumbUrl;\r\n    this.previewVisible = true;\r\n  };\r\n\r\n  remove = (file: NzUploadFile) => {\r\n    if (!this.isEdit) {\r\n      return false;\r\n    }\r\n    console.log(file);\r\n    if (this.opts && this.opts.removeAction) {\r\n      return false;\r\n    }\r\n    return true;\r\n  }\r\n\r\n  beforeUpload = (file: NzUploadFile, fileList: NzUploadFile[]) => {\r\n    return new Observable<boolean>(observe => {\r\n      let fileName;\r\n      if (this.opts.keepName) {\r\n        fileName = file.name;\r\n      } else {\r\n        fileName = ToolsUtil.getRandomFileName() + \".\" + ToolsUtil.getFileExt(file.name);\r\n      }\r\n      this.onBeforeUpload.emit({code: 'getFile', data: {file: file, fileList: fileList}})\r\n      this.httpService.post(atr_static_datas.OSS_POLICY, {\r\n        dir: this.opts.uploadDir,\r\n        fileName: fileName,\r\n        'success_action_status': '200'\r\n      }, ToolsUtil.getHttpOptions()).subscribe(\r\n        result => {\r\n\r\n          if (result.status == 200) {\r\n            this.uploadData[file.uid] = result.data;\r\n            observe.next(true);\r\n          } else\r\n            observe.next(false);\r\n          observe.unsubscribe()\r\n        },\r\n        error => {\r\n          observe.next(false);\r\n          observe.unsubscribe()\r\n        }\r\n      )\r\n    })\r\n\r\n  }\r\n  customReq = (item: NzUploadXHRArgs) => {\r\n    const formData = new FormData();\r\n    let uploadData = this.uploadData[item.file.uid];\r\n    for (let key in uploadData) {\r\n      if (key != 'host')\r\n        formData.append(key, uploadData[key])\r\n    }\r\n    formData.append('file', item.file as any);\r\n    const req = new HttpRequest('POST', uploadData.host!, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    return this.httpClient.request(req).subscribe(\r\n      (event: HttpEvent<any>) => {\r\n        if (event.type === HttpEventType.UploadProgress) {\r\n          if (event.total! > 0) {\r\n            (event as any).percent = (event.loaded / event.total!) * 100;\r\n          }\r\n          item.onProgress!(event, item.file!);\r\n        } else if (event instanceof HttpResponse) {\r\n          item.file[\"key\"] = uploadData.key;\r\n          item.onSuccess!(event.body, item.file!, event);\r\n        }\r\n      },\r\n      err => {\r\n        item.onError!(err, item.file!);\r\n      }\r\n    );\r\n  };\r\n\r\n  openBannerSeq(tplContent: any, tplFooter: any) {\r\n    this.tplModal = this.modalService.create({\r\n      nzTitle: \"修改图片顺序\",\r\n      nzContent: tplContent,\r\n      nzFooter: tplFooter,\r\n      nzMaskClosable: false,\r\n      nzClosable: false,\r\n      nzOnOk: () => console.log('Click ok')\r\n    });\r\n    console.log(this.opts.imageList);\r\n    this.changeVisible = true;\r\n  }\r\n\r\n  destroyTplModal(): void {\r\n    if (this.tplModal)\r\n      this.tplModal.destroy();\r\n  }\r\n\r\n  arrowUp(index: any) {\r\n    let img = this.opts.imageList[index];\r\n    this.opts.imageList[index] = this.opts.imageList[index - 1];\r\n    this.opts.imageList[index - 1] = img;\r\n  }\r\n\r\n  arrowDown(index: any) {\r\n    let img = this.opts.imageList[index];\r\n    this.opts.imageList[index] = this.opts.imageList[index + 1];\r\n    this.opts.imageList[index + 1] = img;\r\n  }\r\n\r\n  saveSeq() {\r\n    this.destroyTplModal();\r\n    let imgs = this.opts.imageList;\r\n    this.opts.imageList = [];\r\n    setTimeout(() => {\r\n      this.opts.imageList = imgs;\r\n      console.log(this.opts.imageList);\r\n      let fileUrls: any = [];\r\n      for (let file of this.opts.imageList) {\r\n        if (file[\"key\"] != undefined) {\r\n          fileUrls.push(file[\"key\"]);\r\n          continue;\r\n        }\r\n        if (file.originFileObj && file.originFileObj[\"key\"] != undefined)\r\n          fileUrls.push(file.originFileObj[\"key\"])\r\n      }\r\n\r\n      this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n    }, 50)\r\n\r\n  }\r\n\r\n  dragnumber(numer: any) {\r\n    console.log(numer);\r\n    console.log('or', this.opts.imageList)\r\n    console.log('new', numer)\r\n    this.saveSeq();\r\n    // this.opts.imageList = numer\r\n  }\r\n\r\n  delImg(numer: any) {\r\n    console.log(numer);\r\n    this.opts.imageList = this.opts.imageList.filter((v: any, i: any) => i != numer)\r\n    let fileUrls: any = [];\r\n    for (let file of this.opts.imageList) {\r\n      if (file[\"key\"] != undefined) {\r\n        fileUrls.push(file[\"key\"]);\r\n        continue;\r\n      }\r\n      if (file.originFileObj && file.originFileObj[\"key\"] != undefined)\r\n        fileUrls.push(file.originFileObj[\"key\"])\r\n    }\r\n    this.afterChange.emit({key: this.opts.key, values: fileUrls.join(\",\")});\r\n  }\r\n\r\n  priviewImg(img: any) {\r\n    let url = ToolsUtil.getOssUrl(this.getImgUrl(img))\r\n    console.log(url)\r\n    this.nzImageService.preview([{\r\n      src: url,\r\n      alt: 'ng-zorro'\r\n    }], {nzZoom: 1.5, nzRotate: 0});\r\n  }\r\n\r\n  getImgUrl(img: any) {\r\n    if (img.originFileObj && img.originFileObj.key) {\r\n      return img.originFileObj.key\r\n    }\r\n    return (img.url || img.thumbUrl)\r\n  }\r\n}\r\n","<div class=\"clearfix\">\r\n  <nz-upload\r\n    *ngIf=\"opts && opts?.uploadType == 'drag'\"\r\n    nzType=\"drag\"\r\n    nzAction=\"\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzRemove]=\"remove\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzLimit]=\"'1'\"\r\n  >\r\n    <p class=\"ant-upload-drag-icon\">\r\n      <i nz-icon nzType=\"inbox\"></i>\r\n    </p>\r\n    <p class=\"ant-upload-text\">单击或拖动文件到此区域上传</p>\r\n  </nz-upload>\r\n  <nz-upload\r\n    *ngIf=\"opts && opts?.uploadType == 'button'\"\r\n    nzType=\"drag\"\r\n    nzAction=\"\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [nzShowUploadList]=\"showUploadList\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzRemove]=\"remove\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzLimit]=\"'1'\"\r\n  >\r\n    <button nz-button nzSize=\"small\"><i nz-icon nzType=\"upload\" style=\"font-size: 16px\"></i><span> {{opts.btnName}}</span></button>\r\n  </nz-upload>\r\n  <nz-upload\r\n    *ngIf=\"opts && !opts?.uploadType \"\r\n    nzAction=\"\"\r\n    nzListType=\"picture-card\"\r\n    [nzSize]=\"opts.nzSize || 0\"\r\n    [(nzFileList)]=\"opts.imageList\"\r\n    [nzShowButton]=\"opts.imageList.length < opts.limit\"\r\n    [nzShowUploadList]=\"showUploadList\"\r\n    [nzPreview]=\"handlePreview\"\r\n    [nzRemove]=\"remove\"\r\n    [nzBeforeUpload]=\"beforeUpload\"\r\n    [nzCustomRequest]=\"customReq\"\r\n    (nzChange)=\"onChange($event)\"\r\n    [nzType]=\"opts?.uploadType\"\r\n    [nzAccept]=\"opts.nzFileType\"\r\n    [nzDisabled]=\"!isEdit\"\r\n    [nzLimit]=\"'1'\"\r\n    [nzFileListRender]=\"opts && isEdit && allowChangSeq && opts.imageList.length > 0 ? fileListTmp : null\"\r\n  >\r\n    <i nz-icon nzType=\"plus\"></i>\r\n    <div class=\"ant-upload-text\">上传图片</div>\r\n  </nz-upload>\r\n  <!-- <a *ngIf=\"allowChangSeq && isEdit && opts.imageList.length > 1\" (click)=\"openBannerSeq(imgsContent, tplFooter)\"\r\n      style=\"margin-left: 10px; \"\r\n   ><i nz-icon nzType=\"plus\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>调整图片顺序</a>-->\r\n  <nz-modal\r\n    [nzVisible]=\"previewVisible\"\r\n    [nzContent]=\"modalContent\"\r\n    [nzFooter]=\"null\"\r\n    (nzOnCancel)=\"previewVisible = false\"\r\n  >\r\n    <ng-template #modalContent>\r\n      <img *ngIf=\"!previewImage.endsWith('.mp4')\" [src]=\"previewImage\" [ngStyle]=\"{ width: '100%' }\"/>\r\n      <div style=\"width: 100%;margin-top: 15px\">\r\n        <app-video *ngIf=\"previewImage.endsWith('.mp4')\" [url]=\"previewImage\"></app-video>\r\n      </div>\r\n    </ng-template>\r\n  </nz-modal>\r\n  <ng-template #imgsContent>\r\n    <ng-container *ngIf=\"opts && opts.imageList\">\r\n      <ng-container *ngFor=\"let imgs of opts.imageList;let i = index\">\r\n        <div class=\"img-div\">\r\n          <img [src]=\"imgs.url || imgs.thumbUrl\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'10px' }\"/>\r\n          <div style=\"margin-right: 20px\">\r\n            <a title=\"上移\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\"><i nz-icon nzType=\"arrow-up\"\r\n                                                                                         nzTheme=\"outline\"\r\n                                                                                         style=\"color: #1890ff; font-size: 15px;\"></i>\r\n              上移</a>\r\n            <a title=\"下移\" *ngIf=\" i < opts.imageList.length - 1\" (click)=\"arrowDown(i)\"><i nz-icon nzType=\"arrow-down\"\r\n                                                                                           nzTheme=\"outline\"\r\n                                                                                           style=\"color: #1890ff; font-size: 15px\"></i>\r\n              下移</a>\r\n          </div>\r\n        </div>\r\n      </ng-container>\r\n    </ng-container>\r\n\r\n  </ng-template>\r\n  <!--  </nz-modal>-->\r\n</div>\r\n<ng-template #fileListTmp>\r\n  <div dragula=\"dragulaBag\" [(dragulaModel)]=\"opts.imageList\" (dragulaModelChange)=\"dragnumber($event)\">\r\n    <ng-container *ngFor=\"let imgs of opts.imageList;let i = index\">\r\n      <div class=\"img-div img-pre\" style=\"\">\r\n        <img [src]=\"getImgUrl(imgs) |ossImg\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'10px' }\"/>\r\n        <div>\r\n          <span (click)=\"priviewImg(imgs)\" nz-icon nzType=\"eye\" nzTheme=\"outline\"></span>\r\n          <span (click)=\"delImg(i)\" nz-icon nzType=\"delete\" nzTheme=\"outline\"></span>\r\n        </div>\r\n      </div>\r\n    </ng-container>\r\n  </div>\r\n\r\n</ng-template>\r\n<ng-template #tplFooter>\r\n  <button nz-button nzType=\"default\" (click)=\"destroyTplModal()\">\r\n    取消\r\n  </button>\r\n  <button nz-button nzType=\"primary\" (click)=\"saveSeq()\">\r\n    保存顺序\r\n  </button>\r\n</ng-template>\r\n\r\n\r\n"]}