office-ui-fabric-react
Version:
Reusable React components for building experiences for Office 365.
47 lines • 2.45 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
var tslib_1 = require("tslib");
var React = require("react");
var Button_1 = require("office-ui-fabric-react/lib/Button");
var Panel_1 = require("office-ui-fabric-react/lib/Panel");
var Toggle_1 = require("office-ui-fabric-react/lib/Toggle");
var PanelPreventDefaultExample = /** @class */ (function (_super) {
tslib_1.__extends(PanelPreventDefaultExample, _super);
function PanelPreventDefaultExample(props) {
var _this = _super.call(this, props) || this;
_this.onKeyDown = function (ev) {
if (ev.keyCode === 27 /* escape */) {
ev.preventDefault();
ev.stopPropagation();
}
};
_this.toggleAllowEsc = function () {
_this.setState({ allowEsc: !_this.state.allowEsc });
};
_this.onDismiss = function (ev) {
if (ev && ev.keyCode === 27 /* escape */ && !_this.state.allowEsc) {
ev.preventDefault();
return;
}
_this.setState({ showPanel: false });
};
_this.state = { showPanel: false, allowEsc: true };
return _this;
}
PanelPreventDefaultExample.prototype.render = function () {
var _this = this;
return (React.createElement("div", null,
React.createElement(Button_1.DefaultButton, { secondaryText: "Opens the Sample Panel",
// tslint:disable-next-line:jsx-no-lambda
onClick: function () { return _this.setState({ showPanel: true }); }, text: "Open Panel" }),
React.createElement(Panel_1.Panel, { isOpen: this.state.showPanel, type: Panel_1.PanelType.smallFixedNear,
// tslint:disable-next-line:jsx-no-lambda
onDismiss: this.onDismiss, headerText: "Panel" },
React.createElement("div", null, "Hitting escape inside the text area will not close the Panel"),
React.createElement("textarea", { onKeyDown: this.onKeyDown }),
React.createElement(Toggle_1.Toggle, { checked: this.state.allowEsc, onChange: this.toggleAllowEsc, label: "Allow ESC key to close panel" }))));
};
return PanelPreventDefaultExample;
}(React.Component));
exports.PanelPreventDefaultExample = PanelPreventDefaultExample;
//# sourceMappingURL=Panel.PreventDefault.Example.js.map
;