office-ui-fabric-react
Version:
Reusable React components for building experiences for Microsoft 365.
40 lines • 2.06 kB
JavaScript
import { __assign, __extends } from "tslib";
import * as React from 'react';
import { Icon } from '../../Icon';
import { Image } from '../../Image';
import { classNamesFunction, initializeComponentRef } from '../../Utilities';
var getClassNames = classNamesFunction();
/**
* {@docCategory DocumentCard}
*/
var DocumentCardImageBase = /** @class */ (function (_super) {
__extends(DocumentCardImageBase, _super);
function DocumentCardImageBase(props) {
var _this = _super.call(this, props) || this;
_this._onImageLoad = function () {
_this.setState({ imageHasLoaded: true });
};
initializeComponentRef(_this);
_this.state = { imageHasLoaded: false };
return _this;
}
DocumentCardImageBase.prototype.render = function () {
var _a = this.props, styles = _a.styles, width = _a.width, height = _a.height, imageFit = _a.imageFit, imageSrc = _a.imageSrc;
this._classNames = getClassNames(styles, this.props);
return (React.createElement("div", { className: this._classNames.root },
imageSrc && (React.createElement(Image, { width: width, height: height, imageFit: imageFit, src: imageSrc, role: "presentation", alt: "", onLoad: this._onImageLoad })),
this.state.imageHasLoaded ? this._renderCornerIcon() : this._renderCenterIcon()));
};
DocumentCardImageBase.prototype._renderCenterIcon = function () {
var iconProps = this.props.iconProps;
return (React.createElement("div", { className: this._classNames.centeredIconWrapper },
React.createElement(Icon, __assign({ className: this._classNames.centeredIcon }, iconProps))));
};
DocumentCardImageBase.prototype._renderCornerIcon = function () {
var iconProps = this.props.iconProps;
return React.createElement(Icon, __assign({ className: this._classNames.cornerIcon }, iconProps));
};
return DocumentCardImageBase;
}(React.Component));
export { DocumentCardImageBase };
//# sourceMappingURL=DocumentCardImage.base.js.map