boundless-dialog
Advanced tools
Comparing version 1.0.0-beta.6 to 1.0.0-beta.7
@@ -1,2 +0,2 @@ | ||
module.exports=function(e){function o(t){if(r[t])return r[t].exports;var n=r[t]={i:t,l:!1,exports:{}};return e[t].call(n.exports,n,n.exports,o),n.l=!0,n.exports}var r={};return o.m=e,o.c=r,o.i=function(e){return e},o.d=function(e,r,t){o.o(e,r)||Object.defineProperty(e,r,{configurable:!1,enumerable:!0,get:t})},o.n=function(e){var r=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(r,"a",r),r},o.o=function(e,o){return Object.prototype.hasOwnProperty.call(e,o)},o.p="",o(o.s=5)}([function(e,o,r){"use strict";function t(e){var o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[];return Object.keys(e).reduce(function(r,t){return o.indexOf(t)===-1&&(r[t]=e[t]),r},{})}o.a=t},function(e,o,r){"use strict";function t(){return"b-"+([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,function(e){return(e^16*Math.random()>>e/4).toString(16)})}o.a=t},function(e,o){e.exports=require("boundless-portal")},function(e,o){e.exports=require("classnames")},function(e,o){e.exports=require("react")},function(e,o,r){"use strict";function t(e,o){if(!(e instanceof o))throw new TypeError("Cannot call a class as a function")}function n(e,o){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!o||"object"!=typeof o&&"function"!=typeof o?e:o}function s(e,o){if("function"!=typeof o&&null!==o)throw new TypeError("Super expression must either be null or a function, not "+typeof o);e.prototype=Object.create(o&&o.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),o&&(Object.setPrototypeOf?Object.setPrototypeOf(e,o):e.__proto__=o)}Object.defineProperty(o,"__esModule",{value:!0});var i=r(4),l=r.n(i),a=r(3),p=r.n(a),u=r(2),c=r.n(u),d=r(0),f=r(1),h=Object.assign||function(e){for(var o=1;o<arguments.length;o++){var r=arguments[o];for(var t in r)Object.prototype.hasOwnProperty.call(r,t)&&(e[t]=r[t])}return e},y=function(){function e(e,o){for(var r=0;r<o.length;r++){var t=o[r];t.enumerable=t.enumerable||!1,t.configurable=!0,"value"in t&&(t.writable=!0),Object.defineProperty(e,t.key,t)}}return function(o,r,t){return r&&e(o.prototype,r),t&&e(o,t),o}}(),O=function(e){return"function"==typeof e},P=function(){},b=Array.prototype.slice,w=function(e){function o(){var e,s,i,l;t(this,o);for(var a=arguments.length,p=Array(a),u=0;u<a;u++)p[u]=arguments[u];return s=i=n(this,(e=o.__proto__||Object.getPrototypeOf(o)).call.apply(e,[this].concat(p))),i.mounted=!1,i.uuidHeader=r.i(f.a)(),i.uuidBody=r.i(f.a)(),i.handleFocus=function(e){if(i.props.captureFocus){var o=e.explicitOriginalTarget||e.relatedTarget;i.isPartOfDialog(o)&&!i.isPartOfDialog(e.target)&&(e.preventDefault(),o.focus())}else if(i.shouldDialogCloseOnEvent("closeOnOutsideFocus",e)&&!i.isPartOfDialog(e.target))return window.setTimeout(i.props.onClose,0)},i.handleKeyDown=function(e){"Escape"===e.key&&i.shouldDialogCloseOnEvent("closeOnEscKey",e)&&window.setTimeout(i.props.onClose,0),i.props.onKeyDown&&i.props.onKeyDown(e)},i.handleInsideClick=function(e){i.shouldDialogCloseOnEvent("closeOnInsideClick",e)&&window.setTimeout(i.props.onClose,0)},i.handleOutsideClick=function(e){i.shouldDialogCloseOnEvent("closeOnOutsideClick",e)&&!i.isPartOfDialog(e.target)&&window.setTimeout(i.props.onClose,0)},i.handleOutsideScrollWheel=function(e){i.shouldDialogCloseOnEvent("closeOnOutsideScroll",e)&&!i.isPartOfDialog(e.target)&&window.setTimeout(i.props.onClose,0)},l=s,n(i,l)}return s(o,e),y(o,[{key:"isPartOfDialog",value:function(e){if(!e||e===window)return!1;var o=[this.$wrapper].concat(b.call(this.$wrapper.querySelectorAll("["+c.a.PORTAL_DATA_ATTRIBUTE+"]")).map(function(e){return document.getElementById(e.getAttribute(c.a.PORTAL_DATA_ATTRIBUTE))})),r=e.nodeType!==Node.ELEMENT_NODE?e.parentNode:e;return o.some(function(e){return e.contains(r)})}},{key:"componentDidMount",value:function(){window.addEventListener("click",this.handleOutsideClick,!0),window.addEventListener("contextmenu",this.handleOutsideClick,!0),window.addEventListener("focus",this.handleFocus,!0),window.addEventListener("scroll",this.handleOutsideScrollWheel,!0),window.addEventListener("wheel",this.handleOutsideScrollWheel,!0),this.props.captureFocus&&!this.isPartOfDialog(document.activeElement)&&this.$dialog.focus()}},{key:"componentWillUnmount",value:function(){window.removeEventListener("click",this.handleOutsideClick,!0),window.removeEventListener("contextmenu",this.handleOutsideClick,!0),window.removeEventListener("focus",this.handleFocus,!0),window.removeEventListener("scroll",this.handleOutsideScrollWheel,!0),window.removeEventListener("wheel",this.handleOutsideScrollWheel,!0)}},{key:"shouldDialogCloseOnEvent",value:function(e,o){return O(this.props[e])?this.props[e](o):this.props[e]}},{key:"renderBody",value:function(){return l.a.createElement("div",h({},this.props.bodyProps,{id:this.props.bodyProps.id||this.uuidBody,className:p()("b-dialog-body",this.props.bodyProps.className)}),this.props.children)}},{key:"renderFooter",value:function(){if(this.props.footer)return l.a.createElement("footer",h({},this.props.footerProps,{className:p()("b-dialog-footer",this.props.footerProps.className)}),this.props.footer)}},{key:"renderHeader",value:function(){if(this.props.header)return l.a.createElement("header",h({},this.props.headerProps,{id:this.props.headerProps.id||this.uuidHeader,className:p()("b-dialog-header",this.props.headerProps.className)}),this.props.header)}},{key:"renderFocusBoundary",value:function(){if(this.props.captureFocus)return l.a.createElement("div",{className:"b-offscreen",tabIndex:"0","aria-hidden":"true"}," ")}},{key:"render",value:function(){var e=this;return l.a.createElement("div",h({},this.props.wrapperProps,{ref:function(o){return e.$wrapper=o},className:p()("b-dialog-wrapper",this.props.wrapperProps.className),tabIndex:"0"}),this.renderFocusBoundary(),this.props.before,l.a.createElement("div",h({},r.i(d.a)(this.props,o.internalKeys),{ref:function(o){return e.$dialog=o},className:p()("b-dialog",this.props.className),onClick:this.handleInsideClick,onKeyDown:this.handleKeyDown,role:"dialog","aria-labelledby":this.uuidHeader,"aria-describedby":this.uuidBody,tabIndex:"0"}),this.renderHeader(),this.renderBody(),this.renderFooter()),this.props.after,this.renderFocusBoundary())}}]),o}(l.a.PureComponent);w.propTypes={after:i.PropTypes.node,before:i.PropTypes.node,bodyProps:i.PropTypes.object,captureFocus:i.PropTypes.bool,children:i.PropTypes.node,closeOnEscKey:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnInsideClick:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideClick:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideFocus:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideScroll:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),footer:i.PropTypes.node,footerProps:i.PropTypes.object,header:i.PropTypes.node,headerProps:i.PropTypes.object,onClose:i.PropTypes.func,wrapperProps:i.PropTypes.object},w.defaultProps={after:null,before:null,bodyProps:{},captureFocus:!0,children:null,closeOnEscKey:!1,closeOnInsideClick:!1,closeOnOutsideClick:!1,closeOnOutsideFocus:!1,closeOnOutsideScroll:!1,footer:null,footerProps:{},header:null,headerProps:{},onClose:P,onKeyDown:P,wrapperProps:{}},w.internalKeys=Object.keys(w.defaultProps),o.default=w}]); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap 8ffa25c61600e8bbf944","webpack:///./packages/boundless-utils-omit-keys/index.js","webpack:///./packages/boundless-utils-uuid/index.js","webpack:///external {\"commonjs2\":\"boundless-portal\"}","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///external {\"commonjs2\":\"react\"}","webpack:///./packages/boundless-dialog/index.js"],"names":["module","exports","modules","__webpack_require__","moduleId","installedModules","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","__webpack_exports__","omitKeysFromSourceObject","source","omittedKeys","arguments","length","undefined","keys","reduce","hash","key","indexOf","uuid","replace","a","Math","random","toString","require","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","create","constructor","writable","setPrototypeOf","__proto__","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1_classnames__","__WEBPACK_IMPORTED_MODULE_1_classnames___default","__WEBPACK_IMPORTED_MODULE_2_boundless_portal__","__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default","__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__","__WEBPACK_IMPORTED_MODULE_4_boundless_utils_uuid__","_extends","assign","target","_createClass","defineProperties","props","descriptor","protoProps","staticProps","isFunction","x","noop","toArray","Array","slice","Dialog","_React$PureComponent","_ref","_temp","_this","_ret","this","_len","args","_key","getPrototypeOf","apply","concat","mounted","uuidHeader","uuidBody","handleFocus","nativeEvent","captureFocus","previous","explicitOriginalTarget","relatedTarget","isPartOfDialog","preventDefault","focus","shouldDialogCloseOnEvent","window","setTimeout","onClose","handleKeyDown","event","onKeyDown","handleInsideClick","handleOutsideClick","handleOutsideScrollWheel","node","roots","$wrapper","querySelectorAll","PORTAL_DATA_ATTRIBUTE","map","dom","document","getElementById","getAttribute","element","nodeType","Node","ELEMENT_NODE","parentNode","some","contains","addEventListener","activeElement","$dialog","removeEventListener","prop","createElement","bodyProps","id","className","children","footer","footerProps","header","headerProps","tabIndex","aria-hidden","_this2","wrapperProps","ref","renderFocusBoundary","before","internalKeys","onClick","role","aria-labelledby","aria-describedby","renderHeader","renderBody","renderFooter","after","PureComponent","propTypes","bool","closeOnEscKey","oneOfType","func","closeOnInsideClick","closeOnOutsideClick","closeOnOutsideFocus","closeOnOutsideScroll","defaultProps"],"mappings":"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","file":"index.js","sourcesContent":["module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 5);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = omitKeysFromSourceObject;\nfunction omitKeysFromSourceObject(source){var omittedKeys=arguments.length>1&&arguments[1]!==undefined?arguments[1]:[];return Object.keys(source).reduce(function relocateAcceptedKeys(hash,key){if(omittedKeys.indexOf(key)===-1){hash[key]=source[key];}return hash;},{});}\n\n/***/ }),\n/* 1 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n/* harmony export (immutable) */ __webpack_exports__[\"a\"] = uuid;\nfunction uuid(){return'b-'+([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,function(a){return(a^Math.random()*16>>a/4).toString(16);});}\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"boundless-portal\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 4 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 5 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(4);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_portal__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_portal___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_boundless_portal__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4_boundless_utils_uuid__ = __webpack_require__(1);\nvar _extends=Object.assign||function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if(\"value\"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor);}}return function(Constructor,protoProps,staticProps){if(protoProps)defineProperties(Constructor.prototype,protoProps);if(staticProps)defineProperties(Constructor,staticProps);return Constructor;};}();function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError(\"Cannot call a class as a function\");}}function _possibleConstructorReturn(self,call){if(!self){throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");}return call&&(typeof call===\"object\"||typeof call===\"function\")?call:self;}function _inherits(subClass,superClass){if(typeof superClass!==\"function\"&&superClass!==null){throw new TypeError(\"Super expression must either be null or a function, not \"+typeof superClass);}subClass.prototype=Object.create(superClass&&superClass.prototype,{constructor:{value:subClass,enumerable:false,writable:true,configurable:true}});if(superClass)Object.setPrototypeOf?Object.setPrototypeOf(subClass,superClass):subClass.__proto__=superClass;}var isFunction=function isFunction(x){return typeof x==='function';};var noop=function noop(){};var toArray=Array.prototype.slice;var Dialog=function(_React$PureComponent){_inherits(Dialog,_React$PureComponent);function Dialog(){var _ref;var _temp,_this,_ret;_classCallCheck(this,Dialog);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=_possibleConstructorReturn(this,(_ref=Dialog.__proto__||Object.getPrototypeOf(Dialog)).call.apply(_ref,[this].concat(args))),_this),_this.mounted=false,_this.uuidHeader=__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4_boundless_utils_uuid__[\"a\" /* default */])(),_this.uuidBody=__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4_boundless_utils_uuid__[\"a\" /* default */])(),_this.handleFocus=function(nativeEvent){if(!_this.props.captureFocus){if(_this.shouldDialogCloseOnEvent('closeOnOutsideFocus',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){return window.setTimeout(_this.props.onClose,0);}return;}var previous=nativeEvent.explicitOriginalTarget||nativeEvent.relatedTarget;if(_this.isPartOfDialog(previous)&&!_this.isPartOfDialog(nativeEvent.target)){nativeEvent.preventDefault();previous.focus();}},_this.handleKeyDown=function(event){if(event.key==='Escape'){if(_this.shouldDialogCloseOnEvent('closeOnEscKey',event)){window.setTimeout(_this.props.onClose,0);}}if(_this.props.onKeyDown){_this.props.onKeyDown(event);}},_this.handleInsideClick=function(event){if(_this.shouldDialogCloseOnEvent('closeOnInsideClick',event)){window.setTimeout(_this.props.onClose,0);}},_this.handleOutsideClick=function(nativeEvent){if(_this.shouldDialogCloseOnEvent('closeOnOutsideClick',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){window.setTimeout(_this.props.onClose,0);}},_this.handleOutsideScrollWheel=function(nativeEvent){if(_this.shouldDialogCloseOnEvent('closeOnOutsideScroll',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){window.setTimeout(_this.props.onClose,0);}},_temp),_possibleConstructorReturn(_this,_ret);}_createClass(Dialog,[{key:'isPartOfDialog',value:function isPartOfDialog(node){if(!node||node===window){return false;}var roots=[this.$wrapper].concat(toArray.call(this.$wrapper.querySelectorAll('['+__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default.a.PORTAL_DATA_ATTRIBUTE+']')).map(function(dom){return document.getElementById(dom.getAttribute(__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default.a.PORTAL_DATA_ATTRIBUTE));}));var element=node.nodeType!==Node.ELEMENT_NODE?node.parentNode:node;return roots.some(function(dom){return dom.contains(element);});}},{key:'componentDidMount',value:function componentDidMount(){window.addEventListener('click',this.handleOutsideClick,true);window.addEventListener('contextmenu',this.handleOutsideClick,true);window.addEventListener('focus',this.handleFocus,true);window.addEventListener('scroll',this.handleOutsideScrollWheel,true);window.addEventListener('wheel',this.handleOutsideScrollWheel,true);if(this.props.captureFocus&&!this.isPartOfDialog(document.activeElement)){this.$dialog.focus();}}},{key:'componentWillUnmount',value:function componentWillUnmount(){window.removeEventListener('click',this.handleOutsideClick,true);window.removeEventListener('contextmenu',this.handleOutsideClick,true);window.removeEventListener('focus',this.handleFocus,true);window.removeEventListener('scroll',this.handleOutsideScrollWheel,true);window.removeEventListener('wheel',this.handleOutsideScrollWheel,true);}},{key:'shouldDialogCloseOnEvent',value:function shouldDialogCloseOnEvent(prop,event){return isFunction(this.props[prop])?this.props[prop](event):this.props[prop];}},{key:'renderBody',value:function renderBody(){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},this.props.bodyProps,{id:this.props.bodyProps.id||this.uuidBody,className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog-body',this.props.bodyProps.className)}),this.props.children);}},{key:'renderFooter',value:function renderFooter(){if(this.props.footer){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('footer',_extends({},this.props.footerProps,{className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog-footer',this.props.footerProps.className)}),this.props.footer);}}},{key:'renderHeader',value:function renderHeader(){if(this.props.header){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('header',_extends({},this.props.headerProps,{id:this.props.headerProps.id||this.uuidHeader,className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog-header',this.props.headerProps.className)}),this.props.header);}}},{key:'renderFocusBoundary',value:function renderFocusBoundary(){if(this.props.captureFocus){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',{className:'b-offscreen',tabIndex:'0','aria-hidden':'true'},'\\xA0');}}},{key:'render',value:function render(){var _this2=this;return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},this.props.wrapperProps,{ref:function ref(node){return _this2.$wrapper=node;},className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog-wrapper',this.props.wrapperProps.className),tabIndex:'0'}),this.renderFocusBoundary(),this.props.before,__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',_extends({},__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__[\"a\" /* default */])(this.props,Dialog.internalKeys),{ref:function ref(node){return _this2.$dialog=node;},className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog',this.props.className),onClick:this.handleInsideClick,onKeyDown:this.handleKeyDown,role:'dialog','aria-labelledby':this.uuidHeader,'aria-describedby':this.uuidBody,tabIndex:'0'}),this.renderHeader(),this.renderBody(),this.renderFooter()),this.props.after,this.renderFocusBoundary());}}]);return Dialog;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Dialog.propTypes={after:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,before:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,bodyProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object,captureFocus:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,children:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,closeOnEscKey:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnInsideClick:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideClick:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideFocus:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideScroll:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),footer:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,footerProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object,header:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,headerProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object,onClose:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func,wrapperProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].object};Dialog.defaultProps={after:null,before:null,bodyProps:{},captureFocus:true,children:null,closeOnEscKey:false,closeOnInsideClick:false,closeOnOutsideClick:false,closeOnOutsideFocus:false,closeOnOutsideScroll:false,footer:null,footerProps:{},header:null,headerProps:{},onClose:noop,onKeyDown:noop,wrapperProps:{}};Dialog.internalKeys=Object.keys(Dialog.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Dialog;\n\n/***/ })\n/******/ ]);\n\n\n// WEBPACK FOOTER //\n// index.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 5);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 8ffa25c61600e8bbf944","/**\n * Returns a modified version of the supplied object without the given keys.\n */\nexport default function omitKeysFromSourceObject(source, omittedKeys = []) {\n    return Object.keys(source).reduce(function relocateAcceptedKeys(hash, key) {\n        if (omittedKeys.indexOf(key) === -1) {\n            hash[key] = source[key];\n        }\n\n        return hash;\n    }, {});\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-omit-keys/index.js","/**\n * Generates a unique ID. Adds a prefix so it is suitable for use as an HTML ID.\n * Based on {@link https://gist.github.com/jed/982883 this implementation}.\n *\n * @return {string} a unique identifier\n *\n * @example\n * uuid(); // b-1f2cd27f-0754-4344-9d20-436a201b2f80\n */\nexport default function uuid() {\n    /* eslint-disable */\n    return 'b-' + ([1e7]+-1e3+-4e3+-8e3+-1e11).replace(/[018]/g,a=>(a^Math.random()*16>>a/4).toString(16));\n    /* eslint-enable */\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-utils-uuid/index.js","module.exports = require(\"boundless-portal\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"boundless-portal\"}\n// module id = 2\n// module chunks = 0","module.exports = require(\"classnames\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"classnames\"}\n// module id = 3\n// module chunks = 0","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"react\"}\n// module id = 4\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport Portal from 'boundless-portal';\nimport omit from 'boundless-utils-omit-keys';\nimport uuid from 'boundless-utils-uuid';\n\nconst isFunction = (x) => typeof x === 'function';\nconst noop = () => {};\nconst toArray = Array.prototype.slice;\n\n/**\n# Dialog\n__A non-blocking, focus-stealing container.__\n\nA dialog differs from a modal in that it does not come with a masking layer (to obscure the rest of the page)\nand the user can choose to shift focus away from the dialog contents via mouse click or a keyboard shortcut.\n\nSpecific areas (header, body, footer) are defined to provide easy conformance to the\n[WAI-ARIA spec](http://www.w3.org * /TR/wai-aria/states_and_properties#aria-labelledby) for `aria-labelledby`\nand `aria-describedby` (screen reader  * accessibility). Their use is optional, but encouraged.\n */\nexport default class Dialog extends React.PureComponent {\n    static propTypes = {\n        /**\n         * arbitrary content to be rendered after the dialog in the DOM\n         */\n        after: PropTypes.node,\n\n        /**\n         * arbitrary content to be rendered before the dialog in the DOM\n         */\n        before: PropTypes.node,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-body` node\n         */\n        bodyProps: PropTypes.object,\n\n        /**\n         * determines if focus is allowed to move away from the dialog\n         */\n        captureFocus: PropTypes.bool,\n\n        children: PropTypes.node,\n\n        /**\n         * enable detection of \"Escape\" keypresses to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnEscKey: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of clicks inside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnInsideClick: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of clicks outside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnOutsideClick: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of focus outside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnOutsideFocus: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of scroll and mousewheel events outside the dialog area to trigger `props.onClose`; if a functio\n         * is provided, the return value determines if the dialog will be closed\n         */\n        closeOnOutsideScroll: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * text, ReactElements, etc. comprising the \"footer\" area of the dialog, e.g. confirm/cancel buttons\n         */\n        footer: PropTypes.node,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-footer` node\n         */\n        footerProps: PropTypes.object,\n\n        /**\n         * text, ReactElements, etc. to represent the \"title bar\" area of the dialog\n         */\n        header: PropTypes.node,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-header` node\n         */\n        headerProps: PropTypes.object,\n\n        /**\n         * a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the `closeOn` props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied\n         */\n        onClose: PropTypes.func,\n\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-wrapper` node\n         */\n        wrapperProps: PropTypes.object,\n    }\n\n    static defaultProps = {\n        after: null,\n        before: null,\n        bodyProps: {},\n        captureFocus: true,\n        children: null,\n        closeOnEscKey: false,\n        closeOnInsideClick: false,\n        closeOnOutsideClick: false,\n        closeOnOutsideFocus: false,\n        closeOnOutsideScroll: false,\n        footer: null,\n        footerProps: {},\n        header: null,\n        headerProps: {},\n        onClose: noop,\n        onKeyDown: noop,\n        wrapperProps: {},\n    }\n\n    static internalKeys = Object.keys(Dialog.defaultProps)\n\n    mounted = false\n\n    // fallbacks if one isn't passed\n    uuidHeader = uuid()\n    uuidBody = uuid()\n\n    isPartOfDialog(node) {\n        if (!node || node === window) { return false; }\n\n        const roots = [this.$wrapper].concat(\n            toArray.call(\n                this.$wrapper.querySelectorAll(`[${Portal.PORTAL_DATA_ATTRIBUTE}]`)\n            ).map((dom) => document.getElementById(dom.getAttribute(Portal.PORTAL_DATA_ATTRIBUTE)))\n        );\n\n        const element = node.nodeType !== Node.ELEMENT_NODE ? node.parentNode : node;\n\n        return roots.some((dom) => dom.contains(element));\n    }\n\n    componentDidMount() {\n        window.addEventListener('click', this.handleOutsideClick, true);\n        window.addEventListener('contextmenu', this.handleOutsideClick, true);\n        window.addEventListener('focus', this.handleFocus, true);\n        window.addEventListener('scroll', this.handleOutsideScrollWheel, true);\n        window.addEventListener('wheel', this.handleOutsideScrollWheel, true);\n\n        if (this.props.captureFocus && !this.isPartOfDialog(document.activeElement)) {\n            this.$dialog.focus();\n        }\n    }\n\n    componentWillUnmount() {\n        window.removeEventListener('click', this.handleOutsideClick, true);\n        window.removeEventListener('contextmenu', this.handleOutsideClick, true);\n        window.removeEventListener('focus', this.handleFocus, true);\n        window.removeEventListener('scroll', this.handleOutsideScrollWheel, true);\n        window.removeEventListener('wheel', this.handleOutsideScrollWheel, true);\n    }\n\n    shouldDialogCloseOnEvent(prop, event) {\n        return isFunction(this.props[prop]) ? this.props[prop](event) : this.props[prop];\n    }\n\n    handleFocus = (nativeEvent) => {\n        if (!this.props.captureFocus) {\n            if (this.shouldDialogCloseOnEvent('closeOnOutsideFocus', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n                return window.setTimeout(this.props.onClose, 0);\n            }\n\n            return;\n        }\n\n        // explicitOriginalTarget is for Firefox, as it doesn't support relatedTarget\n        let previous = nativeEvent.explicitOriginalTarget || nativeEvent.relatedTarget;\n\n        if (this.isPartOfDialog(previous) && !this.isPartOfDialog(nativeEvent.target)) {\n            nativeEvent.preventDefault();\n            previous.focus(); // restore focus\n        }\n    }\n\n    handleKeyDown = (event) => {\n        if (event.key === 'Escape') {\n            if (this.shouldDialogCloseOnEvent('closeOnEscKey', event)) {\n                window.setTimeout(this.props.onClose, 0);\n            }\n        }\n\n        if (this.props.onKeyDown) {\n            this.props.onKeyDown(event);\n        }\n    }\n\n    handleInsideClick = (event) => {\n        if (this.shouldDialogCloseOnEvent('closeOnInsideClick', event)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    handleOutsideClick = (nativeEvent) => {\n        if (this.shouldDialogCloseOnEvent('closeOnOutsideClick', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    handleOutsideScrollWheel = (nativeEvent) => {\n        if (this.shouldDialogCloseOnEvent('closeOnOutsideScroll', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    renderBody() {\n        return (\n            <div\n                {...this.props.bodyProps}\n                id={this.props.bodyProps.id || this.uuidBody}\n                className={cx('b-dialog-body', this.props.bodyProps.className)}>\n                {this.props.children}\n            </div>\n        );\n    }\n\n    renderFooter() {\n        if (this.props.footer) {\n            return (\n                <footer\n                    {...this.props.footerProps}\n                    className={cx('b-dialog-footer', this.props.footerProps.className)}>\n                    {this.props.footer}\n                </footer>\n            );\n        }\n    }\n\n    renderHeader() {\n        if (this.props.header) {\n            return (\n                <header\n                    {...this.props.headerProps}\n                    id={this.props.headerProps.id || this.uuidHeader}\n                    className={cx('b-dialog-header', this.props.headerProps.className)}>\n                    {this.props.header}\n                </header>\n            );\n        }\n    }\n\n    renderFocusBoundary() {\n        if (this.props.captureFocus) {\n            return (\n                <div className='b-offscreen' tabIndex='0' aria-hidden='true'>&nbsp;</div>\n            );\n        }\n    } // used to lock focus into a particular subset of DOM\n\n    render() {\n        return (\n            <div\n                {...this.props.wrapperProps}\n                ref={(node) => (this.$wrapper = node)}\n                className={cx('b-dialog-wrapper', this.props.wrapperProps.className)}\n                tabIndex='0'>\n                {this.renderFocusBoundary()}\n\n                {this.props.before}\n\n                <div\n                    {...omit(this.props, Dialog.internalKeys)}\n                    ref={(node) => (this.$dialog = node)}\n                    className={cx('b-dialog', this.props.className)}\n                    onClick={this.handleInsideClick}\n                    onKeyDown={this.handleKeyDown}\n                    role='dialog'\n                    aria-labelledby={this.uuidHeader}\n                    aria-describedby={this.uuidBody}\n                    tabIndex='0'>\n                    {this.renderHeader()}\n                    {this.renderBody()}\n                    {this.renderFooter()}\n                </div>\n\n                {this.props.after}\n\n                {this.renderFocusBoundary()}\n            </div>\n        );\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-dialog/index.js"],"sourceRoot":""} | ||
module.exports=function(e){function o(t){if(n[t])return n[t].exports;var r=n[t]={i:t,l:!1,exports:{}};return e[t].call(r.exports,r,r.exports,o),r.l=!0,r.exports}var n={};return o.m=e,o.c=n,o.i=function(e){return e},o.d=function(e,n,t){o.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:t})},o.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(n,"a",n),n},o.o=function(e,o){return Object.prototype.hasOwnProperty.call(e,o)},o.p="",o(o.s=4)}([function(e,o){e.exports=require("boundless-portal")},function(e,o){e.exports=require("boundless-utils-omit-keys")},function(e,o){e.exports=require("classnames")},function(e,o){e.exports=require("react")},function(e,o,n){"use strict";function t(e,o){if(!(e instanceof o))throw new TypeError("Cannot call a class as a function")}function r(e,o){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!o||"object"!=typeof o&&"function"!=typeof o?e:o}function s(e,o){if("function"!=typeof o&&null!==o)throw new TypeError("Super expression must either be null or a function, not "+typeof o);e.prototype=Object.create(o&&o.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),o&&(Object.setPrototypeOf?Object.setPrototypeOf(e,o):e.__proto__=o)}Object.defineProperty(o,"__esModule",{value:!0});var i=n(3),l=n.n(i),u=n(2),c=n.n(u),p=n(0),a=n.n(p),d=n(1),f=n.n(d),y=Object.assign||function(e){for(var o=1;o<arguments.length;o++){var n=arguments[o];for(var t in n)Object.prototype.hasOwnProperty.call(n,t)&&(e[t]=n[t])}return e},h=function(){function e(e,o){for(var n=0;n<o.length;n++){var t=o[n];t.enumerable=t.enumerable||!1,t.configurable=!0,"value"in t&&(t.writable=!0),Object.defineProperty(e,t.key,t)}}return function(o,n,t){return n&&e(o.prototype,n),t&&e(o,t),o}}(),O=function(e){return"function"==typeof e},w=function(){},T=Array.prototype.slice,v=function(e){function o(){var e,n,s,i;t(this,o);for(var l=arguments.length,u=Array(l),c=0;c<l;c++)u[c]=arguments[c];return n=s=r(this,(e=o.__proto__||Object.getPrototypeOf(o)).call.apply(e,[this].concat(u))),s.mounted=!1,s.handleFocus=function(e){if(s.props.captureFocus){var o=e.explicitOriginalTarget||e.relatedTarget;s.isPartOfDialog(o)&&!s.isPartOfDialog(e.target)&&(e.preventDefault(),o.focus())}else if(s.shouldDialogCloseOnEvent("closeOnOutsideFocus",e)&&!s.isPartOfDialog(e.target))return window.setTimeout(s.props.onClose,0)},s.handleKeyDown=function(e){"Escape"===e.key&&s.shouldDialogCloseOnEvent("closeOnEscKey",e)&&window.setTimeout(s.props.onClose,0),s.props.onKeyDown&&s.props.onKeyDown(e)},s.handleInsideClick=function(e){s.shouldDialogCloseOnEvent("closeOnInsideClick",e)&&window.setTimeout(s.props.onClose,0)},s.handleOutsideClick=function(e){s.shouldDialogCloseOnEvent("closeOnOutsideClick",e)&&!s.isPartOfDialog(e.target)&&window.setTimeout(s.props.onClose,0)},s.handleOutsideScrollWheel=function(e){s.shouldDialogCloseOnEvent("closeOnOutsideScroll",e)&&!s.isPartOfDialog(e.target)&&window.setTimeout(s.props.onClose,0)},i=n,r(s,i)}return s(o,e),h(o,[{key:"isPartOfDialog",value:function(e){if(!e||e===window)return!1;var o=[this.$wrapper].concat(T.call(this.$wrapper.querySelectorAll("["+a.a.PORTAL_DATA_ATTRIBUTE+"]")).map(function(e){return document.getElementById(e.getAttribute(a.a.PORTAL_DATA_ATTRIBUTE))})),n=e.nodeType!==Node.ELEMENT_NODE?e.parentNode:e;return o.some(function(e){return e.contains(n)})}},{key:"componentDidMount",value:function(){window.addEventListener("click",this.handleOutsideClick,!0),window.addEventListener("contextmenu",this.handleOutsideClick,!0),window.addEventListener("focus",this.handleFocus,!0),window.addEventListener("scroll",this.handleOutsideScrollWheel,!0),window.addEventListener("wheel",this.handleOutsideScrollWheel,!0),this.props.captureFocus&&!this.isPartOfDialog(document.activeElement)&&this.$dialog.focus()}},{key:"componentWillUnmount",value:function(){window.removeEventListener("click",this.handleOutsideClick,!0),window.removeEventListener("contextmenu",this.handleOutsideClick,!0),window.removeEventListener("focus",this.handleFocus,!0),window.removeEventListener("scroll",this.handleOutsideScrollWheel,!0),window.removeEventListener("wheel",this.handleOutsideScrollWheel,!0)}},{key:"shouldDialogCloseOnEvent",value:function(e,o){return O(this.props[e])?this.props[e](o):this.props[e]}},{key:"renderFocusBoundary",value:function(){if(this.props.captureFocus)return l.a.createElement("div",{className:"b-offscreen",tabIndex:"0","aria-hidden":"true"}," ")}},{key:"render",value:function(){var e=this;return l.a.createElement(this.props.component,y({},f()(this.props,o.internalKeys),{ref:function(o){return e.$wrapper=o},className:c()("b-dialog-wrapper",this.props.className)}),this.renderFocusBoundary(),this.props.before,l.a.createElement(this.props.dialogComponent,y({},this.dialogProps,{ref:function(o){return e.$dialog=o},className:c()("b-dialog",this.props.dialogProps.className),onClick:this.handleInsideClick,onKeyDown:this.handleKeyDown,role:"dialog",tabIndex:"0"}),this.props.children),this.props.after,this.renderFocusBoundary())}}]),o}(l.a.PureComponent);v.propTypes={"*":i.PropTypes.any,after:i.PropTypes.node,before:i.PropTypes.node,captureFocus:i.PropTypes.bool,closeOnEscKey:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnInsideClick:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideClick:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideFocus:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),closeOnOutsideScroll:i.PropTypes.oneOfType([i.PropTypes.bool,i.PropTypes.func]),component:i.PropTypes.string,dialogComponent:i.PropTypes.string,dialogProps:i.PropTypes.shape({"*":i.PropTypes.any}),onClose:i.PropTypes.func},v.defaultProps={after:null,before:null,captureFocus:!0,children:null,closeOnEscKey:!1,closeOnInsideClick:!1,closeOnOutsideClick:!1,closeOnOutsideFocus:!1,closeOnOutsideScroll:!1,component:"div",dialogComponent:"div",dialogProps:{},onClose:w,onKeyDown:w},v.internalKeys=Object.keys(v.defaultProps),o.default=v}]); | ||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///index.js","webpack:///webpack/bootstrap f1f749ca33cd14d7c7c6","webpack:///external {\"commonjs2\":\"boundless-portal\"}","webpack:///external {\"commonjs2\":\"boundless-utils-omit-keys\"}","webpack:///external {\"commonjs2\":\"classnames\"}","webpack:///external {\"commonjs2\":\"react\"}","webpack:///./packages/boundless-dialog/index.js"],"names":["module","exports","modules","__webpack_require__","moduleId","installedModules","i","l","call","m","c","value","d","name","getter","o","Object","defineProperty","configurable","enumerable","get","n","__esModule","object","property","prototype","hasOwnProperty","p","s","require","__webpack_exports__","_classCallCheck","instance","Constructor","TypeError","_possibleConstructorReturn","self","ReferenceError","_inherits","subClass","superClass","create","constructor","writable","setPrototypeOf","__proto__","__WEBPACK_IMPORTED_MODULE_0_react__","__WEBPACK_IMPORTED_MODULE_0_react___default","__WEBPACK_IMPORTED_MODULE_1_classnames__","__WEBPACK_IMPORTED_MODULE_1_classnames___default","__WEBPACK_IMPORTED_MODULE_2_boundless_portal__","__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default","__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__","__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys___default","_extends","assign","target","arguments","length","source","key","_createClass","defineProperties","props","descriptor","protoProps","staticProps","isFunction","x","noop","toArray","Array","slice","Dialog","_React$PureComponent","_ref","_temp","_this","_ret","this","_len","args","_key","getPrototypeOf","apply","concat","mounted","handleFocus","nativeEvent","captureFocus","previous","explicitOriginalTarget","relatedTarget","isPartOfDialog","preventDefault","focus","shouldDialogCloseOnEvent","window","setTimeout","onClose","handleKeyDown","event","onKeyDown","handleInsideClick","handleOutsideClick","handleOutsideScrollWheel","node","roots","$wrapper","querySelectorAll","a","PORTAL_DATA_ATTRIBUTE","map","dom","document","getElementById","getAttribute","element","nodeType","Node","ELEMENT_NODE","parentNode","some","contains","addEventListener","activeElement","$dialog","removeEventListener","prop","createElement","className","tabIndex","aria-hidden","_this2","component","internalKeys","ref","renderFocusBoundary","before","dialogComponent","dialogProps","onClick","role","children","after","PureComponent","propTypes","*","any","bool","closeOnEscKey","oneOfType","func","closeOnInsideClick","closeOnOutsideClick","closeOnOutsideFocus","closeOnOutsideScroll","string","shape","defaultProps","keys"],"mappings":"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","file":"index.js","sourcesContent":["module.exports =\n/******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId])\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// identity function for calling harmony imports with the correct context\n/******/ \t__webpack_require__.i = function(value) { return value; };\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, {\n/******/ \t\t\t\tconfigurable: false,\n/******/ \t\t\t\tenumerable: true,\n/******/ \t\t\t\tget: getter\n/******/ \t\t\t});\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 4);\n/******/ })\n/************************************************************************/\n/******/ ([\n/* 0 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"boundless-portal\");\n\n/***/ }),\n/* 1 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"boundless-utils-omit-keys\");\n\n/***/ }),\n/* 2 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"classnames\");\n\n/***/ }),\n/* 3 */\n/***/ (function(module, exports) {\n\nmodule.exports = require(\"react\");\n\n/***/ }),\n/* 4 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react__ = __webpack_require__(3);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_react___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_react__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames__ = __webpack_require__(2);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_classnames___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_classnames__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_portal__ = __webpack_require__(0);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2_boundless_portal___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2_boundless_portal__);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys__);\nvar _extends=Object.assign||function(target){for(var i=1;i<arguments.length;i++){var source=arguments[i];for(var key in source){if(Object.prototype.hasOwnProperty.call(source,key)){target[key]=source[key];}}}return target;};var _createClass=function(){function defineProperties(target,props){for(var i=0;i<props.length;i++){var descriptor=props[i];descriptor.enumerable=descriptor.enumerable||false;descriptor.configurable=true;if(\"value\"in descriptor)descriptor.writable=true;Object.defineProperty(target,descriptor.key,descriptor);}}return function(Constructor,protoProps,staticProps){if(protoProps)defineProperties(Constructor.prototype,protoProps);if(staticProps)defineProperties(Constructor,staticProps);return Constructor;};}();function _classCallCheck(instance,Constructor){if(!(instance instanceof Constructor)){throw new TypeError(\"Cannot call a class as a function\");}}function _possibleConstructorReturn(self,call){if(!self){throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");}return call&&(typeof call===\"object\"||typeof call===\"function\")?call:self;}function _inherits(subClass,superClass){if(typeof superClass!==\"function\"&&superClass!==null){throw new TypeError(\"Super expression must either be null or a function, not \"+typeof superClass);}subClass.prototype=Object.create(superClass&&superClass.prototype,{constructor:{value:subClass,enumerable:false,writable:true,configurable:true}});if(superClass)Object.setPrototypeOf?Object.setPrototypeOf(subClass,superClass):subClass.__proto__=superClass;}var isFunction=function isFunction(x){return typeof x==='function';};var noop=function noop(){};var toArray=Array.prototype.slice;var Dialog=function(_React$PureComponent){_inherits(Dialog,_React$PureComponent);function Dialog(){var _ref;var _temp,_this,_ret;_classCallCheck(this,Dialog);for(var _len=arguments.length,args=Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key];}return _ret=(_temp=(_this=_possibleConstructorReturn(this,(_ref=Dialog.__proto__||Object.getPrototypeOf(Dialog)).call.apply(_ref,[this].concat(args))),_this),_this.mounted=false,_this.handleFocus=function(nativeEvent){if(!_this.props.captureFocus){if(_this.shouldDialogCloseOnEvent('closeOnOutsideFocus',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){return window.setTimeout(_this.props.onClose,0);}return;}var previous=nativeEvent.explicitOriginalTarget||nativeEvent.relatedTarget;if(_this.isPartOfDialog(previous)&&!_this.isPartOfDialog(nativeEvent.target)){nativeEvent.preventDefault();previous.focus();}},_this.handleKeyDown=function(event){if(event.key==='Escape'){if(_this.shouldDialogCloseOnEvent('closeOnEscKey',event)){window.setTimeout(_this.props.onClose,0);}}if(_this.props.onKeyDown){_this.props.onKeyDown(event);}},_this.handleInsideClick=function(event){if(_this.shouldDialogCloseOnEvent('closeOnInsideClick',event)){window.setTimeout(_this.props.onClose,0);}},_this.handleOutsideClick=function(nativeEvent){if(_this.shouldDialogCloseOnEvent('closeOnOutsideClick',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){window.setTimeout(_this.props.onClose,0);}},_this.handleOutsideScrollWheel=function(nativeEvent){if(_this.shouldDialogCloseOnEvent('closeOnOutsideScroll',nativeEvent)&&!_this.isPartOfDialog(nativeEvent.target)){window.setTimeout(_this.props.onClose,0);}},_temp),_possibleConstructorReturn(_this,_ret);}_createClass(Dialog,[{key:'isPartOfDialog',value:function isPartOfDialog(node){if(!node||node===window){return false;}var roots=[this.$wrapper].concat(toArray.call(this.$wrapper.querySelectorAll('['+__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default.a.PORTAL_DATA_ATTRIBUTE+']')).map(function(dom){return document.getElementById(dom.getAttribute(__WEBPACK_IMPORTED_MODULE_2_boundless_portal___default.a.PORTAL_DATA_ATTRIBUTE));}));var element=node.nodeType!==Node.ELEMENT_NODE?node.parentNode:node;return roots.some(function(dom){return dom.contains(element);});}},{key:'componentDidMount',value:function componentDidMount(){window.addEventListener('click',this.handleOutsideClick,true);window.addEventListener('contextmenu',this.handleOutsideClick,true);window.addEventListener('focus',this.handleFocus,true);window.addEventListener('scroll',this.handleOutsideScrollWheel,true);window.addEventListener('wheel',this.handleOutsideScrollWheel,true);if(this.props.captureFocus&&!this.isPartOfDialog(document.activeElement)){this.$dialog.focus();}}},{key:'componentWillUnmount',value:function componentWillUnmount(){window.removeEventListener('click',this.handleOutsideClick,true);window.removeEventListener('contextmenu',this.handleOutsideClick,true);window.removeEventListener('focus',this.handleFocus,true);window.removeEventListener('scroll',this.handleOutsideScrollWheel,true);window.removeEventListener('wheel',this.handleOutsideScrollWheel,true);}},{key:'shouldDialogCloseOnEvent',value:function shouldDialogCloseOnEvent(prop,event){return isFunction(this.props[prop])?this.props[prop](event):this.props[prop];}},{key:'renderFocusBoundary',value:function renderFocusBoundary(){if(this.props.captureFocus){return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement('div',{className:'b-offscreen',tabIndex:'0','aria-hidden':'true'},'\\xA0');}}},{key:'render',value:function render(){var _this2=this;return __WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(this.props.component,_extends({},__WEBPACK_IMPORTED_MODULE_3_boundless_utils_omit_keys___default()(this.props,Dialog.internalKeys),{ref:function ref(node){return _this2.$wrapper=node;},className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog-wrapper',this.props.className)}),this.renderFocusBoundary(),this.props.before,__WEBPACK_IMPORTED_MODULE_0_react___default.a.createElement(this.props.dialogComponent,_extends({},this.dialogProps,{ref:function ref(node){return _this2.$dialog=node;},className:__WEBPACK_IMPORTED_MODULE_1_classnames___default()('b-dialog',this.props.dialogProps.className),onClick:this.handleInsideClick,onKeyDown:this.handleKeyDown,role:'dialog',tabIndex:'0'}),this.props.children),this.props.after,this.renderFocusBoundary());}}]);return Dialog;}(__WEBPACK_IMPORTED_MODULE_0_react___default.a.PureComponent);Dialog.propTypes={'*':__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].any,after:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,before:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].node,captureFocus:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,closeOnEscKey:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnInsideClick:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideClick:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideFocus:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),closeOnOutsideScroll:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].oneOfType([__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].bool,__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func]),component:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,dialogComponent:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].string,dialogProps:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].shape({'*':__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].any}),onClose:__WEBPACK_IMPORTED_MODULE_0_react__[\"PropTypes\"].func};Dialog.defaultProps={after:null,before:null,captureFocus:true,children:null,closeOnEscKey:false,closeOnInsideClick:false,closeOnOutsideClick:false,closeOnOutsideFocus:false,closeOnOutsideScroll:false,component:'div',dialogComponent:'div',dialogProps:{},onClose:noop,onKeyDown:noop};Dialog.internalKeys=Object.keys(Dialog.defaultProps);/* harmony default export */ __webpack_exports__[\"default\"] = Dialog;\n\n/***/ })\n/******/ ]);\n\n\n// WEBPACK FOOTER //\n// index.js"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId])\n \t\t\treturn installedModules[moduleId].exports;\n\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// identity function for calling harmony imports with the correct context\n \t__webpack_require__.i = function(value) { return value; };\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 4);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap f1f749ca33cd14d7c7c6","module.exports = require(\"boundless-portal\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"boundless-portal\"}\n// module id = 0\n// module chunks = 0","module.exports = require(\"boundless-utils-omit-keys\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"boundless-utils-omit-keys\"}\n// module id = 1\n// module chunks = 0","module.exports = require(\"classnames\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"classnames\"}\n// module id = 2\n// module chunks = 0","module.exports = require(\"react\");\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"commonjs2\":\"react\"}\n// module id = 3\n// module chunks = 0","import React, {PropTypes} from 'react';\nimport cx from 'classnames';\n\nimport Portal from 'boundless-portal';\nimport omit from 'boundless-utils-omit-keys';\n\nconst isFunction = (x) => typeof x === 'function';\nconst noop = () => {};\nconst toArray = Array.prototype.slice;\n\n/**\n__A non-blocking, focus-stealing container.__\n\nA dialog differs from a modal in that it does not come with a masking layer (to obscure the rest of the page)\nand the user can choose to shift focus away from the dialog contents via mouse click or a keyboard shortcut.\n\nIf you decide to provide a header inside your dialog, it's recommended to configure the [`aria-labelledby`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-labelledby_attribute) attribute, which can be added to `props.dialogProps`.\n */\nexport default class Dialog extends React.PureComponent {\n    static propTypes = {\n        /**\n         * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes)\n         */\n        '*': PropTypes.any,\n\n        /**\n         * arbitrary content to be rendered after the dialog in the DOM\n         */\n        after: PropTypes.node,\n\n        /**\n         * arbitrary content to be rendered before the dialog in the DOM\n         */\n        before: PropTypes.node,\n\n        /**\n         * determines if focus is allowed to move away from the dialog\n         */\n        captureFocus: PropTypes.bool,\n\n        /**\n         * enable detection of \"Escape\" keypresses to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnEscKey: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of clicks inside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnInsideClick: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of clicks outside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnOutsideClick: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of focus outside the dialog area to trigger `props.onClose`; if a function is provided, the return\n         * value determines if the dialog will be closed\n         */\n        closeOnOutsideFocus: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * enable detection of scroll and mousewheel events outside the dialog area to trigger `props.onClose`; if a functio\n         * is provided, the return value determines if the dialog will be closed\n         */\n        closeOnOutsideScroll: PropTypes.oneOfType([\n            PropTypes.bool,\n            PropTypes.func,\n        ]),\n\n        /**\n         * override the type of `.b-dialog-wrapper` HTML element\n         */\n        component: PropTypes.string,\n\n        /**\n         * override the type of `.b-dialog` HTML element\n         */\n        dialogComponent: PropTypes.string,\n\n        dialogProps: PropTypes.shape({\n            /**\n             * any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes)\n             */\n            '*': PropTypes.any,\n        }),\n\n        /**\n         * a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the \"closeOn\" props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied\n         */\n        onClose: PropTypes.func,\n    }\n\n    static defaultProps = {\n        after: null,\n        before: null,\n        captureFocus: true,\n        children: null,\n        closeOnEscKey: false,\n        closeOnInsideClick: false,\n        closeOnOutsideClick: false,\n        closeOnOutsideFocus: false,\n        closeOnOutsideScroll: false,\n        component: 'div',\n        dialogComponent: 'div',\n        dialogProps: {},\n        onClose: noop,\n        onKeyDown: noop,\n    }\n\n    static internalKeys = Object.keys(Dialog.defaultProps)\n\n    mounted = false\n\n    isPartOfDialog(node) {\n        if (!node || node === window) { return false; }\n\n        const roots = [this.$wrapper].concat(\n            toArray.call(\n                this.$wrapper.querySelectorAll(`[${Portal.PORTAL_DATA_ATTRIBUTE}]`)\n            ).map((dom) => document.getElementById(dom.getAttribute(Portal.PORTAL_DATA_ATTRIBUTE)))\n        );\n\n        const element = node.nodeType !== Node.ELEMENT_NODE ? node.parentNode : node;\n\n        return roots.some((dom) => dom.contains(element));\n    }\n\n    componentDidMount() {\n        window.addEventListener('click', this.handleOutsideClick, true);\n        window.addEventListener('contextmenu', this.handleOutsideClick, true);\n        window.addEventListener('focus', this.handleFocus, true);\n        window.addEventListener('scroll', this.handleOutsideScrollWheel, true);\n        window.addEventListener('wheel', this.handleOutsideScrollWheel, true);\n\n        if (this.props.captureFocus && !this.isPartOfDialog(document.activeElement)) {\n            this.$dialog.focus();\n        }\n    }\n\n    componentWillUnmount() {\n        window.removeEventListener('click', this.handleOutsideClick, true);\n        window.removeEventListener('contextmenu', this.handleOutsideClick, true);\n        window.removeEventListener('focus', this.handleFocus, true);\n        window.removeEventListener('scroll', this.handleOutsideScrollWheel, true);\n        window.removeEventListener('wheel', this.handleOutsideScrollWheel, true);\n    }\n\n    shouldDialogCloseOnEvent(prop, event) {\n        return isFunction(this.props[prop]) ? this.props[prop](event) : this.props[prop];\n    }\n\n    handleFocus = (nativeEvent) => {\n        if (!this.props.captureFocus) {\n            if (this.shouldDialogCloseOnEvent('closeOnOutsideFocus', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n                return window.setTimeout(this.props.onClose, 0);\n            }\n\n            return;\n        }\n\n        // explicitOriginalTarget is for Firefox, as it doesn't support relatedTarget\n        let previous = nativeEvent.explicitOriginalTarget || nativeEvent.relatedTarget;\n\n        if (this.isPartOfDialog(previous) && !this.isPartOfDialog(nativeEvent.target)) {\n            nativeEvent.preventDefault();\n            previous.focus(); // restore focus\n        }\n    }\n\n    handleKeyDown = (event) => {\n        if (event.key === 'Escape') {\n            if (this.shouldDialogCloseOnEvent('closeOnEscKey', event)) {\n                window.setTimeout(this.props.onClose, 0);\n            }\n        }\n\n        if (this.props.onKeyDown) {\n            this.props.onKeyDown(event);\n        }\n    }\n\n    handleInsideClick = (event) => {\n        if (this.shouldDialogCloseOnEvent('closeOnInsideClick', event)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    handleOutsideClick = (nativeEvent) => {\n        if (this.shouldDialogCloseOnEvent('closeOnOutsideClick', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    handleOutsideScrollWheel = (nativeEvent) => {\n        if (this.shouldDialogCloseOnEvent('closeOnOutsideScroll', nativeEvent) && !this.isPartOfDialog(nativeEvent.target)) {\n            window.setTimeout(this.props.onClose, 0);\n        }\n    }\n\n    renderFocusBoundary() {\n        if (this.props.captureFocus) {\n            return (\n                <div className='b-offscreen' tabIndex='0' aria-hidden='true'>&nbsp;</div>\n            );\n        }\n    } // used to lock focus into a particular subset of DOM\n\n    render() {\n        return (\n            <this.props.component\n                {...omit(this.props, Dialog.internalKeys)}\n                ref={(node) => (this.$wrapper = node)}\n                className={cx('b-dialog-wrapper', this.props.className)}>\n                {this.renderFocusBoundary()}\n\n                {this.props.before}\n\n                <this.props.dialogComponent\n                    {...this.dialogProps}\n                    ref={(node) => (this.$dialog = node)}\n                    className={cx('b-dialog', this.props.dialogProps.className)}\n                    onClick={this.handleInsideClick}\n                    onKeyDown={this.handleKeyDown}\n                    role='dialog'\n                    tabIndex='0'>\n                    {this.props.children}\n                </this.props.dialogComponent>\n\n                {this.props.after}\n\n                {this.renderFocusBoundary()}\n            </this.props.component>\n        );\n    }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/boundless-dialog/index.js"],"sourceRoot":""} |
@@ -31,7 +31,5 @@ import React from 'react'; | ||
onClose={this.toggleDialog} | ||
wrapperProps={{ | ||
style: { | ||
left: this.state.leftPosition, | ||
top: this.state.topPosition, | ||
}, | ||
style={{ | ||
left: this.state.leftPosition, | ||
top: this.state.topPosition, | ||
}}> | ||
@@ -38,0 +36,0 @@ <iframe |
120
index.js
@@ -6,3 +6,2 @@ import React, {PropTypes} from 'react'; | ||
import omit from 'boundless-utils-omit-keys'; | ||
import uuid from 'boundless-utils-uuid'; | ||
@@ -14,3 +13,2 @@ const isFunction = (x) => typeof x === 'function'; | ||
/** | ||
# Dialog | ||
__A non-blocking, focus-stealing container.__ | ||
@@ -21,5 +19,3 @@ | ||
Specific areas (header, body, footer) are defined to provide easy conformance to the | ||
[WAI-ARIA spec](http://www.w3.org * /TR/wai-aria/states_and_properties#aria-labelledby) for `aria-labelledby` | ||
and `aria-describedby` (screen reader * accessibility). Their use is optional, but encouraged. | ||
If you decide to provide a header inside your dialog, it's recommended to configure the [`aria-labelledby`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-labelledby_attribute) attribute, which can be added to `props.dialogProps`. | ||
*/ | ||
@@ -29,2 +25,7 @@ export default class Dialog extends React.PureComponent { | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes) | ||
*/ | ||
'*': PropTypes.any, | ||
/** | ||
* arbitrary content to be rendered after the dialog in the DOM | ||
@@ -40,7 +41,2 @@ */ | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-body` node | ||
*/ | ||
bodyProps: PropTypes.object, | ||
/** | ||
* determines if focus is allowed to move away from the dialog | ||
@@ -50,4 +46,2 @@ */ | ||
children: PropTypes.node, | ||
/** | ||
@@ -99,30 +93,22 @@ * enable detection of "Escape" keypresses to trigger `props.onClose`; if a function is provided, the return | ||
/** | ||
* text, ReactElements, etc. comprising the "footer" area of the dialog, e.g. confirm/cancel buttons | ||
* override the type of `.b-dialog-wrapper` HTML element | ||
*/ | ||
footer: PropTypes.node, | ||
component: PropTypes.string, | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-footer` node | ||
* override the type of `.b-dialog` HTML element | ||
*/ | ||
footerProps: PropTypes.object, | ||
dialogComponent: PropTypes.string, | ||
/** | ||
* text, ReactElements, etc. to represent the "title bar" area of the dialog | ||
*/ | ||
header: PropTypes.node, | ||
dialogProps: PropTypes.shape({ | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes) | ||
*/ | ||
'*': PropTypes.any, | ||
}), | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-header` node | ||
* a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the "closeOn" props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied | ||
*/ | ||
headerProps: PropTypes.object, | ||
/** | ||
* a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the `closeOn` props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied | ||
*/ | ||
onClose: PropTypes.func, | ||
/** | ||
* any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-wrapper` node | ||
*/ | ||
wrapperProps: PropTypes.object, | ||
} | ||
@@ -133,3 +119,2 @@ | ||
before: null, | ||
bodyProps: {}, | ||
captureFocus: true, | ||
@@ -142,9 +127,7 @@ children: null, | ||
closeOnOutsideScroll: false, | ||
footer: null, | ||
footerProps: {}, | ||
header: null, | ||
headerProps: {}, | ||
component: 'div', | ||
dialogComponent: 'div', | ||
dialogProps: {}, | ||
onClose: noop, | ||
onKeyDown: noop, | ||
wrapperProps: {}, | ||
} | ||
@@ -156,6 +139,2 @@ | ||
// fallbacks if one isn't passed | ||
uuidHeader = uuid() | ||
uuidBody = uuid() | ||
isPartOfDialog(node) { | ||
@@ -247,38 +226,2 @@ if (!node || node === window) { return false; } | ||
renderBody() { | ||
return ( | ||
<div | ||
{...this.props.bodyProps} | ||
id={this.props.bodyProps.id || this.uuidBody} | ||
className={cx('b-dialog-body', this.props.bodyProps.className)}> | ||
{this.props.children} | ||
</div> | ||
); | ||
} | ||
renderFooter() { | ||
if (this.props.footer) { | ||
return ( | ||
<footer | ||
{...this.props.footerProps} | ||
className={cx('b-dialog-footer', this.props.footerProps.className)}> | ||
{this.props.footer} | ||
</footer> | ||
); | ||
} | ||
} | ||
renderHeader() { | ||
if (this.props.header) { | ||
return ( | ||
<header | ||
{...this.props.headerProps} | ||
id={this.props.headerProps.id || this.uuidHeader} | ||
className={cx('b-dialog-header', this.props.headerProps.className)}> | ||
{this.props.header} | ||
</header> | ||
); | ||
} | ||
} | ||
renderFocusBoundary() { | ||
@@ -294,7 +237,6 @@ if (this.props.captureFocus) { | ||
return ( | ||
<div | ||
{...this.props.wrapperProps} | ||
<this.props.component | ||
{...omit(this.props, Dialog.internalKeys)} | ||
ref={(node) => (this.$wrapper = node)} | ||
className={cx('b-dialog-wrapper', this.props.wrapperProps.className)} | ||
tabIndex='0'> | ||
className={cx('b-dialog-wrapper', this.props.className)}> | ||
{this.renderFocusBoundary()} | ||
@@ -304,16 +246,12 @@ | ||
<div | ||
{...omit(this.props, Dialog.internalKeys)} | ||
<this.props.dialogComponent | ||
{...this.dialogProps} | ||
ref={(node) => (this.$dialog = node)} | ||
className={cx('b-dialog', this.props.className)} | ||
className={cx('b-dialog', this.props.dialogProps.className)} | ||
onClick={this.handleInsideClick} | ||
onKeyDown={this.handleKeyDown} | ||
role='dialog' | ||
aria-labelledby={this.uuidHeader} | ||
aria-describedby={this.uuidBody} | ||
tabIndex='0'> | ||
{this.renderHeader()} | ||
{this.renderBody()} | ||
{this.renderFooter()} | ||
</div> | ||
{this.props.children} | ||
</this.props.dialogComponent> | ||
@@ -323,5 +261,5 @@ {this.props.after} | ||
{this.renderFocusBoundary()} | ||
</div> | ||
</this.props.component> | ||
); | ||
} | ||
} |
@@ -11,3 +11,3 @@ /* eslint no-unused-expressions:0 */ | ||
import Popover from '../boundless-popover/index'; | ||
import conformanceChecker from '../boundless-utils-conformance/index'; | ||
import {$, $$, conformanceChecker} from '../boundless-utils-test-helpers/index'; | ||
@@ -26,58 +26,27 @@ describe('Dialog component', () => { | ||
it('conforms to the Boundless prop interface standards', () => conformanceChecker(render, Dialog, {}, '$dialog')); | ||
it('conforms to the Boundless prop interface standards', () => conformanceChecker(render, Dialog, {})); | ||
it('renders .b-dialog', () => { | ||
render(<Dialog />); | ||
expect(document.querySelector('.b-dialog')).not.toBe(null); | ||
expect($('.b-dialog')).not.toBe(null); | ||
}); | ||
it('renders .b-dialog-body', () => { | ||
render(<Dialog />); | ||
expect(document.querySelector('.b-dialog-body')).not.toBe(null); | ||
it('accepts component customization', () => { | ||
render(<Dialog component='figure' />); | ||
expect($('figure.b-dialog-wrapper')).not.toBe(null); | ||
}); | ||
it('renders .b-dialog-footer', () => { | ||
render(<Dialog footer='x' />); | ||
expect(document.querySelector('.b-dialog-footer')).not.toBe(null); | ||
it('accepts dialog component customization', () => { | ||
render(<Dialog dialogComponent='article' />); | ||
expect($('article.b-dialog')).not.toBe(null); | ||
}); | ||
it('renders .b-dialog-header', () => { | ||
render(<Dialog header='x' />); | ||
expect(document.querySelector('.b-dialog-header')).not.toBe(null); | ||
}); | ||
it('accepts arbitrary React-supported HTML attributes via props.bodyProps', () => { | ||
render(<Dialog bodyProps={{'data-id': 'foo'}} />); | ||
expect(document.querySelector('.b-dialog-body').getAttribute('data-id')).toBe('foo'); | ||
}); | ||
it('accepts arbitrary React-supported HTML attributes via props.footerProps', () => { | ||
render(<Dialog footer='x' footerProps={{'data-id': 'foo'}} />); | ||
expect(document.querySelector('.b-dialog-footer').getAttribute('data-id')).toBe('foo'); | ||
}); | ||
it('accepts arbitrary React-supported HTML attributes via props.headerProps', () => { | ||
render(<Dialog header='x' headerProps={{'data-id': 'foo'}} />); | ||
expect(document.querySelector('.b-dialog-header').getAttribute('data-id')).toBe('foo'); | ||
}); | ||
it('accepts an additional class as a string without replacing the core hook', () => { | ||
it('accepts an additional CSS class', () => { | ||
render(<Dialog className='foo' />); | ||
expect(document.querySelector('.b-dialog').classList.contains('b-dialog')).toBe(true); | ||
expect(document.querySelector('.b-dialog').classList.contains('foo')).toBe(true); | ||
expect($('.b-dialog-wrapper.foo')).not.toBe(null); | ||
}); | ||
it('accepts renderable header content', () => { | ||
render(<Dialog header='foo' />); | ||
expect(document.querySelector('.b-dialog-header').textContent).toBe('foo'); | ||
}); | ||
it('accepts renderable footer content', () => { | ||
render(<Dialog footer='foo' />); | ||
expect(document.querySelector('.b-dialog-footer').textContent).toBe('foo'); | ||
}); | ||
it('accepts renderable content as a nested child', () => { | ||
render(<Dialog>foo</Dialog>); | ||
expect(document.querySelector('.b-dialog-body').textContent).toBe('foo'); | ||
expect($('.b-dialog').textContent).toBe('foo'); | ||
}); | ||
@@ -87,3 +56,3 @@ | ||
render(<Dialog captureFocus={true} />); | ||
expect(document.querySelectorAll('.b-offscreen[tabindex="0"]').length).toBe(2); | ||
expect($$('.b-offscreen[tabindex="0"]').length).toBe(2); | ||
}); | ||
@@ -93,3 +62,3 @@ | ||
render(<Dialog captureFocus={false} />); | ||
expect(document.querySelectorAll('.b-offscreen[tabindex="0"]').length).toBe(0); | ||
expect($$('.b-offscreen[tabindex="0"]').length).toBe(0); | ||
}); | ||
@@ -100,3 +69,3 @@ | ||
render(<Dialog captureFocus={true} />); | ||
expect(document.activeElement).toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).toBe($('.b-dialog')); | ||
}); | ||
@@ -106,3 +75,3 @@ | ||
render(<Dialog captureFocus={false} />); | ||
expect(document.activeElement).not.toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).not.toBe($('.b-dialog')); | ||
}); | ||
@@ -119,3 +88,3 @@ | ||
expect(document.activeElement).toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).toBe($('.b-dialog')); | ||
}); | ||
@@ -255,3 +224,3 @@ }); | ||
expect(document.activeElement).not.toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).not.toBe($('.b-dialog')); | ||
@@ -267,3 +236,3 @@ element.handleFocus({target: mountNode}); | ||
expect(document.activeElement).not.toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).not.toBe($('.b-dialog')); | ||
@@ -288,3 +257,3 @@ element.handleFocus({target: mountNode}); | ||
expect(document.activeElement).not.toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).not.toBe($('.b-dialog')); | ||
@@ -300,3 +269,3 @@ element.handleFocus({target: mountNode}); | ||
expect(document.activeElement).not.toBe(document.querySelector('.b-dialog')); | ||
expect(document.activeElement).not.toBe($('.b-dialog')); | ||
@@ -443,3 +412,3 @@ element.handleFocus({target: mountNode}); | ||
document.querySelector('.bar').click(); | ||
$('.bar').click(); | ||
@@ -446,0 +415,0 @@ expect(element.state.outerPopoverRendered).toBe(true); |
{ | ||
"name": "boundless-dialog", | ||
"version": "1.0.0-beta.6", | ||
"version": "1.0.0-beta.7", | ||
"description": "A non-blocking, focus-stealing container.", | ||
@@ -27,5 +27,4 @@ "main": "build/index.js", | ||
"dependencies": { | ||
"boundless-portal": "^1.0.0-beta.6", | ||
"boundless-utils-omit-keys": "^1.0.0-beta.6", | ||
"boundless-utils-uuid": "^1.0.0-beta.5", | ||
"boundless-portal": "^1.0.0-beta.7", | ||
"boundless-utils-omit-keys": "^1.0.0-beta.7", | ||
"classnames": "^2.1.5" | ||
@@ -32,0 +31,0 @@ }, |
265
README.md
@@ -0,4 +1,6 @@ | ||
<!--- | ||
THIS IS AN AUTOGENERATED FILE. EDIT INDEX.JS INSTEAD. | ||
--> | ||
# Dialog | ||
# Dialog | ||
__A non-blocking, focus-stealing container.__ | ||
@@ -9,9 +11,72 @@ | ||
Specific areas (header, body, footer) are defined to provide easy conformance to the | ||
[WAI-ARIA spec](http://www.w3.org * /TR/wai-aria/states_and_properties#aria-labelledby) for `aria-labelledby` | ||
and `aria-describedby` (screen reader * accessibility). Their use is optional, but encouraged. | ||
If you decide to provide a header inside your dialog, it's recommended to configure the [`aria-labelledby`](https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Techniques/Using_the_aria-labelledby_attribute) attribute, which can be added to `props.dialogProps`. | ||
## Example Usage | ||
```jsx | ||
import React from 'react'; | ||
import {findDOMNode} from 'react-dom'; | ||
import Button from '../../boundless-button/index'; | ||
import Dialog from '../index'; | ||
export default class DialogDemo extends React.PureComponent { | ||
state = { | ||
showDialog: false, | ||
} | ||
componentDidMount() { | ||
const node = findDOMNode(this.refs.trigger); | ||
this.setState({ | ||
leftPosition: node.offsetLeft + node.offsetWidth + 10 + 'px', | ||
topPosition: node.offsetTop + 'px', | ||
}); | ||
} | ||
toggleDialog = () => { | ||
this.setState({showDialog: !this.state.showDialog}); | ||
} | ||
renderDialog() { | ||
if (this.state.showDialog) { | ||
return ( | ||
<Dialog | ||
closeOnEscKey={true} | ||
closeOnOutsideClick={true} | ||
onClose={this.toggleDialog} | ||
style={{ | ||
left: this.state.leftPosition, | ||
top: this.state.topPosition, | ||
}}> | ||
<iframe | ||
className='dialog-demo-video-frame' | ||
width='560' | ||
height='315' | ||
src='https://www.youtube.com/embed/HEheh1BH34Q?autoplay=1&showinfo=0&autohide=1' | ||
frameBorder='0' | ||
allowFullScreen /> | ||
<Button | ||
className='dialog-demo-close-button' | ||
title='Close' | ||
onPressed={this.toggleDialog} /> | ||
</Dialog> | ||
); | ||
} | ||
} | ||
render() { | ||
return ( | ||
<div> | ||
<Button ref='trigger' onPressed={this.toggleDialog}>Launch Video</Button> | ||
{this.renderDialog()} | ||
</div> | ||
); | ||
} | ||
} | ||
``` | ||
## Props | ||
_Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Dialog#props)._ | ||
> Note: only top-level props are in the README, for the full list check out the [website](http://boundless.js.org/Dialog#props). | ||
@@ -25,129 +90,101 @@ ### Required Props | ||
<table> | ||
<tr> | ||
<th>Name</th> | ||
<th>Type</th> | ||
<th>Default Value</th> | ||
<th>Description</th> | ||
</tr> | ||
- __`*`__ ・ any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes) | ||
<tr> | ||
<td>after</td> | ||
<td><pre><code>any renderable</code></pre></td> | ||
<td><pre><code class="language-js">null</code></pre></td> | ||
<td>arbitrary content to be rendered after the dialog in the DOM</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`any` | `n/a` | ||
<tr> | ||
<td>before</td> | ||
<td><pre><code>any renderable</code></pre></td> | ||
<td><pre><code class="language-js">null</code></pre></td> | ||
<td>arbitrary content to be rendered before the dialog in the DOM</td> | ||
</tr> | ||
- __`after`__ ・ arbitrary content to be rendered after the dialog in the DOM | ||
<tr> | ||
<td>bodyProps</td> | ||
<td><pre><code>object</code></pre></td> | ||
<td><pre><code class="language-js">{}</code></pre></td> | ||
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-body` node</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`any renderable` | `null` | ||
<tr> | ||
<td>captureFocus</td> | ||
<td><pre><code>bool</code></pre></td> | ||
<td><pre><code class="language-js">true</code></pre></td> | ||
<td>determines if focus is allowed to move away from the dialog</td> | ||
</tr> | ||
- __`before`__ ・ arbitrary content to be rendered before the dialog in the DOM | ||
<tr> | ||
<td>children</td> | ||
<td><pre><code>any renderable</code></pre></td> | ||
<td><pre><code class="language-js">null</code></pre></td> | ||
<td></td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`any renderable` | `null` | ||
<tr> | ||
<td>closeOnEscKey</td> | ||
<td><pre><code>bool or function</code></pre></td> | ||
<td><pre><code class="language-js">false</code></pre></td> | ||
<td>enable detection of "Escape" keypresses to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed</td> | ||
</tr> | ||
- __`captureFocus`__ ・ determines if focus is allowed to move away from the dialog | ||
<tr> | ||
<td>closeOnInsideClick</td> | ||
<td><pre><code>bool or function</code></pre></td> | ||
<td><pre><code class="language-js">false</code></pre></td> | ||
<td>enable detection of clicks inside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`bool` | `true` | ||
<tr> | ||
<td>closeOnOutsideClick</td> | ||
<td><pre><code>bool or function</code></pre></td> | ||
<td><pre><code class="language-js">false</code></pre></td> | ||
<td>enable detection of clicks outside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed</td> | ||
</tr> | ||
- __`closeOnEscKey`__ ・ enable detection of "Escape" keypresses to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed | ||
<tr> | ||
<td>closeOnOutsideFocus</td> | ||
<td><pre><code>bool or function</code></pre></td> | ||
<td><pre><code class="language-js">false</code></pre></td> | ||
<td>enable detection of focus outside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`bool or function` | `false` | ||
<tr> | ||
<td>closeOnOutsideScroll</td> | ||
<td><pre><code>bool or function</code></pre></td> | ||
<td><pre><code class="language-js">false</code></pre></td> | ||
<td>enable detection of scroll and mousewheel events outside the dialog area to trigger `props.onClose`; if a functio | ||
is provided, the return value determines if the dialog will be closed</td> | ||
</tr> | ||
- __`closeOnInsideClick`__ ・ enable detection of clicks inside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed | ||
<tr> | ||
<td>footer</td> | ||
<td><pre><code>any renderable</code></pre></td> | ||
<td><pre><code class="language-js">null</code></pre></td> | ||
<td>text, ReactElements, etc. comprising the "footer" area of the dialog, e.g. confirm/cancel buttons</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`bool or function` | `false` | ||
<tr> | ||
<td>footerProps</td> | ||
<td><pre><code>object</code></pre></td> | ||
<td><pre><code class="language-js">{}</code></pre></td> | ||
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-footer` node</td> | ||
</tr> | ||
- __`closeOnOutsideClick`__ ・ enable detection of clicks outside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed | ||
<tr> | ||
<td>header</td> | ||
<td><pre><code>any renderable</code></pre></td> | ||
<td><pre><code class="language-js">null</code></pre></td> | ||
<td>text, ReactElements, etc. to represent the "title bar" area of the dialog</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`bool or function` | `false` | ||
<tr> | ||
<td>headerProps</td> | ||
<td><pre><code>object</code></pre></td> | ||
<td><pre><code class="language-js">{}</code></pre></td> | ||
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-header` node</td> | ||
</tr> | ||
- __`closeOnOutsideFocus`__ ・ enable detection of focus outside the dialog area to trigger `props.onClose`; if a function is provided, the return | ||
value determines if the dialog will be closed | ||
<tr> | ||
<td>onClose</td> | ||
<td><pre><code>function</code></pre></td> | ||
<td><pre><code class="language-js">() => {}</code></pre></td> | ||
<td>a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the `closeOn` props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied</td> | ||
</tr> | ||
Expects | Default Value | ||
- | - | ||
`bool or function` | `false` | ||
<tr> | ||
<td>wrapperProps</td> | ||
<td><pre><code>object</code></pre></td> | ||
<td><pre><code class="language-js">{}</code></pre></td> | ||
<td>any [React-supported attribute](https://facebook.github.io/react/docs/tags-and-attributes.html#html-attributes); applied to the `.b-dialog-wrapper` node</td> | ||
</tr> | ||
- __`closeOnOutsideScroll`__ ・ enable detection of scroll and mousewheel events outside the dialog area to trigger `props.onClose`; if a functio | ||
is provided, the return value determines if the dialog will be closed | ||
</table> | ||
Expects | Default Value | ||
- | - | ||
`bool or function` | `false` | ||
- __`component`__ ・ override the type of `.b-dialog-wrapper` HTML element | ||
Expects | Default Value | ||
- | - | ||
`string` | `'div'` | ||
- __`dialogComponent`__ ・ override the type of `.b-dialog` HTML element | ||
Expects | Default Value | ||
- | - | ||
`string` | `'div'` | ||
- __`dialogProps`__ | ||
Expects | Default Value | ||
- | - | ||
`object` | `{}` | ||
- __`onClose`__ ・ a custom event handler that is called to indicate that the dialog should be unrendered by its parent; the event occurs if one or more of the "closeOn" props (`closeOnEscKey`, `closeOnOutsideClick`, etc.) are passed as `true` and the dismissal criteria are satisfied | ||
Expects | Default Value | ||
- | - | ||
`function` | `() => {}` | ||
## Reference Styles | ||
### Stylus | ||
```stylus | ||
// Bring in Boundless's base Stylus variables | ||
@require "node_modules/boundless-dialog/variables" | ||
// Redefine any variables as desired, e.g. | ||
color-accent = royalblue | ||
// Bring in the component styles; they will be autoconfigured based on the above | ||
@require "node_modules/boundless-dialog/style" | ||
``` | ||
### CSS | ||
If desired, a precompiled plain CSS stylesheet is available for customization at `/build/style.css`, based on Boundless's [default variables](https://github.com/enigma-io/boundless/blob/master/variables.styl). | ||
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
5
9
189
86945
636