@raona/components
Version:
React components used at Raona to work with SPFx
65 lines (64 loc) • 3.22 kB
JavaScript
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
Object.defineProperty(exports, "__esModule", { value: true });
var React = require("react");
var react_1 = require("react");
var Bind_1 = require("@raona/sp/dist/decorators/Bind");
var TextField_1 = require("office-ui-fabric-react/lib/components/TextField/TextField");
var DelayedInput = /** @class */ (function (_super) {
__extends(DelayedInput, _super);
function DelayedInput() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.timeoutId = null;
return _this;
}
DelayedInput.prototype.onInputChange = function (event) {
var _a = this.props, delayms = _a.delayms, delayedOnChange = _a.delayedOnChange, clearOnChange = _a.clearOnChange;
var val = '';
if (this.timeoutId) {
clearTimeout(this.timeoutId);
this.timeoutId = null;
if (clearOnChange)
clearOnChange();
}
if (typeof event !== 'string') {
val = event.currentTarget.value;
}
else {
val = event;
}
this.timeoutId = setTimeout(function () {
if (delayedOnChange)
delayedOnChange(val);
}, delayms);
};
DelayedInput.prototype.render = function () {
var _a = this.props, label = _a.label, placeholder = _a.placeholder, className = _a.className, defaultValue = _a.defaultValue, useFabric = _a.useFabric;
return (useFabric === false
? React.createElement("input", { className: className, onChange: this.onInputChange, placeholder: placeholder, defaultValue: defaultValue })
: React.createElement(TextField_1.TextField, { className: className, onChanged: this.onInputChange, label: label, placeholder: placeholder, defaultValue: defaultValue }));
};
__decorate([
Bind_1.Bind()
], DelayedInput.prototype, "onInputChange", null);
return DelayedInput;
}(react_1.Component));
exports.DelayedInput = DelayedInput;
;