office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
38 lines • 2.66 kB
JavaScript
define(["require", "exports", "tslib", "react", "../../Utilities", "./Spinner.Props", "./Spinner.scss"], function (require, exports, tslib_1, React, Utilities_1, Spinner_Props_1, stylesImport) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
var styles = stylesImport;
var Spinner = (function (_super) {
tslib_1.__extends(Spinner, _super);
function Spinner() {
return _super !== null && _super.apply(this, arguments) || this;
}
Spinner.prototype.render = function () {
var _a = this.props, type = _a.type, size = _a.size, label = _a.label, className = _a.className, ariaLive = _a.ariaLive, ariaLabel = _a.ariaLabel; // TODO remove deprecated type property at >= 2.0.0
var statusMessage = ariaLabel || label;
return (React.createElement("div", { className: Utilities_1.css('ms-Spinner', styles.root, className) },
React.createElement("div", { className: Utilities_1.css('ms-Spinner-circle', styles.circle, (_b = {},
_b['ms-Spinner--xSmall ' + styles.circleIsXSmall] = size === Spinner_Props_1.SpinnerSize.xSmall,
_b['ms-Spinner--small ' + styles.circleIsSmall] = size === Spinner_Props_1.SpinnerSize.small,
_b['ms-Spinner--medium ' + styles.circleIsMedium] = size === Spinner_Props_1.SpinnerSize.medium,
_b['ms-Spinner--large ' + styles.circleIsLarge] = size === Spinner_Props_1.SpinnerSize.large,
_b['ms-Spinner--normal ' + styles.circleIsTypeMedium] = type === Spinner_Props_1.SpinnerType.normal,
_b['ms-Spinner--large ' + styles.circleIsTypeLarge] = type === Spinner_Props_1.SpinnerType.large // TODO remove deprecated value at >= 2.0.0
,
_b)) }),
label && React.createElement("div", { className: Utilities_1.css('ms-Spinner-label', styles.label) }, label),
statusMessage &&
React.createElement("div", { role: 'status', "aria-live": this.props.ariaLive },
React.createElement(Utilities_1.DelayedRender, null,
React.createElement("div", { className: styles.screenReaderOnly }, statusMessage)))));
var _b;
};
Spinner.defaultProps = {
size: Spinner_Props_1.SpinnerSize.medium,
ariaLive: 'polite'
};
return Spinner;
}(Utilities_1.BaseComponent));
exports.Spinner = Spinner;
});
//# sourceMappingURL=Spinner.js.map