office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
55 lines (54 loc) • 2.54 kB
JavaScript
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
define(["require", "exports", 'react', '../../../../index', '../../../../utilities/Async/Async'], function (require, exports, React, index_1, Async_1) {
"use strict";
var INTERVAL_DELAY = 100;
var INTERVAL_INCREMENT = .01;
var RESTART_WAIT_TIME = 2000;
var ProgressIndicatorBasicExample = (function (_super) {
__extends(ProgressIndicatorBasicExample, _super);
function ProgressIndicatorBasicExample() {
_super.call(this);
this._async = new Async_1.Async(this);
this.state = {
percentComplete: 0
};
this._startProgressDemo = this._startProgressDemo.bind(this);
}
ProgressIndicatorBasicExample.prototype.componentDidMount = function () {
this._startProgressDemo();
};
ProgressIndicatorBasicExample.prototype.componentWillUnmount = function () {
this._async.dispose();
};
ProgressIndicatorBasicExample.prototype.render = function () {
var percentComplete = this.state.percentComplete;
return (React.createElement(index_1.ProgressIndicator, {label: 'Example title', description: 'Example description', percentComplete: percentComplete}));
};
ProgressIndicatorBasicExample.prototype._startProgressDemo = function () {
var _this = this;
// reset the demo
this.setState({
percentComplete: 0
});
// update progress
this._interval = this._async.setInterval(function () {
var percentComplete = _this.state.percentComplete + INTERVAL_INCREMENT;
// once complete, set the demo to start again
if (percentComplete >= 1.0) {
percentComplete = 1.0;
_this._async.clearInterval(_this._interval);
_this._async.setTimeout(_this._startProgressDemo, RESTART_WAIT_TIME);
}
_this.setState({
percentComplete: percentComplete
});
}, INTERVAL_DELAY);
};
return ProgressIndicatorBasicExample;
}(React.Component));
exports.ProgressIndicatorBasicExample = ProgressIndicatorBasicExample;
});