nsc-react-component 2.11.8 → 2.11.9
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.
- package/lib/base/image/index.js +24 -9
- package/package.json +1 -1
package/lib/base/image/index.js
CHANGED
|
@@ -88,29 +88,44 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
88
88
|
_this$props = this.props, fileId = _this$props.fileId, _this$props$newVersio = _this$props.newVersion, newVersion = _this$props$newVersio === void 0 ? true : _this$props$newVersio, _this$props$requestCo = _this$props.requestConfig, requestConfig = _this$props$requestCo === void 0 ? {} : _this$props$requestCo;
|
|
89
89
|
|
|
90
90
|
if (!newVersion) {
|
|
91
|
-
_context.next =
|
|
91
|
+
_context.next = 12;
|
|
92
92
|
break;
|
|
93
93
|
}
|
|
94
94
|
|
|
95
|
-
|
|
95
|
+
if (!fileId) {
|
|
96
|
+
_context.next = 9;
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
_context.next = 5;
|
|
96
101
|
return previewImage(fileId, requestConfig);
|
|
97
102
|
|
|
98
|
-
case
|
|
103
|
+
case 5:
|
|
99
104
|
res2 = _context.sent;
|
|
100
105
|
this.setState({
|
|
101
106
|
imgData: res2.data,
|
|
102
107
|
loading: false
|
|
103
108
|
});
|
|
104
|
-
_context.next =
|
|
109
|
+
_context.next = 10;
|
|
105
110
|
break;
|
|
106
111
|
|
|
107
|
-
case
|
|
108
|
-
|
|
112
|
+
case 9:
|
|
113
|
+
this.setState({
|
|
114
|
+
imgData: this.props.defaultImg || this.defaultImg,
|
|
115
|
+
loading: false
|
|
116
|
+
});
|
|
117
|
+
|
|
118
|
+
case 10:
|
|
119
|
+
_context.next = 16;
|
|
120
|
+
break;
|
|
121
|
+
|
|
122
|
+
case 12:
|
|
123
|
+
_context.next = 14;
|
|
109
124
|
return download(fileId, false, _objectSpread(_objectSpread({}, requestConfig), {}, {
|
|
110
125
|
showErrMsg: false
|
|
111
126
|
}));
|
|
112
127
|
|
|
113
|
-
case
|
|
128
|
+
case 14:
|
|
114
129
|
img = _context.sent;
|
|
115
130
|
|
|
116
131
|
if ((_img$data = img.data) !== null && _img$data !== void 0 && _img$data.data) {
|
|
@@ -126,7 +141,7 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
126
141
|
});
|
|
127
142
|
}
|
|
128
143
|
|
|
129
|
-
case
|
|
144
|
+
case 16:
|
|
130
145
|
case "end":
|
|
131
146
|
return _context.stop();
|
|
132
147
|
}
|
|
@@ -286,4 +301,4 @@ var NscImage = /*#__PURE__*/function (_React$PureComponent) {
|
|
|
286
301
|
}(React.PureComponent);
|
|
287
302
|
|
|
288
303
|
export { NscImage as default };
|
|
289
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/base/image/index.tsx"],"names":["React","file","styles","getLess","EyeOutlined","DownloadOutlined","DeleteOutlined","Spin","download","previewDocument","previewImage","NscImage","props","state","imgData","defaultImg","visible","mask","loading","fileId","newVersion","requestConfig","res2","setState","data","showErrMsg","img","blobToBase64","then","res","blob","Promise","resolve","reject","fileReader","FileReader","onload","e","target","result","readAsDataURL","onerror","Error","prevProps","getImgData","src","clickPreview","showDownloadIcon","preview","showDeleteIcon","onDelete","onPreview","onDownload","params","width","height","display","onVisibleChange","value","PureComponent"],"mappings":"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","sourcesContent":["import * as React from \"react\";\r\nimport { Image, ImageProps } from \"antd\";\r\nimport file from \"nsc-file\";\r\nimport styles from \"./index.less\";\r\nimport { getLess } from \"../../utils\";\r\nimport {\r\n  EyeOutlined,\r\n  DownloadOutlined,\r\n  UploadOutlined,\r\n  DeleteOutlined,\r\n} from \"@ant-design/icons\";\r\nimport cls from \"classnames\";\r\nimport Spin from \"../spin\";\r\n\r\nconst { download, previewDocument, previewImage } = file;\r\ninterface IImageProps extends ImageProps {\r\n  fileId?: string;\r\n  src?: string;\r\n  clickPreview?: boolean;\r\n  showDeleteIcon?: boolean;\r\n  // showUploadIcon?: boolean;\r\n  showDownloadIcon?: boolean;\r\n  preview?: boolean;\r\n  defaultImg?: string;\r\n  onDelete?: any;\r\n  onPreview?: any;\r\n  onDownload?: any;\r\n  newVersion?: boolean;\r\n  requestConfig?: Object;\r\n}\r\n\r\nexport default class NscImage extends React.PureComponent<IImageProps, any> {\r\n  defaultImg =\r\n    \"data:image/png;base64,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\";\r\n\r\n  constructor(props) {\r\n    super(props);\r\n    this.state = {\r\n      imgData: props.defaultImg || this.defaultImg,\r\n      visible: false,\r\n      mask: false,\r\n      loading: true,\r\n    };\r\n  }\r\n  async getImgData() {\r\n    const { fileId, newVersion = true, requestConfig = {} } = this.props;\r\n    if (newVersion) {\r\n      const res2: any = await previewImage(fileId, requestConfig);\r\n      this.setState({\r\n        imgData: res2.data,\r\n        loading: false,\r\n      });\r\n    } else {\r\n      const img = await download(fileId, false, {\r\n        ...requestConfig,\r\n        showErrMsg: false,\r\n      });\r\n      if (img.data?.data) {\r\n        this.blobToBase64(img.data?.data).then((res) => {\r\n          this.setState({\r\n            imgData: res,\r\n            loading: false,\r\n          });\r\n        });\r\n      } else {\r\n        this.setState({\r\n          loading: false,\r\n        });\r\n      }\r\n    }\r\n  }\r\n  blobToBase64(blob) {\r\n    return new Promise((resolve, reject) => {\r\n      const fileReader = new FileReader();\r\n      fileReader.onload = (e) => {\r\n        resolve(e.target.result);\r\n      };\r\n      fileReader.readAsDataURL(blob);\r\n      fileReader.onerror = () => {\r\n        reject(new Error(\"blobToBase64 error\"));\r\n      };\r\n    });\r\n  }\r\n  componentDidUpdate(prevProps) {\r\n    if (prevProps.fileId !== this.props.fileId) {\r\n      if (this.props.fileId) {\r\n        this.setState({\r\n          loading: true,\r\n          imgData: this.defaultImg,\r\n        });\r\n        this.getImgData();\r\n      }\r\n    }\r\n  }\r\n  componentDidMount() {\r\n    const { fileId } = this.props;\r\n    if (fileId) {\r\n      this.getImgData();\r\n    } else {\r\n      this.setState({\r\n        loading: false,\r\n      });\r\n    }\r\n  }\r\n  render(): React.ReactNode {\r\n    const {\r\n      fileId,\r\n      src,\r\n      clickPreview = true,\r\n      showDownloadIcon = false,\r\n      preview = true,\r\n      defaultImg,\r\n      showDeleteIcon = false,\r\n      onDelete,\r\n      onPreview,\r\n      onDownload,\r\n      newVersion,\r\n      requestConfig,\r\n      ...params\r\n    } = this.props;\r\n    return (\r\n      <div\r\n        className={getLess(styles, \"nsc-image-total\")}\r\n        onMouseEnter={() => {\r\n          this.setState({\r\n            mask: true,\r\n          });\r\n        }}\r\n        onMouseLeave={() => {\r\n          this.setState({\r\n            mask: false,\r\n          });\r\n        }}\r\n        onClick={() => {\r\n          clickPreview &&\r\n            preview &&\r\n            this.setState({\r\n              visible: true,\r\n            });\r\n        }}\r\n      >\r\n        <Spin\r\n          spinning={this.state.loading}\r\n          // style={{ width: \"100%\", height: \"100%\" }}\r\n        >\r\n          <img\r\n            src={this.props.src || this.state.imgData}\r\n            style={{ width: \"100%\", height: \"100%\" }}\r\n          />\r\n        </Spin>\r\n        {this.state.mask && preview && !this.state.visible && (\r\n          <div className={getLess(styles, \"nsc-image-mask\")}>\r\n            {/* <div className={getLess(styles, \"nsc-image-icon\")}>\r\n            <UploadOutlined />\r\n          </div> */}\r\n            {showDownloadIcon && (\r\n              <div\r\n                className={getLess(styles, \"nsc-image-icon\")}\r\n                onClick={() => {\r\n                  if (onDownload) {\r\n                    onDownload(fileId);\r\n                    return;\r\n                  }\r\n                  if (fileId)\r\n                    download(fileId, true, {\r\n                      ...requestConfig,\r\n                      showErrMsg: false,\r\n                    });\r\n                }}\r\n              >\r\n                <DownloadOutlined />\r\n              </div>\r\n            )}\r\n            <div\r\n              onClick={() => {\r\n                this.setState({\r\n                  visible: true,\r\n                });\r\n              }}\r\n              className={getLess(styles, \"nsc-image-icon\")}\r\n            >\r\n              <EyeOutlined />\r\n            </div>\r\n            {showDeleteIcon && (\r\n              <div\r\n                className={getLess(styles, \"nsc-image-icon\")}\r\n                onClick={() => {\r\n                  if (onDelete) onDelete(fileId);\r\n                }}\r\n              >\r\n                <DeleteOutlined />\r\n              </div>\r\n            )}\r\n          </div>\r\n        )}\r\n        <div style={{ display: \"none\", height: 0 }}>\r\n          <Image\r\n            src={this.props.src || this.state.imgData}\r\n            style={{ display: \"none\" }}\r\n            preview={{\r\n              visible: this.state.visible,\r\n              src: this.props.src || this.state.imgData,\r\n              onVisibleChange: (value) => {\r\n                this.setState({\r\n                  visible: value,\r\n                });\r\n              },\r\n            }}\r\n            {...params}\r\n          />\r\n        </div>\r\n      </div>\r\n    );\r\n  }\r\n}\r\n"]}
|
|
304
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/base/image/index.tsx"],"names":["React","file","styles","getLess","EyeOutlined","DownloadOutlined","DeleteOutlined","Spin","download","previewDocument","previewImage","NscImage","props","state","imgData","defaultImg","visible","mask","loading","fileId","newVersion","requestConfig","res2","setState","data","showErrMsg","img","blobToBase64","then","res","blob","Promise","resolve","reject","fileReader","FileReader","onload","e","target","result","readAsDataURL","onerror","Error","prevProps","getImgData","src","clickPreview","showDownloadIcon","preview","showDeleteIcon","onDelete","onPreview","onDownload","params","width","height","display","onVisibleChange","value","PureComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,OAAO,KAAKA,KAAZ,MAAuB,OAAvB;AAEA,OAAOC,IAAP,MAAiB,UAAjB;AACA,OAAOC,MAAP,MAAmB,cAAnB;AACA,SAASC,OAAT,QAAwB,aAAxB;AACA,SACEC,WADF,EAEEC,gBAFF,EAIEC,cAJF,QAKO,mBALP;AAOA,OAAOC,IAAP,MAAiB,SAAjB;AAEA,IAAQC,QAAR,GAAoDP,IAApD,CAAQO,QAAR;AAAA,IAAkBC,eAAlB,GAAoDR,IAApD,CAAkBQ,eAAlB;AAAA,IAAmCC,YAAnC,GAAoDT,IAApD,CAAmCS,YAAnC;;IAiBqBC,Q;;;;;AAInB,oBAAYC,KAAZ,EAAmB;AAAA;;AAAA;;AACjB,8BAAMA,KAAN;;AADiB,iEAFjB,gqGAEiB;;AAEjB,UAAKC,KAAL,GAAa;AACXC,MAAAA,OAAO,EAAEF,KAAK,CAACG,UAAN,IAAoB,MAAKA,UADvB;AAEXC,MAAAA,OAAO,EAAE,KAFE;AAGXC,MAAAA,IAAI,EAAE,KAHK;AAIXC,MAAAA,OAAO,EAAE;AAJE,KAAb;AAFiB;AAQlB;;;;;gFACD;AAAA;;AAAA;;AAAA;AAAA;AAAA;AAAA;AAAA,8BAC4D,KAAKN,KADjE,EACUO,MADV,eACUA,MADV,sCACkBC,UADlB,EACkBA,UADlB,sCAC+B,IAD/B,8DACqCC,aADrC,EACqCA,aADrC,sCACqD,EADrD;;AAAA,qBAEMD,UAFN;AAAA;AAAA;AAAA;;AAAA,qBAGQD,MAHR;AAAA;AAAA;AAAA;;AAAA;AAAA,uBAI8BT,YAAY,CAACS,MAAD,EAASE,aAAT,CAJ1C;;AAAA;AAIYC,gBAAAA,IAJZ;AAKM,qBAAKC,QAAL,CAAc;AACZT,kBAAAA,OAAO,EAAEQ,IAAI,CAACE,IADF;AAEZN,kBAAAA,OAAO,EAAE;AAFG,iBAAd;AALN;AAAA;;AAAA;AAUM,qBAAKK,QAAL,CAAc;AACZT,kBAAAA,OAAO,EAAE,KAAKF,KAAL,CAAWG,UAAX,IAAyB,KAAKA,UAD3B;AAEZG,kBAAAA,OAAO,EAAE;AAFG,iBAAd;;AAVN;AAAA;AAAA;;AAAA;AAAA;AAAA,uBAgBsBV,QAAQ,CAACW,MAAD,EAAS,KAAT,kCACrBE,aADqB;AAExBI,kBAAAA,UAAU,EAAE;AAFY,mBAhB9B;;AAAA;AAgBUC,gBAAAA,GAhBV;;AAoBI,iCAAIA,GAAG,CAACF,IAAR,sCAAI,UAAUA,IAAd,EAAoB;AAClB,uBAAKG,YAAL,eAAkBD,GAAG,CAACF,IAAtB,+CAAkB,WAAUA,IAA5B,EAAkCI,IAAlC,CAAuC,UAACC,GAAD,EAAS;AAC9C,oBAAA,MAAI,CAACN,QAAL,CAAc;AACZT,sBAAAA,OAAO,EAAEe,GADG;AAEZX,sBAAAA,OAAO,EAAE;AAFG,qBAAd;AAID,mBALD;AAMD,iBAPD,MAOO;AACL,uBAAKK,QAAL,CAAc;AACZL,oBAAAA,OAAO,EAAE;AADG,mBAAd;AAGD;;AA/BL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,O;;;;;;;;;;WAkCA,sBAAaY,IAAb,EAAmB;AACjB,aAAO,IAAIC,OAAJ,CAAY,UAACC,OAAD,EAAUC,MAAV,EAAqB;AACtC,YAAMC,UAAU,GAAG,IAAIC,UAAJ,EAAnB;;AACAD,QAAAA,UAAU,CAACE,MAAX,GAAoB,UAACC,CAAD,EAAO;AACzBL,UAAAA,OAAO,CAACK,CAAC,CAACC,MAAF,CAASC,MAAV,CAAP;AACD,SAFD;;AAGAL,QAAAA,UAAU,CAACM,aAAX,CAAyBV,IAAzB;;AACAI,QAAAA,UAAU,CAACO,OAAX,GAAqB,YAAM;AACzBR,UAAAA,MAAM,CAAC,IAAIS,KAAJ,CAAU,oBAAV,CAAD,CAAN;AACD,SAFD;AAGD,OATM,CAAP;AAUD;;;WACD,4BAAmBC,SAAnB,EAA8B;AAC5B,UAAIA,SAAS,CAACxB,MAAV,KAAqB,KAAKP,KAAL,CAAWO,MAApC,EAA4C;AAC1C,YAAI,KAAKP,KAAL,CAAWO,MAAf,EAAuB;AACrB,eAAKI,QAAL,CAAc;AACZL,YAAAA,OAAO,EAAE,IADG;AAEZJ,YAAAA,OAAO,EAAE,KAAKC;AAFF,WAAd;AAIA,eAAK6B,UAAL;AACD;AACF;AACF;;;WACD,6BAAoB;AAClB,UAAQzB,MAAR,GAAmB,KAAKP,KAAxB,CAAQO,MAAR;;AACA,UAAIA,MAAJ,EAAY;AACV,aAAKyB,UAAL;AACD,OAFD,MAEO;AACL,aAAKrB,QAAL,CAAc;AACZL,UAAAA,OAAO,EAAE;AADG,SAAd;AAGD;AACF;;;WACD,kBAA0B;AAAA;;AACxB,yBAcI,KAAKN,KAdT;AAAA,UACEO,MADF,gBACEA,MADF;AAAA,UAEE0B,GAFF,gBAEEA,GAFF;AAAA,+CAGEC,YAHF;AAAA,UAGEA,YAHF,sCAGiB,IAHjB;AAAA,+CAIEC,gBAJF;AAAA,UAIEA,gBAJF,sCAIqB,KAJrB;AAAA,8CAKEC,OALF;AAAA,UAKEA,OALF,qCAKY,IALZ;AAAA,UAMEjC,UANF,gBAMEA,UANF;AAAA,+CAOEkC,cAPF;AAAA,UAOEA,cAPF,sCAOmB,KAPnB;AAAA,UAQEC,QARF,gBAQEA,QARF;AAAA,UASEC,SATF,gBASEA,SATF;AAAA,UAUEC,UAVF,gBAUEA,UAVF;AAAA,UAWEhC,UAXF,gBAWEA,UAXF;AAAA,UAYEC,aAZF,gBAYEA,aAZF;AAAA,UAaKgC,MAbL;;AAeA,0BACE;AACE,QAAA,SAAS,EAAElD,OAAO,CAACD,MAAD,EAAS,iBAAT,CADpB;AAEE,QAAA,YAAY,EAAE,wBAAM;AAClB,UAAA,MAAI,CAACqB,QAAL,CAAc;AACZN,YAAAA,IAAI,EAAE;AADM,WAAd;AAGD,SANH;AAOE,QAAA,YAAY,EAAE,wBAAM;AAClB,UAAA,MAAI,CAACM,QAAL,CAAc;AACZN,YAAAA,IAAI,EAAE;AADM,WAAd;AAGD,SAXH;AAYE,QAAA,OAAO,EAAE,mBAAM;AACb6B,UAAAA,YAAY,IACVE,OADF,IAEE,MAAI,CAACzB,QAAL,CAAc;AACZP,YAAAA,OAAO,EAAE;AADG,WAAd,CAFF;AAKD;AAlBH,sBAoBE,oBAAC,IAAD;AACE,QAAA,QAAQ,EAAE,KAAKH,KAAL,CAAWK,OADvB,CAEE;;AAFF,sBAIE;AACE,QAAA,GAAG,EAAE,KAAKN,KAAL,CAAWiC,GAAX,IAAkB,KAAKhC,KAAL,CAAWC,OADpC;AAEE,QAAA,KAAK,EAAE;AAAEwC,UAAAA,KAAK,EAAE,MAAT;AAAiBC,UAAAA,MAAM,EAAE;AAAzB;AAFT,QAJF,CApBF,EA6BG,KAAK1C,KAAL,CAAWI,IAAX,IAAmB+B,OAAnB,IAA8B,CAAC,KAAKnC,KAAL,CAAWG,OAA1C,iBACC;AAAK,QAAA,SAAS,EAAEb,OAAO,CAACD,MAAD,EAAS,gBAAT;AAAvB,SAIG6C,gBAAgB,iBACf;AACE,QAAA,SAAS,EAAE5C,OAAO,CAACD,MAAD,EAAS,gBAAT,CADpB;AAEE,QAAA,OAAO,EAAE,mBAAM;AACb,cAAIkD,UAAJ,EAAgB;AACdA,YAAAA,UAAU,CAACjC,MAAD,CAAV;AACA;AACD;;AACD,cAAIA,MAAJ,EACEX,QAAQ,CAACW,MAAD,EAAS,IAAT,kCACHE,aADG;AAENI,YAAAA,UAAU,EAAE;AAFN,aAAR;AAIH;AAZH,sBAcE,oBAAC,gBAAD,OAdF,CALJ,eAsBE;AACE,QAAA,OAAO,EAAE,mBAAM;AACb,UAAA,MAAI,CAACF,QAAL,CAAc;AACZP,YAAAA,OAAO,EAAE;AADG,WAAd;AAGD,SALH;AAME,QAAA,SAAS,EAAEb,OAAO,CAACD,MAAD,EAAS,gBAAT;AANpB,sBAQE,oBAAC,WAAD,OARF,CAtBF,EAgCG+C,cAAc,iBACb;AACE,QAAA,SAAS,EAAE9C,OAAO,CAACD,MAAD,EAAS,gBAAT,CADpB;AAEE,QAAA,OAAO,EAAE,mBAAM;AACb,cAAIgD,QAAJ,EAAcA,QAAQ,CAAC/B,MAAD,CAAR;AACf;AAJH,sBAME,oBAAC,cAAD,OANF,CAjCJ,CA9BJ,eA0EE;AAAK,QAAA,KAAK,EAAE;AAAEqC,UAAAA,OAAO,EAAE,MAAX;AAAmBD,UAAAA,MAAM,EAAE;AAA3B;AAAZ,sBACE;AACE,QAAA,GAAG,EAAE,KAAK3C,KAAL,CAAWiC,GAAX,IAAkB,KAAKhC,KAAL,CAAWC,OADpC;AAEE,QAAA,KAAK,EAAE;AAAE0C,UAAAA,OAAO,EAAE;AAAX,SAFT;AAGE,QAAA,OAAO,EAAE;AACPxC,UAAAA,OAAO,EAAE,KAAKH,KAAL,CAAWG,OADb;AAEP6B,UAAAA,GAAG,EAAE,KAAKjC,KAAL,CAAWiC,GAAX,IAAkB,KAAKhC,KAAL,CAAWC,OAF3B;AAGP2C,UAAAA,eAAe,EAAE,yBAACC,KAAD,EAAW;AAC1B,YAAA,MAAI,CAACnC,QAAL,CAAc;AACZP,cAAAA,OAAO,EAAE0C;AADG,aAAd;AAGD;AAPM;AAHX,SAYML,MAZN,EADF,CA1EF,CADF;AA6FD;;;;EA7LmCrD,KAAK,CAAC2D,a;;SAAvBhD,Q","sourcesContent":["import * as React from \"react\";\r\nimport { Image, ImageProps } from \"antd\";\r\nimport file from \"nsc-file\";\r\nimport styles from \"./index.less\";\r\nimport { getLess } from \"../../utils\";\r\nimport {\r\n  EyeOutlined,\r\n  DownloadOutlined,\r\n  UploadOutlined,\r\n  DeleteOutlined,\r\n} from \"@ant-design/icons\";\r\nimport cls from \"classnames\";\r\nimport Spin from \"../spin\";\r\n\r\nconst { download, previewDocument, previewImage } = file;\r\ninterface IImageProps extends ImageProps {\r\n  fileId?: string;\r\n  src?: string;\r\n  clickPreview?: boolean;\r\n  showDeleteIcon?: boolean;\r\n  // showUploadIcon?: boolean;\r\n  showDownloadIcon?: boolean;\r\n  preview?: boolean;\r\n  defaultImg?: string;\r\n  onDelete?: any;\r\n  onPreview?: any;\r\n  onDownload?: any;\r\n  newVersion?: boolean;\r\n  requestConfig?: Object;\r\n}\r\n\r\nexport default class NscImage extends React.PureComponent<IImageProps, any> {\r\n  defaultImg =\r\n    \"data:image/png;base64,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\";\r\n\r\n  constructor(props) {\r\n    super(props);\r\n    this.state = {\r\n      imgData: props.defaultImg || this.defaultImg,\r\n      visible: false,\r\n      mask: false,\r\n      loading: true,\r\n    };\r\n  }\r\n  async getImgData() {\r\n    const { fileId, newVersion = true, requestConfig = {} } = this.props;\r\n    if (newVersion) {\r\n      if (fileId) {\r\n        const res2: any = await previewImage(fileId, requestConfig);\r\n        this.setState({\r\n          imgData: res2.data,\r\n          loading: false,\r\n        });\r\n      } else {\r\n        this.setState({\r\n          imgData: this.props.defaultImg || this.defaultImg,\r\n          loading: false,\r\n        });\r\n      }\r\n    } else {\r\n      const img = await download(fileId, false, {\r\n        ...requestConfig,\r\n        showErrMsg: false,\r\n      });\r\n      if (img.data?.data) {\r\n        this.blobToBase64(img.data?.data).then((res) => {\r\n          this.setState({\r\n            imgData: res,\r\n            loading: false,\r\n          });\r\n        });\r\n      } else {\r\n        this.setState({\r\n          loading: false,\r\n        });\r\n      }\r\n    }\r\n  }\r\n  blobToBase64(blob) {\r\n    return new Promise((resolve, reject) => {\r\n      const fileReader = new FileReader();\r\n      fileReader.onload = (e) => {\r\n        resolve(e.target.result);\r\n      };\r\n      fileReader.readAsDataURL(blob);\r\n      fileReader.onerror = () => {\r\n        reject(new Error(\"blobToBase64 error\"));\r\n      };\r\n    });\r\n  }\r\n  componentDidUpdate(prevProps) {\r\n    if (prevProps.fileId !== this.props.fileId) {\r\n      if (this.props.fileId) {\r\n        this.setState({\r\n          loading: true,\r\n          imgData: this.defaultImg,\r\n        });\r\n        this.getImgData();\r\n      }\r\n    }\r\n  }\r\n  componentDidMount() {\r\n    const { fileId } = this.props;\r\n    if (fileId) {\r\n      this.getImgData();\r\n    } else {\r\n      this.setState({\r\n        loading: false,\r\n      });\r\n    }\r\n  }\r\n  render(): React.ReactNode {\r\n    const {\r\n      fileId,\r\n      src,\r\n      clickPreview = true,\r\n      showDownloadIcon = false,\r\n      preview = true,\r\n      defaultImg,\r\n      showDeleteIcon = false,\r\n      onDelete,\r\n      onPreview,\r\n      onDownload,\r\n      newVersion,\r\n      requestConfig,\r\n      ...params\r\n    } = this.props;\r\n    return (\r\n      <div\r\n        className={getLess(styles, \"nsc-image-total\")}\r\n        onMouseEnter={() => {\r\n          this.setState({\r\n            mask: true,\r\n          });\r\n        }}\r\n        onMouseLeave={() => {\r\n          this.setState({\r\n            mask: false,\r\n          });\r\n        }}\r\n        onClick={() => {\r\n          clickPreview &&\r\n            preview &&\r\n            this.setState({\r\n              visible: true,\r\n            });\r\n        }}\r\n      >\r\n        <Spin\r\n          spinning={this.state.loading}\r\n          // style={{ width: \"100%\", height: \"100%\" }}\r\n        >\r\n          <img\r\n            src={this.props.src || this.state.imgData}\r\n            style={{ width: \"100%\", height: \"100%\" }}\r\n          />\r\n        </Spin>\r\n        {this.state.mask && preview && !this.state.visible && (\r\n          <div className={getLess(styles, \"nsc-image-mask\")}>\r\n            {/* <div className={getLess(styles, \"nsc-image-icon\")}>\r\n            <UploadOutlined />\r\n          </div> */}\r\n            {showDownloadIcon && (\r\n              <div\r\n                className={getLess(styles, \"nsc-image-icon\")}\r\n                onClick={() => {\r\n                  if (onDownload) {\r\n                    onDownload(fileId);\r\n                    return;\r\n                  }\r\n                  if (fileId)\r\n                    download(fileId, true, {\r\n                      ...requestConfig,\r\n                      showErrMsg: false,\r\n                    });\r\n                }}\r\n              >\r\n                <DownloadOutlined />\r\n              </div>\r\n            )}\r\n            <div\r\n              onClick={() => {\r\n                this.setState({\r\n                  visible: true,\r\n                });\r\n              }}\r\n              className={getLess(styles, \"nsc-image-icon\")}\r\n            >\r\n              <EyeOutlined />\r\n            </div>\r\n            {showDeleteIcon && (\r\n              <div\r\n                className={getLess(styles, \"nsc-image-icon\")}\r\n                onClick={() => {\r\n                  if (onDelete) onDelete(fileId);\r\n                }}\r\n              >\r\n                <DeleteOutlined />\r\n              </div>\r\n            )}\r\n          </div>\r\n        )}\r\n        <div style={{ display: \"none\", height: 0 }}>\r\n          <Image\r\n            src={this.props.src || this.state.imgData}\r\n            style={{ display: \"none\" }}\r\n            preview={{\r\n              visible: this.state.visible,\r\n              src: this.props.src || this.state.imgData,\r\n              onVisibleChange: (value) => {\r\n                this.setState({\r\n                  visible: value,\r\n                });\r\n              },\r\n            }}\r\n            {...params}\r\n          />\r\n        </div>\r\n      </div>\r\n    );\r\n  }\r\n}\r\n"]}
|