atr-components 0.2.224 → 0.2.225

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.
@@ -1,6 +1,6 @@
1
1
  import { HttpService } from './http.service';
2
2
  import { Observable } from 'rxjs';
3
- import { HttpClient, HttpEvent } from '@angular/common/http';
3
+ import { HttpClient } from '@angular/common/http';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class UploadOssService {
6
6
  private httpService;
@@ -8,8 +8,6 @@ export declare class UploadOssService {
8
8
  uploadData: any;
9
9
  constructor(httpService: HttpService, httpClient: HttpClient);
10
10
  uploadOss: (file: any, dir?: string) => Observable<any>;
11
- customReqP: (file: File) => Promise<HttpEvent<unknown> | undefined>;
12
- uploadOssFiles: (files: any[]) => Observable<any>;
13
11
  customReq: (file: File) => Observable<any>;
14
12
  static ɵfac: i0.ɵɵFactoryDeclaration<UploadOssService, never>;
15
13
  static ɵprov: i0.ɵɵInjectableDeclaration<UploadOssService>;
@@ -33,50 +33,6 @@ export class UploadOssService {
33
33
  this.httpService.post(atr_static_datas.OSS_POLICY, { dir: dir, fileName: fileName }, ToolsUtil.getHttpOptions()).subscribe(success, error);
34
34
  });
35
35
  };
36
- this.customReqP = (file) => {
37
- const formData = new FormData();
38
- for (let key in this.uploadData) {
39
- if (key != 'host')
40
- formData.append(key, this.uploadData[key]);
41
- }
42
- formData.append('file', file);
43
- const req = new HttpRequest('POST', this.uploadData.host, formData, {
44
- reportProgress: true
45
- });
46
- return this.httpClient.request(req).toPromise();
47
- };
48
- this.uploadOssFiles = (files) => {
49
- return new Observable(observe => {
50
- const success = (result) => {
51
- if (result.status === 200) {
52
- this.uploadData = result.data;
53
- let param = [];
54
- files.forEach(item => {
55
- item.key = this.uploadData.dir + ToolsUtil.getRandomFileName() + '.' + ToolsUtil.getFileExt(item.name);
56
- param.push(this.customReqP(item));
57
- });
58
- Promise.all(param).then(events => {
59
- for (let i = 0; i < events.length; i++) {
60
- if (events[i].status == 200) {
61
- events[i].url = events[i].url + files[i].key;
62
- }
63
- }
64
- observe.next(events);
65
- observe.unsubscribe();
66
- });
67
- }
68
- else {
69
- observe.next(false);
70
- observe.unsubscribe();
71
- }
72
- };
73
- const error = (err) => {
74
- observe.next(false);
75
- observe.unsubscribe();
76
- };
77
- this.httpService.post(atr_static_datas.OSS_POLICY, { dir: 'ueditor' }, ToolsUtil.getHttpOptions()).subscribe(success, error);
78
- });
79
- };
80
36
  this.customReq = (file) => {
81
37
  const formData = new FormData();
82
38
  for (let key in this.uploadData) {
@@ -111,4 +67,4 @@ UploadOssService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", ver
111
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: UploadOssService, decorators: [{
112
68
  type: Injectable
113
69
  }], ctorParameters: function () { return [{ type: i1.HttpService }, { type: i2.HttpClient }]; } });
114
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-oss.service.js","sourceRoot":"","sources":["../../../../../projects/components/src/core/services/upload-oss.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpService } from './http.service';\r\nimport { Observable } from 'rxjs';\r\nimport { ToolsUtil } from '../utils/ToolsUtil';\r\nimport { HttpRequest, HttpClient, HttpEvent, HttpResponse, HttpEventType } from '@angular/common/http';\r\nimport {atr_static_datas} from \"../base/atr-common\";\r\n\r\n@Injectable()\r\nexport class UploadOssService {\r\n  uploadData: any;\r\n\r\n  constructor(private httpService: HttpService,private httpClient: HttpClient) { }\r\n\r\n  uploadOss = (file:any,dir = 'ueditor') => {\r\n    return new Observable<any>(observe => {\r\n      const success = (result:any) => {\r\n        if (result.status === 200) {\r\n          this.uploadData = result.data;\r\n          this.customReq(file).subscribe((url) => {\r\n            observe.next(url);\r\n            observe.unsubscribe();\r\n          });\r\n\r\n        } else {\r\n          observe.next(false);\r\n          observe.unsubscribe();\r\n        }\r\n      };\r\n\r\n      const error = (err:any) => {\r\n        observe.next(false);\r\n        observe.unsubscribe();\r\n      };\r\n      let fileName = ToolsUtil.getRandomFileName() + \".\" + ToolsUtil.getFileExt(file.name);\r\n      this.httpService.post(atr_static_datas.OSS_POLICY, { dir: dir,fileName:fileName}, ToolsUtil.getHttpOptions()).subscribe(success, error);\r\n    });\r\n\r\n  }\r\n  customReqP = (file: File) => {\r\n    const formData = new FormData();\r\n    for(let key in this.uploadData){\r\n      if(key!='host')\r\n      formData.append(key,this.uploadData[key])\r\n    }\r\n    formData.append('file', file as any);\r\n    \r\n    const req = new HttpRequest('POST', this.uploadData.host!, formData, {\r\n      reportProgress: true\r\n    });\r\n    return this.httpClient.request(req).toPromise();\r\n  }\r\n  uploadOssFiles = (files: any[]) => {\r\n    return new Observable<any>(observe => {\r\n      const success = (result:any) => {\r\n        if (result.status === 200) {\r\n          this.uploadData = result.data;\r\n          let param: any[] = [];\r\n          files.forEach(item => {\r\n            item.key = this.uploadData.dir + ToolsUtil.getRandomFileName() + '.' + ToolsUtil.getFileExt(item.name);\r\n            param.push(this.customReqP(item));\r\n          })\r\n          Promise.all(param).then(events => {\r\n            for (let i = 0; i < events.length; i++) {\r\n              if (events[i].status == 200) {\r\n                events[i].url = events[i].url + files[i].key;\r\n              }\r\n            }\r\n            observe.next(events);\r\n            observe.unsubscribe();\r\n          })\r\n\r\n        } else {\r\n          observe.next(false);\r\n          observe.unsubscribe();\r\n        }\r\n      };\r\n\r\n      const error = (err:any) => {\r\n        observe.next(false);\r\n        observe.unsubscribe();\r\n      };\r\n\r\n      this.httpService.post(atr_static_datas.OSS_POLICY, {dir: 'ueditor'}, ToolsUtil.getHttpOptions()).subscribe(success, error);\r\n    });\r\n\r\n  }\r\n  customReq = (file: File) => {\r\n    const formData = new FormData();\r\n    for(let key in this.uploadData){\r\n      if(key!='host')\r\n      formData.append(key,this.uploadData[key])\r\n    }\r\n    formData.append('file', file as any);\r\n\r\n    const req = new HttpRequest('POST', this.uploadData.host!, formData, {\r\n      reportProgress: true\r\n    });\r\n\r\n    return new Observable<any>(observe => {\r\n      const success = (event: HttpEvent<any>) => {\r\n        if (event.type === HttpEventType.UploadProgress) {\r\n\r\n        } else if (event instanceof HttpResponse) {\r\n          const url = event.url + this.uploadData.key;\r\n          observe.next(url);\r\n          observe.unsubscribe();\r\n        }\r\n      }\r\n\r\n      const error = () => {\r\n        observe.next(false);\r\n        observe.unsubscribe();\r\n      };\r\n\r\n      this.httpClient.request(req).subscribe(success, error);\r\n    });\r\n  }\r\n\r\n}\r\n"]}
70
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXBsb2FkLW9zcy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29tcG9uZW50cy9zcmMvY29yZS9zZXJ2aWNlcy91cGxvYWQtb3NzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQ2xDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUF5QixZQUFZLEVBQUUsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdkcsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sb0JBQW9CLENBQUM7Ozs7QUFHcEQsTUFBTSxPQUFPLGdCQUFnQjtJQUczQixZQUFvQixXQUF3QixFQUFTLFVBQXNCO1FBQXZELGdCQUFXLEdBQVgsV0FBVyxDQUFhO1FBQVMsZUFBVSxHQUFWLFVBQVUsQ0FBWTtRQUUzRSxjQUFTLEdBQUcsQ0FBQyxJQUFRLEVBQUMsR0FBRyxHQUFHLFNBQVMsRUFBRSxFQUFFO1lBQ3ZDLE9BQU8sSUFBSSxVQUFVLENBQU0sT0FBTyxDQUFDLEVBQUU7Z0JBQ25DLE1BQU0sT0FBTyxHQUFHLENBQUMsTUFBVSxFQUFFLEVBQUU7b0JBQzdCLElBQUksTUFBTSxDQUFDLE1BQU0sS0FBSyxHQUFHLEVBQUU7d0JBQ3pCLElBQUksQ0FBQyxVQUFVLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQzt3QkFDOUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRTs0QkFDckMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzs0QkFDbEIsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO3dCQUN4QixDQUFDLENBQUMsQ0FBQztxQkFFSjt5QkFBTTt3QkFDTCxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO3dCQUNwQixPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7cUJBQ3ZCO2dCQUNILENBQUMsQ0FBQztnQkFFRixNQUFNLEtBQUssR0FBRyxDQUFDLEdBQU8sRUFBRSxFQUFFO29CQUN4QixPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNwQixPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ3hCLENBQUMsQ0FBQztnQkFDRixJQUFJLFFBQVEsR0FBRyxTQUFTLENBQUMsaUJBQWlCLEVBQUUsR0FBRyxHQUFHLEdBQUcsU0FBUyxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUM7Z0JBQ3JGLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsRUFBRSxFQUFFLEdBQUcsRUFBRSxHQUFHLEVBQUMsUUFBUSxFQUFDLFFBQVEsRUFBQyxFQUFFLFNBQVMsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFDMUksQ0FBQyxDQUFDLENBQUM7UUFFTCxDQUFDLENBQUE7UUFFRCxjQUFTLEdBQUcsQ0FBQyxJQUFVLEVBQUUsRUFBRTtZQUN6QixNQUFNLFFBQVEsR0FBRyxJQUFJLFFBQVEsRUFBRSxDQUFDO1lBQ2hDLEtBQUksSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLFVBQVUsRUFBQztnQkFDN0IsSUFBRyxHQUFHLElBQUUsTUFBTTtvQkFDZCxRQUFRLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUE7YUFDMUM7WUFDRCxRQUFRLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxJQUFXLENBQUMsQ0FBQztZQUVyQyxNQUFNLEdBQUcsR0FBRyxJQUFJLFdBQVcsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFLLEVBQUUsUUFBUSxFQUFFO2dCQUNuRSxjQUFjLEVBQUUsSUFBSTthQUNyQixDQUFDLENBQUM7WUFFSCxPQUFPLElBQUksVUFBVSxDQUFNLE9BQU8sQ0FBQyxFQUFFO2dCQUNuQyxNQUFNLE9BQU8sR0FBRyxDQUFDLEtBQXFCLEVBQUUsRUFBRTtvQkFDeEMsSUFBSSxLQUFLLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxjQUFjLEVBQUU7cUJBRWhEO3lCQUFNLElBQUksS0FBSyxZQUFZLFlBQVksRUFBRTt3QkFDeEMsTUFBTSxHQUFHLEdBQUcsS0FBSyxDQUFDLEdBQUcsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsQ0FBQzt3QkFDNUMsT0FBTyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQzt3QkFDbEIsT0FBTyxDQUFDLFdBQVcsRUFBRSxDQUFDO3FCQUN2QjtnQkFDSCxDQUFDLENBQUE7Z0JBRUQsTUFBTSxLQUFLLEdBQUcsR0FBRyxFQUFFO29CQUNqQixPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO29CQUNwQixPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7Z0JBQ3hCLENBQUMsQ0FBQztnQkFFRixJQUFJLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFLEtBQUssQ0FBQyxDQUFDO1lBQ3pELENBQUMsQ0FBQyxDQUFDO1FBQ0wsQ0FBQyxDQUFBO0lBMUQ4RSxDQUFDOzs4R0FIckUsZ0JBQWdCO2tIQUFoQixnQkFBZ0I7NEZBQWhCLGdCQUFnQjtrQkFENUIsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSHR0cFNlcnZpY2UgfSBmcm9tICcuL2h0dHAuc2VydmljZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgVG9vbHNVdGlsIH0gZnJvbSAnLi4vdXRpbHMvVG9vbHNVdGlsJztcclxuaW1wb3J0IHsgSHR0cFJlcXVlc3QsIEh0dHBDbGllbnQsIEh0dHBFdmVudCwgSHR0cFJlc3BvbnNlLCBIdHRwRXZlbnRUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQge2F0cl9zdGF0aWNfZGF0YXN9IGZyb20gXCIuLi9iYXNlL2F0ci1jb21tb25cIjtcclxuXHJcbkBJbmplY3RhYmxlKClcclxuZXhwb3J0IGNsYXNzIFVwbG9hZE9zc1NlcnZpY2Uge1xyXG4gIHVwbG9hZERhdGE6IGFueTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwU2VydmljZTogSHR0cFNlcnZpY2UscHJpdmF0ZSBodHRwQ2xpZW50OiBIdHRwQ2xpZW50KSB7IH1cclxuXHJcbiAgdXBsb2FkT3NzID0gKGZpbGU6YW55LGRpciA9ICd1ZWRpdG9yJykgPT4ge1xyXG4gICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlPGFueT4ob2JzZXJ2ZSA9PiB7XHJcbiAgICAgIGNvbnN0IHN1Y2Nlc3MgPSAocmVzdWx0OmFueSkgPT4ge1xyXG4gICAgICAgIGlmIChyZXN1bHQuc3RhdHVzID09PSAyMDApIHtcclxuICAgICAgICAgIHRoaXMudXBsb2FkRGF0YSA9IHJlc3VsdC5kYXRhO1xyXG4gICAgICAgICAgdGhpcy5jdXN0b21SZXEoZmlsZSkuc3Vic2NyaWJlKCh1cmwpID0+IHtcclxuICAgICAgICAgICAgb2JzZXJ2ZS5uZXh0KHVybCk7XHJcbiAgICAgICAgICAgIG9ic2VydmUudW5zdWJzY3JpYmUoKTtcclxuICAgICAgICAgIH0pO1xyXG5cclxuICAgICAgICB9IGVsc2Uge1xyXG4gICAgICAgICAgb2JzZXJ2ZS5uZXh0KGZhbHNlKTtcclxuICAgICAgICAgIG9ic2VydmUudW5zdWJzY3JpYmUoKTtcclxuICAgICAgICB9XHJcbiAgICAgIH07XHJcblxyXG4gICAgICBjb25zdCBlcnJvciA9IChlcnI6YW55KSA9PiB7XHJcbiAgICAgICAgb2JzZXJ2ZS5uZXh0KGZhbHNlKTtcclxuICAgICAgICBvYnNlcnZlLnVuc3Vic2NyaWJlKCk7XHJcbiAgICAgIH07XHJcbiAgICAgIGxldCBmaWxlTmFtZSA9IFRvb2xzVXRpbC5nZXRSYW5kb21GaWxlTmFtZSgpICsgXCIuXCIgKyBUb29sc1V0aWwuZ2V0RmlsZUV4dChmaWxlLm5hbWUpO1xyXG4gICAgICB0aGlzLmh0dHBTZXJ2aWNlLnBvc3QoYXRyX3N0YXRpY19kYXRhcy5PU1NfUE9MSUNZLCB7IGRpcjogZGlyLGZpbGVOYW1lOmZpbGVOYW1lfSwgVG9vbHNVdGlsLmdldEh0dHBPcHRpb25zKCkpLnN1YnNjcmliZShzdWNjZXNzLCBlcnJvcik7XHJcbiAgICB9KTtcclxuXHJcbiAgfVxyXG4gIFxyXG4gIGN1c3RvbVJlcSA9IChmaWxlOiBGaWxlKSA9PiB7XHJcbiAgICBjb25zdCBmb3JtRGF0YSA9IG5ldyBGb3JtRGF0YSgpO1xyXG4gICAgZm9yKGxldCBrZXkgaW4gdGhpcy51cGxvYWREYXRhKXtcclxuICAgICAgaWYoa2V5IT0naG9zdCcpXHJcbiAgICAgIGZvcm1EYXRhLmFwcGVuZChrZXksdGhpcy51cGxvYWREYXRhW2tleV0pXHJcbiAgICB9XHJcbiAgICBmb3JtRGF0YS5hcHBlbmQoJ2ZpbGUnLCBmaWxlIGFzIGFueSk7XHJcblxyXG4gICAgY29uc3QgcmVxID0gbmV3IEh0dHBSZXF1ZXN0KCdQT1NUJywgdGhpcy51cGxvYWREYXRhLmhvc3QhLCBmb3JtRGF0YSwge1xyXG4gICAgICByZXBvcnRQcm9ncmVzczogdHJ1ZVxyXG4gICAgfSk7XHJcblxyXG4gICAgcmV0dXJuIG5ldyBPYnNlcnZhYmxlPGFueT4ob2JzZXJ2ZSA9PiB7XHJcbiAgICAgIGNvbnN0IHN1Y2Nlc3MgPSAoZXZlbnQ6IEh0dHBFdmVudDxhbnk+KSA9PiB7XHJcbiAgICAgICAgaWYgKGV2ZW50LnR5cGUgPT09IEh0dHBFdmVudFR5cGUuVXBsb2FkUHJvZ3Jlc3MpIHtcclxuXHJcbiAgICAgICAgfSBlbHNlIGlmIChldmVudCBpbnN0YW5jZW9mIEh0dHBSZXNwb25zZSkge1xyXG4gICAgICAgICAgY29uc3QgdXJsID0gZXZlbnQudXJsICsgdGhpcy51cGxvYWREYXRhLmtleTtcclxuICAgICAgICAgIG9ic2VydmUubmV4dCh1cmwpO1xyXG4gICAgICAgICAgb2JzZXJ2ZS51bnN1YnNjcmliZSgpO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG5cclxuICAgICAgY29uc3QgZXJyb3IgPSAoKSA9PiB7XHJcbiAgICAgICAgb2JzZXJ2ZS5uZXh0KGZhbHNlKTtcclxuICAgICAgICBvYnNlcnZlLnVuc3Vic2NyaWJlKCk7XHJcbiAgICAgIH07XHJcblxyXG4gICAgICB0aGlzLmh0dHBDbGllbnQucmVxdWVzdChyZXEpLnN1YnNjcmliZShzdWNjZXNzLCBlcnJvcik7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
@@ -126,18 +126,16 @@ export class QuillEditorComponent {
126
126
  if (!blods || blods.length <= 0) {
127
127
  return;
128
128
  }
129
- this.uploadOssService.uploadOssFiles(blods.map((v) => v.blob)).subscribe((res) => {
130
- if (res && res.length > 0) {
129
+ for (let i = 0; i < blods.length; i++) {
130
+ let blob = blods[i];
131
+ this.uploadOssService.uploadOss(blob).subscribe((url) => {
131
132
  let delta = this.editor.getContents();
132
- for (let i = 0; i < res.length; i++) {
133
- console.log('delta', delta);
134
- delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
135
- opt.insert.image = res[i].url;
136
- });
137
- }
133
+ delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
134
+ opt.insert.image = url;
135
+ });
138
136
  this.editor.setContents(delta, 'api');
139
- }
140
- });
137
+ });
138
+ }
141
139
  }
142
140
  isEndContents(blods, index) {
143
141
  let details = this.editor.getContents();
@@ -247,4 +245,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
247
245
  }], needImgSeq: [{
248
246
  type: Input
249
247
  }] } });
250
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.ts","../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, forwardRef, ViewChild} from '@angular/core';\r\nimport {Subject} from 'rxjs';\r\nimport {debounceTime} from 'rxjs/operators';\r\nimport Quill from 'quill';\r\nimport ResizeModule from \"@ssumo/quill-resize-module\";\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {NzMessageService} from 'ng-zorro-antd/message';\r\nimport {UploadOssService} from \"../../../core/services/upload-oss.service\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\n\r\nQuill.register(\"modules/resize\", ResizeModule);\r\nconst icons = Quill.import('ui/icons');\r\nicons.undo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"6 10 4 12 2 10 6 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M8.09,13.91A4.6,4.6,0,0,0,9,14,5,5,0,1,0,4,9\"></path>\r\n</svg>`;\r\nicons.redo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"12 10 14 12 16 10 12 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M9.91,13.91A4.6,4.6,0,0,1,9,14a5,5,0,1,1,5-5\"></path>\r\n</svg>`;\r\n\r\n@Component({\r\n  selector: 'app-quill-editor',\r\n  templateUrl: './quill-editor.component.html',\r\n  styleUrls: ['./quill-editor.component.less'],\r\n  providers: [\r\n    UploadOssService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => QuillEditorComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class QuillEditorComponent implements OnInit, ControlValueAccessor {\r\n\r\n  @Input() placeholder = '请输入';\r\n  @Input() styles: any = {height: '350px'};\r\n  @Input() value: string | any; // 组件对应的 “ ngModel ”\r\n  @Input() readOnly: boolean = false;\r\n  @Input() needImgSeq: boolean = false;\r\n  editor: any;\r\n  onChangeListener: any; // 改变值回调\r\n  onTouchedListener: any; // 交互回调\r\n  imgUrls: any = [];\r\n  editor$ = new Subject<string>();\r\n  imgVis = false;\r\n\r\n  constructor(private uploadOssService: UploadOssService, private message: NzMessageService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.editor$.pipe(\r\n      debounceTime(700)\r\n    ).subscribe((editorContent: string) => {\r\n      if (typeof (this.onChangeListener) === 'function' && typeof (this.onTouchedListener)) {\r\n        this.onChangeListener(editorContent); // 告诉form，你的表单值改变成了payload\r\n        this.onTouchedListener(); // 告诉form，你的表单有交互发生\r\n      }\r\n    });\r\n  }\r\n\r\n  writeValue(value: string | any[]): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChangeListener = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedListener = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n\r\n  }\r\n\r\n  onChange(quill: any) {\r\n    this.editor$.next(quill.html);\r\n  }\r\n\r\n  EditorCreated(quill: any) {\r\n    const toolbar = quill.getModule('toolbar');\r\n    toolbar.addHandler('image', this.imageHandler.bind(this));\r\n    this.editor = quill;\r\n    let that = this;\r\n    quill.on('text-change', function (delta: any, oldDelta: any, source: any) {\r\n      if (source == 'api') {\r\n      } else if (source == 'user') {\r\n        console.log('user');\r\n        that.uploadImgs([], 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  getBlobByBase64(url: any, oldUrl: any) {\r\n    const c: any = document.createElement('canvas');\r\n    console.log(c);\r\n    const ctx = c.getContext('2d');\r\n    ctx.stroke();\r\n    let blob: any = ToolsUtil.dataURItoBlob(url);\r\n    blob.name = '.png';\r\n    let delta = this.editor.getContents();\r\n    console.log('delta', delta)\r\n    for (let i = 0; i < delta.ops.length; i++) {\r\n      if (delta.ops[i].insert.image == oldUrl) {\r\n        return {\r\n          index: i,\r\n          blob: blob,\r\n          oldUrl: oldUrl\r\n        }\r\n      }\r\n    }\r\n    return;\r\n  }\r\n\r\n  uploadImgs(blods: any, index: any) {\r\n    let details = this.editor.getContents();\r\n    let opt = details.ops[index];\r\n    if (opt && opt.insert && opt.insert.image) {\r\n      if (ToolsUtil.isBase64(opt.insert.image)) {\r\n        blods.push(this.getBlobByBase64(opt.insert.image, opt.insert.image));\r\n        this.isEndContents(blods, index)\r\n      } else {\r\n        let c = document.createElement('canvas');\r\n        let ctx: any = c.getContext('2d');\r\n        let img = new Image();\r\n        img.src = opt.insert.image;\r\n        img.setAttribute('crossOrigin', '*');\r\n        let that = this;\r\n        img.onload = function () {\r\n          c.width = img.width;\r\n          c.height = img.height;\r\n          ctx.drawImage(img, 0, 0, img.width, img.height);\r\n          let url = c.toDataURL();\r\n          blods.push(that.getBlobByBase64(url, img.src))\r\n          that.isEndContents(blods, index)\r\n        }\r\n      }\r\n    } else {\r\n      this.isEndContents(blods, index)\r\n    }\r\n\r\n  }\r\n  uploadImg(blods:any) {\r\n    if (!blods || blods.length <= 0) {\r\n      return\r\n    }\r\n    this.uploadOssService.uploadOssFiles(blods.map((v:any) => v.blob)).subscribe((res:any) => {\r\n        if (res && res.length > 0) {\r\n          let delta = this.editor.getContents();\r\n          for (let i = 0; i < res.length; i++) {\r\n            console.log('delta', delta);\r\n            delta.filter((opt:any) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt:any, index:any) => {\r\n              opt.insert.image = res[i].url\r\n            });\r\n          }\r\n          this.editor.setContents(delta, 'api');\r\n        }\r\n      }\r\n    )\r\n  }\r\n  isEndContents(blods:any, index:any) {\r\n    let details = this.editor.getContents();\r\n    if (++index != details.ops.length) {\r\n      this.uploadImgs(blods, index);\r\n    } else {\r\n      this.uploadImg(blods);\r\n    }\r\n  }\r\n\r\n  imageHandler() {\r\n    const Imageinput = document.createElement('input');\r\n    Imageinput.setAttribute('type', 'file');\r\n    Imageinput.setAttribute('multiple', 'multiple');\r\n    Imageinput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp');\r\n    Imageinput.classList.add('ql-image');\r\n    Imageinput.addEventListener('change', () => {\r\n      if (this.needImgSeq) {\r\n        this.imgVis = true;\r\n      }\r\n      console.log(Imageinput);\r\n      let files: any = Imageinput.files;\r\n      if (files === null || files.length == 0) {\r\n        return;\r\n      }\r\n      this.imgUrls = [];\r\n      for (let i = 0; i < files.length; i++) {\r\n        const file = files[i];\r\n        if (file === null) {\r\n          continue;\r\n        }\r\n\r\n\r\n        const error = (res: any) => {\r\n          this.message.warning('上传失败');\r\n        };\r\n\r\n        this.uploadOssService.uploadOss(file).subscribe((url) => {\r\n          console.log(file);\r\n          if (url) {\r\n            this.imgUrls.push({url: url, file: file, index: i});\r\n            if (!this.needImgSeq) {\r\n              this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', url);\r\n            }\r\n          } else {\r\n            this.message.warning('上传失败');\r\n          }\r\n          if (this.needImgSeq && this.imgUrls.length == files.length) {\r\n            this.imgVis = true;\r\n            this.imgUrls.sort((a: any, b: any) => a.index - b.index);\r\n            document.getElementById(\"te\")?.click();\r\n          }\r\n        }, error);\r\n      }\r\n\r\n    });\r\n\r\n    Imageinput.click();\r\n  }\r\n\r\n  saveSeq() {\r\n    console.log(123);\r\n    for (let i = this.imgUrls.length - 1; i >= 0; i--) {\r\n      this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', this.imgUrls[i].url);\r\n    }\r\n    this.imgVis = false;\r\n  }\r\n\r\n  arrowUp(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index - 1];\r\n    this.imgUrls[index - 1] = img;\r\n  }\r\n\r\n  arrowDown(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index + 1];\r\n    this.imgUrls[index + 1] = img;\r\n  }\r\n\r\n  cancle() {\r\n    this.imgVis = false;\r\n  }\r\n\r\n  te() {\r\n    console.log('上传完毕')\r\n  }\r\n}\r\n","<quill-editor\r\n  [styles]=\"styles\"\r\n  [placeholder]=\"placeholder\"\r\n  (onEditorCreated)=\"EditorCreated($event)\"\r\n  [(ngModel)]=\"value\"\r\n  (onContentChanged)=\"onChange($event)\"\r\n  [readOnly]=\"readOnly\"\r\n></quill-editor>\r\n<!--这个div,是因为上传完毕焦点还在富文本里,弹出无法显示.....-->\r\n<div id=\"te\" (click)=\"te()\"></div>\r\n<nz-modal [(nzVisible)]=\"imgVis\" (nzOnOk)=\"saveSeq()\" (nzOnCancel)=\"cancle()\" nzMaskClosable=\"false\"\r\n          [nzStyle]=\"{padding:0}\">\r\n  <ng-container *nzModalContent>\r\n  <div style=\"max-height:600px;overflow:auto;margin-top: 10px;\">\r\n    <ng-container *ngTemplateOutlet=\"imgsContent\"></ng-container>\r\n  </div>\r\n  </ng-container>\r\n</nz-modal>\r\n<ng-template #imgsContent>\r\n  <ng-container *ngFor=\"let imgOpt of imgUrls;let i = index\">\r\n    <div class=\"img-div\">\r\n      <img [src]=\"imgOpt.url\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'5px' }\"/>\r\n      <div style=\"margin-left: 20px; color: grey;\">{{imgOpt.file.name}}</div>\r\n      <div style=\"margin-right: 20px; flex: 1;text-align: right;\">\r\n        <a title=\"上移\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\">\r\n          <i nz-icon nzType=\"arrow-up\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px;\"></i>\r\n          上移</a>\r\n        <a title=\"下移\" *ngIf=\" i < imgUrls.length - 1\" (click)=\"arrowDown(i)\">\r\n          <i nz-icon nzType=\"arrow-down\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>\r\n          下移</a>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n"]}
248
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"quill-editor.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.ts","../../../../../../projects/components/src/lib/shared/quill-editor/quill-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, Input, forwardRef, ViewChild} from '@angular/core';\r\nimport {Subject} from 'rxjs';\r\nimport {debounceTime} from 'rxjs/operators';\r\nimport Quill from 'quill';\r\nimport ResizeModule from \"@ssumo/quill-resize-module\";\r\nimport {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';\r\nimport {NzMessageService} from 'ng-zorro-antd/message';\r\nimport {UploadOssService} from \"../../../core/services/upload-oss.service\";\r\nimport {ToolsUtil} from \"../../../core/utils/ToolsUtil\";\r\n\r\nQuill.register(\"modules/resize\", ResizeModule);\r\nconst icons = Quill.import('ui/icons');\r\nicons.undo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"6 10 4 12 2 10 6 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M8.09,13.91A4.6,4.6,0,0,0,9,14,5,5,0,1,0,4,9\"></path>\r\n</svg>`;\r\nicons.redo = `<svg viewbox=\"0 0 18 18\">\r\n  <polygon class=\"ql-fill ql-stroke\" points=\"12 10 14 12 16 10 12 10\"></polygon>\r\n  <path class=\"ql-stroke\" d=\"M9.91,13.91A4.6,4.6,0,0,1,9,14a5,5,0,1,1,5-5\"></path>\r\n</svg>`;\r\n\r\n@Component({\r\n  selector: 'app-quill-editor',\r\n  templateUrl: './quill-editor.component.html',\r\n  styleUrls: ['./quill-editor.component.less'],\r\n  providers: [\r\n    UploadOssService,\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => QuillEditorComponent),\r\n      multi: true\r\n    }\r\n  ]\r\n})\r\nexport class QuillEditorComponent implements OnInit, ControlValueAccessor {\r\n\r\n  @Input() placeholder = '请输入';\r\n  @Input() styles: any = {height: '350px'};\r\n  @Input() value: string | any; // 组件对应的 “ ngModel ”\r\n  @Input() readOnly: boolean = false;\r\n  @Input() needImgSeq: boolean = false;\r\n  editor: any;\r\n  onChangeListener: any; // 改变值回调\r\n  onTouchedListener: any; // 交互回调\r\n  imgUrls: any = [];\r\n  editor$ = new Subject<string>();\r\n  imgVis = false;\r\n\r\n  constructor(private uploadOssService: UploadOssService, private message: NzMessageService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.editor$.pipe(\r\n      debounceTime(700)\r\n    ).subscribe((editorContent: string) => {\r\n      if (typeof (this.onChangeListener) === 'function' && typeof (this.onTouchedListener)) {\r\n        this.onChangeListener(editorContent); // 告诉form，你的表单值改变成了payload\r\n        this.onTouchedListener(); // 告诉form，你的表单有交互发生\r\n      }\r\n    });\r\n  }\r\n\r\n  writeValue(value: string | any[]): void {\r\n    this.value = value;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChangeListener = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedListener = fn;\r\n  }\r\n\r\n  setDisabledState?(isDisabled: boolean): void {\r\n\r\n  }\r\n\r\n  onChange(quill: any) {\r\n    this.editor$.next(quill.html);\r\n  }\r\n\r\n  EditorCreated(quill: any) {\r\n    const toolbar = quill.getModule('toolbar');\r\n    toolbar.addHandler('image', this.imageHandler.bind(this));\r\n    this.editor = quill;\r\n    let that = this;\r\n    quill.on('text-change', function (delta: any, oldDelta: any, source: any) {\r\n      if (source == 'api') {\r\n      } else if (source == 'user') {\r\n        console.log('user');\r\n        that.uploadImgs([], 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  getBlobByBase64(url: any, oldUrl: any) {\r\n    const c: any = document.createElement('canvas');\r\n    console.log(c);\r\n    const ctx = c.getContext('2d');\r\n    ctx.stroke();\r\n    let blob: any = ToolsUtil.dataURItoBlob(url);\r\n    blob.name = '.png';\r\n    let delta = this.editor.getContents();\r\n    console.log('delta', delta)\r\n    for (let i = 0; i < delta.ops.length; i++) {\r\n      if (delta.ops[i].insert.image == oldUrl) {\r\n        return {\r\n          index: i,\r\n          blob: blob,\r\n          oldUrl: oldUrl\r\n        }\r\n      }\r\n    }\r\n    return;\r\n  }\r\n\r\n  uploadImgs(blods: any, index: any) {\r\n    let details = this.editor.getContents();\r\n    let opt = details.ops[index];\r\n    if (opt && opt.insert && opt.insert.image) {\r\n      if (ToolsUtil.isBase64(opt.insert.image)) {\r\n        blods.push(this.getBlobByBase64(opt.insert.image, opt.insert.image));\r\n        this.isEndContents(blods, index)\r\n      } else {\r\n        let c = document.createElement('canvas');\r\n        let ctx: any = c.getContext('2d');\r\n        let img = new Image();\r\n        img.src = opt.insert.image;\r\n        img.setAttribute('crossOrigin', '*');\r\n        let that = this;\r\n        img.onload = function () {\r\n          c.width = img.width;\r\n          c.height = img.height;\r\n          ctx.drawImage(img, 0, 0, img.width, img.height);\r\n          let url = c.toDataURL();\r\n          blods.push(that.getBlobByBase64(url, img.src))\r\n          that.isEndContents(blods, index)\r\n        }\r\n      }\r\n    } else {\r\n      this.isEndContents(blods, index)\r\n    }\r\n\r\n  }\r\n  uploadImg(blods:any) {\r\n    if (!blods || blods.length <= 0) {\r\n      return\r\n    }\r\n\r\n    for(let i = 0;i< blods.length;i++){\r\n      let blob = blods[i];\r\n      this.uploadOssService.uploadOss(blob).subscribe((url) => {\r\n        let delta = this.editor.getContents();\r\n        delta.filter((opt:any) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt:any, index:any) => {\r\n          opt.insert.image = url\r\n        });\r\n        this.editor.setContents(delta, 'api');\r\n      })\r\n    }\r\n  }\r\n  isEndContents(blods:any, index:any) {\r\n    let details = this.editor.getContents();\r\n    if (++index != details.ops.length) {\r\n      this.uploadImgs(blods, index);\r\n    } else {\r\n      this.uploadImg(blods);\r\n    }\r\n  }\r\n\r\n  imageHandler() {\r\n    const Imageinput = document.createElement('input');\r\n    Imageinput.setAttribute('type', 'file');\r\n    Imageinput.setAttribute('multiple', 'multiple');\r\n    Imageinput.setAttribute('accept', 'image/png, image/gif, image/jpeg, image/bmp');\r\n    Imageinput.classList.add('ql-image');\r\n    Imageinput.addEventListener('change', () => {\r\n      if (this.needImgSeq) {\r\n        this.imgVis = true;\r\n      }\r\n      console.log(Imageinput);\r\n      let files: any = Imageinput.files;\r\n      if (files === null || files.length == 0) {\r\n        return;\r\n      }\r\n      this.imgUrls = [];\r\n      for (let i = 0; i < files.length; i++) {\r\n        const file = files[i];\r\n        if (file === null) {\r\n          continue;\r\n        }\r\n\r\n\r\n        const error = (res: any) => {\r\n          this.message.warning('上传失败');\r\n        };\r\n\r\n        this.uploadOssService.uploadOss(file).subscribe((url) => {\r\n          console.log(file);\r\n          if (url) {\r\n            this.imgUrls.push({url: url, file: file, index: i});\r\n            if (!this.needImgSeq) {\r\n              this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', url);\r\n            }\r\n          } else {\r\n            this.message.warning('上传失败');\r\n          }\r\n          if (this.needImgSeq && this.imgUrls.length == files.length) {\r\n            this.imgVis = true;\r\n            this.imgUrls.sort((a: any, b: any) => a.index - b.index);\r\n            document.getElementById(\"te\")?.click();\r\n          }\r\n        }, error);\r\n      }\r\n\r\n    });\r\n\r\n    Imageinput.click();\r\n  }\r\n\r\n  saveSeq() {\r\n    console.log(123);\r\n    for (let i = this.imgUrls.length - 1; i >= 0; i--) {\r\n      this.editor.insertEmbed(this.editor.getSelection(true).index, 'image', this.imgUrls[i].url);\r\n    }\r\n    this.imgVis = false;\r\n  }\r\n\r\n  arrowUp(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index - 1];\r\n    this.imgUrls[index - 1] = img;\r\n  }\r\n\r\n  arrowDown(index: any) {\r\n    let img = this.imgUrls[index];\r\n    this.imgUrls[index] = this.imgUrls[index + 1];\r\n    this.imgUrls[index + 1] = img;\r\n  }\r\n\r\n  cancle() {\r\n    this.imgVis = false;\r\n  }\r\n\r\n  te() {\r\n    console.log('上传完毕')\r\n  }\r\n}\r\n","<quill-editor\r\n  [styles]=\"styles\"\r\n  [placeholder]=\"placeholder\"\r\n  (onEditorCreated)=\"EditorCreated($event)\"\r\n  [(ngModel)]=\"value\"\r\n  (onContentChanged)=\"onChange($event)\"\r\n  [readOnly]=\"readOnly\"\r\n></quill-editor>\r\n<!--这个div,是因为上传完毕焦点还在富文本里,弹出无法显示.....-->\r\n<div id=\"te\" (click)=\"te()\"></div>\r\n<nz-modal [(nzVisible)]=\"imgVis\" (nzOnOk)=\"saveSeq()\" (nzOnCancel)=\"cancle()\" nzMaskClosable=\"false\"\r\n          [nzStyle]=\"{padding:0}\">\r\n  <ng-container *nzModalContent>\r\n  <div style=\"max-height:600px;overflow:auto;margin-top: 10px;\">\r\n    <ng-container *ngTemplateOutlet=\"imgsContent\"></ng-container>\r\n  </div>\r\n  </ng-container>\r\n</nz-modal>\r\n<ng-template #imgsContent>\r\n  <ng-container *ngFor=\"let imgOpt of imgUrls;let i = index\">\r\n    <div class=\"img-div\">\r\n      <img [src]=\"imgOpt.url\" [ngStyle]=\"{ width: '100px',display: 'inline-block', margin:'5px' }\"/>\r\n      <div style=\"margin-left: 20px; color: grey;\">{{imgOpt.file.name}}</div>\r\n      <div style=\"margin-right: 20px; flex: 1;text-align: right;\">\r\n        <a title=\"上移\" *ngIf=\" i > 0\" style=\"display: block;\" (click)=\"arrowUp(i)\">\r\n          <i nz-icon nzType=\"arrow-up\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px;\"></i>\r\n          上移</a>\r\n        <a title=\"下移\" *ngIf=\" i < imgUrls.length - 1\" (click)=\"arrowDown(i)\">\r\n          <i nz-icon nzType=\"arrow-down\" nzTheme=\"outline\" style=\"color: #1890ff; font-size: 15px\"></i>\r\n          下移</a>\r\n      </div>\r\n    </div>\r\n  </ng-container>\r\n</ng-template>\r\n\r\n"]}
@@ -1959,50 +1959,6 @@ class UploadOssService {
1959
1959
  this.httpService.post(atr_static_datas.OSS_POLICY, { dir: dir, fileName: fileName }, ToolsUtil.getHttpOptions()).subscribe(success, error);
1960
1960
  });
1961
1961
  };
1962
- this.customReqP = (file) => {
1963
- const formData = new FormData();
1964
- for (let key in this.uploadData) {
1965
- if (key != 'host')
1966
- formData.append(key, this.uploadData[key]);
1967
- }
1968
- formData.append('file', file);
1969
- const req = new HttpRequest('POST', this.uploadData.host, formData, {
1970
- reportProgress: true
1971
- });
1972
- return this.httpClient.request(req).toPromise();
1973
- };
1974
- this.uploadOssFiles = (files) => {
1975
- return new Observable(observe => {
1976
- const success = (result) => {
1977
- if (result.status === 200) {
1978
- this.uploadData = result.data;
1979
- let param = [];
1980
- files.forEach(item => {
1981
- item.key = this.uploadData.dir + ToolsUtil.getRandomFileName() + '.' + ToolsUtil.getFileExt(item.name);
1982
- param.push(this.customReqP(item));
1983
- });
1984
- Promise.all(param).then(events => {
1985
- for (let i = 0; i < events.length; i++) {
1986
- if (events[i].status == 200) {
1987
- events[i].url = events[i].url + files[i].key;
1988
- }
1989
- }
1990
- observe.next(events);
1991
- observe.unsubscribe();
1992
- });
1993
- }
1994
- else {
1995
- observe.next(false);
1996
- observe.unsubscribe();
1997
- }
1998
- };
1999
- const error = (err) => {
2000
- observe.next(false);
2001
- observe.unsubscribe();
2002
- };
2003
- this.httpService.post(atr_static_datas.OSS_POLICY, { dir: 'ueditor' }, ToolsUtil.getHttpOptions()).subscribe(success, error);
2004
- });
2005
- };
2006
1962
  this.customReq = (file) => {
2007
1963
  const formData = new FormData();
2008
1964
  for (let key in this.uploadData) {
@@ -3734,18 +3690,16 @@ class QuillEditorComponent {
3734
3690
  if (!blods || blods.length <= 0) {
3735
3691
  return;
3736
3692
  }
3737
- this.uploadOssService.uploadOssFiles(blods.map((v) => v.blob)).subscribe((res) => {
3738
- if (res && res.length > 0) {
3693
+ for (let i = 0; i < blods.length; i++) {
3694
+ let blob = blods[i];
3695
+ this.uploadOssService.uploadOss(blob).subscribe((url) => {
3739
3696
  let delta = this.editor.getContents();
3740
- for (let i = 0; i < res.length; i++) {
3741
- console.log('delta', delta);
3742
- delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
3743
- opt.insert.image = res[i].url;
3744
- });
3745
- }
3697
+ delta.filter((opt) => opt && opt.insert && opt.insert.image == blods[i].oldUrl).forEach((opt, index) => {
3698
+ opt.insert.image = url;
3699
+ });
3746
3700
  this.editor.setContents(delta, 'api');
3747
- }
3748
- });
3701
+ });
3702
+ }
3749
3703
  }
3750
3704
  isEndContents(blods, index) {
3751
3705
  let details = this.editor.getContents();