UNPKG

@raona/components

Version:

React components used at Raona to work with SPFx

65 lines (64 loc) 3.22 kB
"use strict"; 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;