Created
January 29, 2016 00:16
-
-
Save futuro/6c761182b2952d39bd5e to your computer and use it in GitHub Desktop.
This file has been truncated, but you can view the full file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var TimePicker = | |
/******/ (function(modules) { // webpackBootstrap | |
/******/ // The module cache | |
/******/ var installedModules = {}; | |
/******/ | |
/******/ // The require function | |
/******/ function __webpack_require__(moduleId) { | |
/******/ | |
/******/ // Check if module is in cache | |
/******/ if(installedModules[moduleId]) | |
/******/ return installedModules[moduleId].exports; | |
/******/ | |
/******/ // Create a new module (and put it into the cache) | |
/******/ var module = installedModules[moduleId] = { | |
/******/ exports: {}, | |
/******/ id: moduleId, | |
/******/ loaded: false | |
/******/ }; | |
/******/ | |
/******/ // Execute the module function | |
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); | |
/******/ | |
/******/ // Flag the module as loaded | |
/******/ module.loaded = true; | |
/******/ | |
/******/ // Return the exports of the module | |
/******/ return module.exports; | |
/******/ } | |
/******/ | |
/******/ | |
/******/ // expose the modules object (__webpack_modules__) | |
/******/ __webpack_require__.m = modules; | |
/******/ | |
/******/ // expose the module cache | |
/******/ __webpack_require__.c = installedModules; | |
/******/ | |
/******/ // __webpack_public_path__ | |
/******/ __webpack_require__.p = ""; | |
/******/ | |
/******/ // Load entry module and return exports | |
/******/ return __webpack_require__(0); | |
/******/ }) | |
/************************************************************************/ | |
/******/ ([ | |
/* 0 */ | |
/***/ function(module, exports, __webpack_require__) { | |
"use strict"; | |
module.exports = __webpack_require__(1); | |
/***/ }, | |
/* 1 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _timePicker = __webpack_require__(2); | |
var _timePicker2 = _interopRequireDefault(_timePicker); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
exports.default = _timePicker2.default; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 2 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _windowListenable = __webpack_require__(32); | |
var _windowListenable2 = _interopRequireDefault(_windowListenable); | |
var _timePickerDialog = __webpack_require__(34); | |
var _timePickerDialog2 = _interopRequireDefault(_timePickerDialog); | |
var _textField = __webpack_require__(246); | |
var _textField2 = _interopRequireDefault(_textField); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var emptyTime = new Date(); | |
emptyTime.setHours(0); | |
emptyTime.setMinutes(0); | |
emptyTime.setSeconds(0); | |
emptyTime.setMilliseconds(0); | |
var TimePicker = _react2.default.createClass({ | |
displayName: 'TimePicker', | |
propTypes: { | |
/** | |
* If true, automatically accept and close the picker on set minutes. | |
*/ | |
autoOk: _react2.default.PropTypes.bool, | |
/** | |
* This is the initial time value of the component. | |
*/ | |
defaultTime: _react2.default.PropTypes.object, | |
/** | |
* Tells the component to display the picker in | |
* ampm (12hr) format or 24hr format. | |
*/ | |
format: _react2.default.PropTypes.oneOf(['ampm', '24hr']), | |
/** | |
* Callback function that is fired when the time | |
* value changes. The time value is passed in a Date | |
* Object.Since there is no particular event associated | |
* with the change the first argument will always be null | |
* and the second argument will be the new Date instance. | |
*/ | |
onChange: _react2.default.PropTypes.func, | |
/** | |
* Fired when the timepicker dialog is dismissed. | |
*/ | |
onDismiss: _react2.default.PropTypes.func, | |
/** | |
* Callback function that is fired when the timepicker field gains focus. | |
*/ | |
onFocus: _react2.default.PropTypes.func, | |
/** | |
* Fired when the timepicker dialog is shown. | |
*/ | |
onShow: _react2.default.PropTypes.func, | |
/** | |
* Callback for touch tap event. | |
*/ | |
onTouchTap: _react2.default.PropTypes.func, | |
/** | |
* It's technically more correct to refer to | |
* "12 noon" and "12 midnight" rather than | |
* "12 a.m." and "12 p.m." and it avoids real | |
* confusion between different locales. By default | |
* (for compatibility reasons) TimePicker uses | |
* (12 a.m./12 p.m.) To use (noon/midnight) set pedantic={true}. | |
*/ | |
pedantic: _react2.default.PropTypes.bool, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object, | |
/** | |
* Override the inline-styles of TimePicker's TextField element. | |
*/ | |
textFieldStyle: _react2.default.PropTypes.object, | |
/** | |
* Wordings used inside the button of the dialog. | |
*/ | |
wordings: _react2.default.PropTypes.object | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default, _windowListenable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
defaultTime: null, | |
format: 'ampm', | |
pedantic: false, | |
autoOk: false, | |
style: {} | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
time: this.props.defaultTime || emptyTime, | |
dialogTime: new Date(), | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
windowListeners: { | |
'keyup': '_handleWindowKeyUp' | |
}, | |
formatTime: function formatTime(date) { | |
var hours = date.getHours(); | |
var mins = date.getMinutes().toString(); | |
if (this.props.format === 'ampm') { | |
var isAM = hours < 12; | |
hours = hours % 12; | |
var additional = isAM ? ' am' : ' pm'; | |
hours = (hours || 12).toString(); | |
if (mins.length < 2) mins = '0' + mins; | |
if (this.props.pedantic) { | |
// Treat midday/midnight specially http://www.nist.gov/pml/div688/times.cfm | |
if (hours === '12' && mins === '00') { | |
return additional === ' pm' ? '12 noon' : '12 midnight'; | |
} | |
} | |
return hours + (mins === '00' ? '' : ':' + mins) + additional; | |
} | |
hours = hours.toString(); | |
if (hours.length < 2) hours = '0' + hours; | |
if (mins.length < 2) mins = '0' + mins; | |
return hours + ':' + mins; | |
}, | |
getTime: function getTime() { | |
return this.state.time; | |
}, | |
setTime: function setTime(time) { | |
this.setState({ time: time ? time : emptyTime }); | |
}, | |
/** | |
* Alias for `openDialog()` for an api consistent with TextField. | |
*/ | |
focus: function focus() { | |
this.openDialog(); | |
}, | |
openDialog: function openDialog() { | |
this.setState({ | |
dialogTime: this.getTime() | |
}); | |
this.refs.dialogWindow.show(); | |
}, | |
_handleDialogAccept: function _handleDialogAccept(t) { | |
this.setTime(t); | |
if (this.props.onChange) this.props.onChange(null, t); | |
}, | |
_handleInputFocus: function _handleInputFocus(e) { | |
e.target.blur(); | |
if (this.props.onFocus) this.props.onFocus(e); | |
}, | |
_handleInputTouchTap: function _handleInputTouchTap(e) { | |
e.preventDefault(); | |
this.openDialog(); | |
if (this.props.onTouchTap) this.props.onTouchTap(e); | |
}, | |
render: function render() { | |
var _props = this.props; | |
var autoOk = _props.autoOk; | |
var format = _props.format; | |
var onFocus = _props.onFocus; | |
var onTouchTap = _props.onTouchTap; | |
var onShow = _props.onShow; | |
var onDismiss = _props.onDismiss; | |
var style = _props.style; | |
var wordings = _props.wordings; | |
var textFieldStyle = _props.textFieldStyle; | |
var other = _objectWithoutProperties(_props, ['autoOk', 'format', 'onFocus', 'onTouchTap', 'onShow', 'onDismiss', 'style', 'wordings', 'textFieldStyle']); | |
var time = this.state.time; | |
return _react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(style) }, | |
_react2.default.createElement(_textField2.default, _extends({}, other, { | |
style: textFieldStyle, | |
ref: 'input', | |
value: time === emptyTime ? null : this.formatTime(time), | |
onFocus: this._handleInputFocus, | |
onTouchTap: this._handleInputTouchTap | |
})), | |
_react2.default.createElement(_timePickerDialog2.default, { | |
ref: 'dialogWindow', | |
initialTime: this.state.dialogTime, | |
onAccept: this._handleDialogAccept, | |
onShow: onShow, | |
onDismiss: onDismiss, | |
format: format, | |
wordings: wordings, | |
autoOk: autoOk | |
}) | |
); | |
} | |
}); | |
exports.default = TimePicker; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 3 */ | |
/***/ function(module, exports) { | |
module.exports = React; | |
/***/ }, | |
/* 4 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _styles = __webpack_require__(5); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
/** | |
* This mixin isn't necessary and will be removed soon. DO NOT USE! | |
* | |
* All internal components that use this mixin should be switched to the | |
* `styleUtils` that this mixin now wraps. Notice the method signature of | |
* the `prepareStyles()` function of this mixin is different than the method | |
* signature of the `prepareStyles()` function in `styleUtils`. | |
* | |
* See `../utils/styles.js` for more details. | |
*/ | |
exports.default = { | |
propTypes: { | |
style: _react2.default.PropTypes.object | |
}, | |
mergeStyles: _styles.mergeStyles, | |
mergeAndPrefix: _styles.mergeAndPrefix, | |
prepareStyles: function prepareStyles() { | |
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | |
args[_key] = arguments[_key]; | |
} | |
return _styles.prepareStyles.apply(undefined, [this.state && this.state.muiTheme || this.context.muiTheme || this.props && this.props.muiTheme].concat(args)); | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 5 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.mergeStyles = mergeStyles; | |
exports.mergeAndPrefix = mergeAndPrefix; | |
exports.prepareStyles = prepareStyles; | |
var _autoPrefix = __webpack_require__(7); | |
var _autoPrefix2 = _interopRequireDefault(_autoPrefix); | |
var _reactAddonsUpdate = __webpack_require__(27); | |
var _reactAddonsUpdate2 = _interopRequireDefault(_reactAddonsUpdate); | |
var _warning = __webpack_require__(26); | |
var _warning2 = _interopRequireDefault(_warning); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var reTranslate = /((^|\s)translate(3d|X)?\()(\-?[\d]+)/; | |
var reSkew = /((^|\s)skew(x|y)?\()\s*(\-?[\d]+)(deg|rad|grad)(,\s*(\-?[\d]+)(deg|rad|grad))?/; | |
function mergeSingle(objA, objB) { | |
if (!objA) return objB; | |
if (!objB) return objA; | |
return (0, _reactAddonsUpdate2.default)(objA, { $merge: objB }); | |
} | |
/** | |
* This function ensures that `style` supports both ltr and rtl directions by | |
* checking `styleConstants` in `muiTheme` and replacing attribute keys if | |
* necessary. | |
*/ | |
function ensureDirection(muiTheme, style) { | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(!style.didFlip, 'You\'re calling ensureDirection() on the same style | |
object twice.') : undefined; | |
style = mergeStyles({ | |
didFlip: 'true' | |
}, style); | |
} | |
// Left to right is the default. No need to flip anything. | |
if (!muiTheme || !muiTheme.isRtl) return style; | |
var flippedAttributes = { | |
// Keys and their replacements. | |
right: 'left', | |
left: 'right', | |
marginRight: 'marginLeft', | |
marginLeft: 'marginRight', | |
paddingRight: 'paddingLeft', | |
paddingLeft: 'paddingRight', | |
borderRight: 'borderLeft', | |
borderLeft: 'borderRight' | |
}; | |
var newStyle = {}; | |
Object.keys(style).forEach(function (attribute) { | |
var value = style[attribute]; | |
var key = attribute; | |
if (flippedAttributes.hasOwnProperty(attribute)) { | |
key = flippedAttributes[attribute]; | |
} | |
switch (attribute) { | |
case 'float': | |
case 'textAlign': | |
if (value === 'right') { | |
value = 'left'; | |
} else if (value === 'left') { | |
value = 'right'; | |
} | |
break; | |
case 'direction': | |
if (value === 'ltr') { | |
value = 'rtl'; | |
} else if (value === 'rtl') { | |
value = 'ltr'; | |
} | |
break; | |
case 'transform': | |
var matches = undefined; | |
if (matches = value.match(reTranslate)) { | |
value = value.replace(matches[0], matches[1] + -parseFloat(matches[4])); | |
} | |
if (matches = value.match(reSkew)) { | |
value = value.replace(matches[0], matches[1] + -parseFloat(matches[4]) + matches[5] + matches[6] ? ',' + -parseFloat(matches[7]) + matches[8] : ''); | |
} | |
break; | |
case 'transformOrigin': | |
if (value.indexOf('right') > -1) { | |
value = value.replace('right', 'left'); | |
} else if (value.indexOf('left') > -1) { | |
value = value.replace('left', 'right'); | |
} | |
break; | |
} | |
newStyle[key] = value; | |
}); | |
return newStyle; | |
} | |
function mergeStyles(base) { | |
for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { | |
args[_key - 1] = arguments[_key]; | |
} | |
for (var i = 0; i < args.length; i++) { | |
if (args[i]) { | |
base = mergeSingle(base, args[i]); | |
} | |
} | |
return base; | |
} | |
/** | |
* `mergeAndPrefix` is used to merge styles and autoprefix them. It has has been deprecated | |
* and should no longer be used. | |
*/ | |
function mergeAndPrefix() { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Use of mergeAndPrefix() has been deprecated. ' + 'Please use mergeStyles() for merging styles, and then prepareStyles() for prefixing and ensuring direction.') : undefined; | |
return _autoPrefix2.default.all(mergeStyles.apply(undefined, arguments)); | |
} | |
/** | |
* `prepareStyles` is used to merge multiple styles, make sure they are flipped | |
* to rtl if needed, and then autoprefix them. | |
* | |
* Never call this on the same style object twice. As a rule of thumb, only | |
* call it when passing style attribute to html elements. | |
* | |
* If this method detects you called it twice on the same style object, it | |
* will produce a warning in the console. | |
*/ | |
function prepareStyles(muiTheme) { | |
var style = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; | |
for (var _len2 = arguments.length, styles = Array(_len2 > 2 ? _len2 - 2 : 0), _key2 = 2; _key2 < _len2; _key2++) { | |
styles[_key2 - 2] = arguments[_key2]; | |
} | |
if (styles) { | |
//warning(false, 'Providing more than one style argument to prepareStyles has been deprecated. ' + | |
// 'Please pass a single style, such as the result from mergeStyles(...styles).'); | |
style = mergeStyles.apply(undefined, [style].concat(styles)); | |
} | |
var flipped = ensureDirection(muiTheme, style); | |
return muiTheme.prefix(flipped); | |
} | |
exports.default = { | |
mergeStyles: mergeStyles, | |
mergeAndPrefix: mergeAndPrefix, | |
prepareStyles: prepareStyles | |
}; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 6 */ | |
/***/ function(module, exports) { | |
// shim for using process in browser | |
var process = module.exports = {}; | |
var queue = []; | |
var draining = false; | |
var currentQueue; | |
var queueIndex = -1; | |
function cleanUpNextTick() { | |
draining = false; | |
if (currentQueue.length) { | |
queue = currentQueue.concat(queue); | |
} else { | |
queueIndex = -1; | |
} | |
if (queue.length) { | |
drainQueue(); | |
} | |
} | |
function drainQueue() { | |
if (draining) { | |
return; | |
} | |
var timeout = setTimeout(cleanUpNextTick); | |
draining = true; | |
var len = queue.length; | |
while(len) { | |
currentQueue = queue; | |
queue = []; | |
while (++queueIndex < len) { | |
if (currentQueue) { | |
currentQueue[queueIndex].run(); | |
} | |
} | |
queueIndex = -1; | |
len = queue.length; | |
} | |
currentQueue = null; | |
draining = false; | |
clearTimeout(timeout); | |
} | |
process.nextTick = function (fun) { | |
var args = new Array(arguments.length - 1); | |
if (arguments.length > 1) { | |
for (var i = 1; i < arguments.length; i++) { | |
args[i - 1] = arguments[i]; | |
} | |
} | |
queue.push(new Item(fun, args)); | |
if (queue.length === 1 && !draining) { | |
setTimeout(drainQueue, 0); | |
} | |
}; | |
// v8 likes predictible objects | |
function Item(fun, array) { | |
this.fun = fun; | |
this.array = array; | |
} | |
Item.prototype.run = function () { | |
this.fun.apply(null, this.array); | |
}; | |
process.title = 'browser'; | |
process.browser = true; | |
process.env = {}; | |
process.argv = []; | |
process.version = ''; // empty string to avoid regexp issues | |
process.versions = {}; | |
function noop() {} | |
process.on = noop; | |
process.addListener = noop; | |
process.once = noop; | |
process.off = noop; | |
process.removeListener = noop; | |
process.removeAllListeners = noop; | |
process.emit = noop; | |
process.binding = function (name) { | |
throw new Error('process.binding is not supported'); | |
}; | |
process.cwd = function () { return '/' }; | |
process.chdir = function (dir) { | |
throw new Error('process.chdir is not supported'); | |
}; | |
process.umask = function() { return 0; }; | |
/***/ }, | |
/* 7 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _inlineStylePrefixer = __webpack_require__(8); | |
var _inlineStylePrefixer2 = _interopRequireDefault(_inlineStylePrefixer); | |
var _warning = __webpack_require__(26); | |
var _warning2 = _interopRequireDefault(_warning); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var prefixers = {}; | |
var hasWarnedAboutUserAgent = false; | |
exports.default = { | |
getTransform: function getTransform(userAgent) { | |
if (userAgent === undefined && typeof navigator !== 'undefined') { | |
userAgent = navigator.userAgent; | |
} | |
if (userAgent === undefined && !hasWarnedAboutUserAgent) { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI: userAgent should be supplied in the muiTheme context | |
for server-side rendering.') : undefined; | |
hasWarnedAboutUserAgent = true; | |
} | |
if (userAgent === false) { | |
// Disabled autoprefixer | |
return function (style) { | |
return style; | |
}; | |
} else if (userAgent === 'all' || userAgent === undefined) { | |
// Prefix for all user agent | |
return _inlineStylePrefixer2.default.prefixAll; | |
} else { | |
var prefixer = new _inlineStylePrefixer2.default({ | |
userAgent: userAgent | |
}); | |
return prefixer.prefix; | |
} | |
}, | |
getPrefixer: function getPrefixer() { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI: getPrefixer() is no longer used. Do not use it.') : undefined; | |
if (typeof navigator === 'undefined') { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI expects the global navigator.userAgent to be defined | |
for server-side rendering. Set this property when receiving the request headers.') : undefined; | |
return null; | |
} | |
var userAgent = navigator.userAgent; | |
// Get prefixing instance for this user agent | |
var prefixer = prefixers[userAgent]; | |
// None found, create a new instance | |
if (!prefixer) { | |
prefixer = new _inlineStylePrefixer2.default({ userAgent: userAgent }); | |
prefixers[userAgent] = prefixer; | |
} | |
return prefixer; | |
}, | |
all: function all(style) { | |
if (!style) { | |
return {}; | |
} | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI: all() is no longer used, it will be removed. Do not use it') : undefined; | |
var prefixer = this.getPrefixer(); | |
if (prefixer) { | |
return prefixer.prefix(style); | |
} else { | |
return _inlineStylePrefixer2.default.prefixAll(style); | |
} | |
}, | |
set: function set(style, key, value, muiTheme) { | |
style[key] = value; | |
if (muiTheme) { | |
style = muiTheme.prefix(style); | |
} else { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI: you need to provide the muiTheme to the autoPrefix.set()') : undefined; | |
var prefixer = this.getPrefixer(); | |
if (prefixer) { | |
style = prefixer.prefix(style); | |
} else { | |
style = _inlineStylePrefixer2.default.prefixAll(style); | |
} | |
} | |
}, | |
getPrefix: function getPrefix(key) { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Material UI: getPrefix() is no longer used, it will be removed. Do not use it') : undefined; | |
var style = {}; | |
style[key] = true; | |
var prefixer = this.getPrefixer(); | |
var prefixes = undefined; | |
if (prefixer) { | |
prefixes = Object.keys(prefixer.prefix(style)); | |
} else { | |
prefixes = Object.keys(_inlineStylePrefixer2.default.prefixAll(style)); | |
} | |
return prefixes ? prefixes[0] : key; | |
} | |
}; | |
module.exports = exports['default']; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 8 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
var _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 _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError('Cannot call a class as a function'); } } | |
var _utilsGetBrowserInformation = __webpack_require__(9); | |
var _utilsGetBrowserInformation2 = _interopRequireDefault(_utilsGetBrowserInformation); | |
var _utilsGetPrefixedKeyframes = __webpack_require__(11); | |
var _utilsGetPrefixedKeyframes2 = _interopRequireDefault(_utilsGetPrefixedKeyframes); | |
var _utilsCapitalizeString = __webpack_require__(12); | |
var _utilsCapitalizeString2 = _interopRequireDefault(_utilsCapitalizeString); | |
var _utilsAssign = __webpack_require__(13); | |
var _utilsAssign2 = _interopRequireDefault(_utilsAssign); | |
var _utilsWarn = __webpack_require__(14); | |
var _utilsWarn2 = _interopRequireDefault(_utilsWarn); | |
var _caniuseData = __webpack_require__(15); | |
var _caniuseData2 = _interopRequireDefault(_caniuseData); | |
var _Plugins = __webpack_require__(16); | |
var _Plugins2 = _interopRequireDefault(_Plugins); | |
var browserWhitelist = ['phantom']; | |
var Prefixer = (function () { | |
/** | |
* Instantiante a new prefixer | |
* @param {string} userAgent - userAgent to gather prefix information according to caniuse.com | |
* @param {string} keepUnprefixed - keeps unprefixed properties and values | |
*/ | |
function Prefixer() { | |
var _this = this; | |
var options = arguments.length <= 0 || arguments[0] === undefined ? {} : arguments[0]; | |
_classCallCheck(this, Prefixer); | |
var defaultUserAgent = typeof navigator !== 'undefined' ? navigator.userAgent : undefined; | |
this._userAgent = options.userAgent || defaultUserAgent; | |
this._keepUnprefixed = options.keepUnprefixed || false; | |
this._browserInfo = (0, _utilsGetBrowserInformation2['default'])(this._userAgent); | |
// Checks if the userAgent was resolved correctly | |
if (this._browserInfo && this._browserInfo.prefix) { | |
// set additional prefix information | |
this.cssPrefix = this._browserInfo.prefix.css; | |
this.jsPrefix = this._browserInfo.prefix.inline; | |
this.prefixedKeyframes = (0, _utilsGetPrefixedKeyframes2['default'])(this._browserInfo); | |
} else { | |
this._hasPropsRequiringPrefix = false; | |
(0, _utilsWarn2['default'])('Either the global navigator was undefined or an invalid userAgent was provided.', 'Using a valid userAgent? Please let us know and create an issue at https://github.com/rofrischmann/inline-style-prefixer/issues'); | |
return false; | |
} | |
var data = this._browserInfo.browser && _caniuseData2['default'][this._browserInfo.browser]; | |
if (data) { | |
this._requiresPrefix = Object.keys(data).filter(function (key) { | |
return data[key] >= _this._browserInfo.version; | |
}).reduce(function (result, name) { | |
return _extends({}, result, _defineProperty({}, name, true)); | |
}, {}); | |
this._hasPropsRequiringPrefix = Object.keys(this._requiresPrefix).length > 0; | |
} else { | |
// check for whitelisted browsers | |
browserWhitelist.forEach(function (browser) { | |
if (_this._browserInfo[browser]) { | |
_this._isWhitelisted = true; | |
} | |
}); | |
this._hasPropsRequiringPrefix = false; | |
// Do not throw a warning if whitelisted | |
if (this._isWhitelisted) { | |
return true; | |
} | |
(0, _utilsWarn2['default'])('Your userAgent seems to be not supported by inline-style-prefixer. Feel free to open an issue.'); | |
return false; | |
} | |
} | |
/** | |
* Returns a prefixed version of the style object | |
* @param {Object} styles - Style object that gets prefixed properties added | |
* @returns {Object} - Style object with prefixed properties and values | |
*/ | |
_createClass(Prefixer, [{ | |
key: 'prefix', | |
value: function prefix(styles) { | |
var _this2 = this; | |
// only add prefixes if needed | |
if (!this._hasPropsRequiringPrefix) { | |
return styles; | |
} | |
styles = (0, _utilsAssign2['default'])({}, styles); | |
Object.keys(styles).forEach(function (property) { | |
var value = styles[property]; | |
if (value instanceof Object) { | |
// recurse through nested style objects | |
styles[property] = _this2.prefix(value); | |
} else { | |
// add prefixes if needed | |
if (_this2._requiresPrefix[property]) { | |
styles[_this2.jsPrefix + (0, _utilsCapitalizeString2['default'])(property)] = value; | |
if (!_this2._keepUnprefixed) { | |
delete styles[property]; | |
} | |
} | |
// resolve plugins | |
_Plugins2['default'].forEach(function (plugin) { | |
// generates a new plugin interface with current data | |
var resolvedStyles = plugin({ | |
property: property, | |
value: value, | |
styles: styles, | |
browserInfo: _this2._browserInfo, | |
prefix: { | |
js: _this2.jsPrefix, | |
css: _this2.cssPrefix, | |
keyframes: _this2.prefixedKeyframes | |
}, | |
keepUnprefixed: _this2._keepUnprefixed, | |
requiresPrefix: _this2._requiresPrefix, | |
forceRun: false | |
}); | |
(0, _utilsAssign2['default'])(styles, resolvedStyles); | |
}); | |
} | |
}); | |
return styles; | |
} | |
/** | |
* Returns a prefixed version of the style object using all vendor prefixes | |
* @param {Object} styles - Style object that gets prefixed properties added | |
* @returns {Object} - Style object with prefixed properties and values | |
*/ | |
}], [{ | |
key: 'prefixAll', | |
value: function prefixAll(styles) { | |
var prefixes = {}; | |
var browserInfo = (0, _utilsGetBrowserInformation2['default'])('*'); | |
browserInfo.browsers.forEach(function (browser) { | |
var data = _caniuseData2['default'][browser]; | |
if (data) { | |
(0, _utilsAssign2['default'])(prefixes, data); | |
} | |
}); | |
// there should always be at least one prefixed style, but just incase | |
if (!Object.keys(prefixes).length > 0) { | |
return styles; | |
} | |
styles = (0, _utilsAssign2['default'])({}, styles); | |
Object.keys(styles).forEach(function (property) { | |
var value = styles[property]; | |
if (value instanceof Object) { | |
// recurse through nested style objects | |
styles[property] = Prefixer.prefixAll(value); | |
} else { | |
var browsers = Object.keys(browserInfo.prefixes); | |
browsers.forEach(function (browser) { | |
var style = browserInfo.prefixes[browser]; | |
// add prefixes if needed | |
if (prefixes[property]) { | |
styles[style.inline + (0, _utilsCapitalizeString2['default'])(property)] = value; | |
} | |
// resolve plugins for each browser | |
_Plugins2['default'].forEach(function (plugin) { | |
var resolvedStyles = plugin({ | |
property: property, | |
value: value, | |
styles: styles, | |
browserInfo: { | |
name: browser, | |
prefix: style, | |
version: 0 // assume lowest | |
}, | |
prefix: {}, | |
keepUnprefixed: true, | |
requiresPrefix: prefixes, | |
forceRun: true | |
}); | |
(0, _utilsAssign2['default'])(styles, resolvedStyles); | |
}); | |
}); | |
} | |
}); | |
return styles; | |
} | |
}]); | |
return Prefixer; | |
})(); | |
exports['default'] = Prefixer; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 9 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } | |
var _bowser = __webpack_require__(10); | |
var _bowser2 = _interopRequireDefault(_bowser); | |
var vendorPrefixes = { | |
Webkit: ['chrome', 'safari', 'ios', 'android', 'phantom', 'opera', 'webos', 'blackberry', 'bada', 'tizen'], | |
Moz: ['firefox', 'seamonkey', 'sailfish'], | |
ms: ['msie', 'msedge'] | |
}; | |
var browsers = { | |
chrome: [['chrome']], | |
safari: [['safari']], | |
firefox: [['firefox']], | |
ie: [['msie']], | |
edge: [['msedge']], | |
opera: [['opera']], | |
ios_saf: [['ios', 'mobile'], ['ios', 'tablet']], | |
ie_mob: [['windowsphone', 'mobile', 'msie'], ['windowsphone', 'tablet', 'msie'], ['windowsphone', 'mobile', 'msedge'], ['windowsphone', 'tablet', 'msedge']], | |
op_mini: [['opera', 'mobile'], ['opera', 'tablet']], | |
and_uc: [['android', 'mobile'], ['android', 'tablet']], | |
android: [['android', 'mobile'], ['android', 'tablet']] | |
}; | |
/** | |
* Returns an object containing prefix data associated with a browser | |
* @param {string} browser - browser to find a prefix for | |
*/ | |
var getPrefixes = function getPrefixes(browser) { | |
var prefixKeys = undefined; | |
var prefix = undefined; | |
var vendors = undefined; | |
var conditions = undefined; | |
var prefixVendor = undefined; | |
var browserVendors = undefined; | |
// Find the prefix for this browser (if any) | |
prefixKeys = Object.keys(vendorPrefixes); | |
for (var i = 0; i < prefixKeys.length; i++) { | |
prefix = prefixKeys[i]; | |
// Find a matching vendor | |
vendors = vendorPrefixes[prefix]; | |
conditions = browsers[browser]; | |
for (var j = 0; j < vendors.length; j++) { | |
prefixVendor = vendors[j]; | |
for (var k = 0; k < conditions.length; k++) { | |
browserVendors = conditions[k]; | |
if (browserVendors.indexOf(prefixVendor) !== -1) { | |
return { | |
inline: prefix, | |
css: '-' + prefix.toLowerCase() + '-' | |
}; | |
} | |
} | |
} | |
} | |
// No prefix found for this browser | |
return { inline: '', css: '' }; | |
}; | |
/** | |
* Uses bowser to get default browser information such as version and name | |
* Evaluates bowser info and adds vendorPrefix information | |
* @param {string} userAgent - userAgent that gets evaluated | |
*/ | |
exports['default'] = function (userAgent) { | |
if (!userAgent) { | |
return false; | |
} | |
var info = {}; | |
// Special user agent, return all supported prefixes | |
// instead of returning a string browser name and a prefix object | |
// we return an array of browser names and map of prefixes for each browser | |
if (userAgent === '*') { | |
// Return an array of supported browsers | |
info.browsers = Object.keys(browsers); | |
// Return prefixes associated by browser | |
info.prefixes = {}; | |
// Iterate browser list, assign prefix to each | |
info.browsers.forEach(function (browser) { | |
info.prefixes[browser] = getPrefixes(browser); | |
}); | |
return info; | |
} | |
// Normal user agent, detect browser | |
info = _bowser2['default']._detect(userAgent); | |
Object.keys(vendorPrefixes).forEach(function (prefix) { | |
vendorPrefixes[prefix].forEach(function (browser) { | |
if (info[browser]) { | |
info.prefix = { | |
inline: prefix, | |
css: '-' + prefix.toLowerCase() + '-' | |
}; | |
} | |
}); | |
}); | |
var name = ''; | |
Object.keys(browsers).forEach(function (browser) { | |
browsers[browser].forEach(function (condition) { | |
var match = 0; | |
condition.forEach(function (single) { | |
if (info[single]) { | |
match += 1; | |
} | |
}); | |
if (condition.length === match) { | |
name = browser; | |
} | |
}); | |
}); | |
info.browser = name; | |
// For cordova IOS 8 the version is missing, set truncated osversion to prevent NaN | |
info.version = info.version ? parseFloat(info.version) : parseInt(parseFloat(info.osversion), 10); | |
// seperate native android chrome | |
// https://github.com/rofrischmann/inline-style-prefixer/issues/45 | |
if (info.browser === 'android' && info.chrome && info.version > 37) { | |
info.browser = 'and_chr'; | |
} | |
info.version = parseFloat(info.version); | |
info.osversion = parseFloat(info.osversion); | |
// For android < 4.4 we want to check the osversion | |
// not the chrome version, see issue #26 | |
// https://github.com/rofrischmann/inline-style-prefixer/issues/26 | |
if (info.browser === 'android' && info.osversion < 5) { | |
info.version = info.osversion; | |
} | |
return info; | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 10 */ | |
/***/ function(module, exports, __webpack_require__) { | |
var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! | |
* Bowser - a browser detector | |
* https://github.com/ded/bowser | |
* MIT License | (c) Dustin Diaz 2015 | |
*/ | |
!function (name, definition) { | |
if (typeof module != 'undefined' && module.exports) module.exports = definition() | |
else if (true) !(__WEBPACK_AMD_DEFINE_FACTORY__ = (definition), __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) : __WEBPACK_AMD_DEFINE_FACTORY__), __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)) | |
else this[name] = definition() | |
}('bowser', function () { | |
/** | |
* See useragents.js for examples of navigator.userAgent | |
*/ | |
var t = true | |
function detect(ua) { | |
function getFirstMatch(regex) { | |
var match = ua.match(regex); | |
return (match && match.length > 1 && match[1]) || ''; | |
} | |
function getSecondMatch(regex) { | |
var match = ua.match(regex); | |
return (match && match.length > 1 && match[2]) || ''; | |
} | |
var iosdevice = getFirstMatch(/(ipod|iphone|ipad)/i).toLowerCase() | |
, likeAndroid = /like android/i.test(ua) | |
, android = !likeAndroid && /android/i.test(ua) | |
, chromeBook = /CrOS/.test(ua) | |
, edgeVersion = getFirstMatch(/edge\/(\d+(\.\d+)?)/i) | |
, versionIdentifier = getFirstMatch(/version\/(\d+(\.\d+)?)/i) | |
, tablet = /tablet/i.test(ua) | |
, mobile = !tablet && /[^-]mobi/i.test(ua) | |
, result | |
if (/opera|opr/i.test(ua)) { | |
result = { | |
name: 'Opera' | |
, opera: t | |
, version: versionIdentifier || getFirstMatch(/(?:opera|opr)[\s\/](\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/yabrowser/i.test(ua)) { | |
result = { | |
name: 'Yandex Browser' | |
, yandexbrowser: t | |
, version: versionIdentifier || getFirstMatch(/(?:yabrowser)[\s\/](\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/windows phone/i.test(ua)) { | |
result = { | |
name: 'Windows Phone' | |
, windowsphone: t | |
} | |
if (edgeVersion) { | |
result.msedge = t | |
result.version = edgeVersion | |
} | |
else { | |
result.msie = t | |
result.version = getFirstMatch(/iemobile\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/msie|trident/i.test(ua)) { | |
result = { | |
name: 'Internet Explorer' | |
, msie: t | |
, version: getFirstMatch(/(?:msie |rv:)(\d+(\.\d+)?)/i) | |
} | |
} else if (chromeBook) { | |
result = { | |
name: 'Chrome' | |
, chromeBook: t | |
, chrome: t | |
, version: getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.\d+)?)/i) | |
} | |
} else if (/chrome.+? edge/i.test(ua)) { | |
result = { | |
name: 'Microsoft Edge' | |
, msedge: t | |
, version: edgeVersion | |
} | |
} | |
else if (/chrome|crios|crmo/i.test(ua)) { | |
result = { | |
name: 'Chrome' | |
, chrome: t | |
, version: getFirstMatch(/(?:chrome|crios|crmo)\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (iosdevice) { | |
result = { | |
name : iosdevice == 'iphone' ? 'iPhone' : iosdevice == 'ipad' ? 'iPad' : 'iPod' | |
} | |
// WTF: version is not part of user agent in web apps | |
if (versionIdentifier) { | |
result.version = versionIdentifier | |
} | |
} | |
else if (/sailfish/i.test(ua)) { | |
result = { | |
name: 'Sailfish' | |
, sailfish: t | |
, version: getFirstMatch(/sailfish\s?browser\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/seamonkey\//i.test(ua)) { | |
result = { | |
name: 'SeaMonkey' | |
, seamonkey: t | |
, version: getFirstMatch(/seamonkey\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/firefox|iceweasel/i.test(ua)) { | |
result = { | |
name: 'Firefox' | |
, firefox: t | |
, version: getFirstMatch(/(?:firefox|iceweasel)[ \/](\d+(\.\d+)?)/i) | |
} | |
if (/\((mobile|tablet);[^\)]*rv:[\d\.]+\)/i.test(ua)) { | |
result.firefoxos = t | |
} | |
} | |
else if (/silk/i.test(ua)) { | |
result = { | |
name: 'Amazon Silk' | |
, silk: t | |
, version : getFirstMatch(/silk\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (android) { | |
result = { | |
name: 'Android' | |
, version: versionIdentifier | |
} | |
} | |
else if (/phantom/i.test(ua)) { | |
result = { | |
name: 'PhantomJS' | |
, phantom: t | |
, version: getFirstMatch(/phantomjs\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/blackberry|bb\d+/i.test(ua) || /rim\stablet/i.test(ua)) { | |
result = { | |
name: 'BlackBerry' | |
, blackberry: t | |
, version: versionIdentifier || getFirstMatch(/blackberry[\d]+\/(\d+(\.\d+)?)/i) | |
} | |
} | |
else if (/(web|hpw)os/i.test(ua)) { | |
result = { | |
name: 'WebOS' | |
, webos: t | |
, version: versionIdentifier || getFirstMatch(/w(?:eb)?osbrowser\/(\d+(\.\d+)?)/i) | |
}; | |
/touchpad\//i.test(ua) && (result.touchpad = t) | |
} | |
else if (/bada/i.test(ua)) { | |
result = { | |
name: 'Bada' | |
, bada: t | |
, version: getFirstMatch(/dolfin\/(\d+(\.\d+)?)/i) | |
}; | |
} | |
else if (/tizen/i.test(ua)) { | |
result = { | |
name: 'Tizen' | |
, tizen: t | |
, version: getFirstMatch(/(?:tizen\s?)?browser\/(\d+(\.\d+)?)/i) || versionIdentifier | |
}; | |
} | |
else if (/safari/i.test(ua)) { | |
result = { | |
name: 'Safari' | |
, safari: t | |
, version: versionIdentifier | |
} | |
} | |
else { | |
result = { | |
name: getFirstMatch(/^(.*)\/(.*) /), | |
version: getSecondMatch(/^(.*)\/(.*) /) | |
}; | |
} | |
// set webkit or gecko flag for browsers based on these engines | |
if (!result.msedge && /(apple)?webkit/i.test(ua)) { | |
result.name = result.name || "Webkit" | |
result.webkit = t | |
if (!result.version && versionIdentifier) { | |
result.version = versionIdentifier | |
} | |
} else if (!result.opera && /gecko\//i.test(ua)) { | |
result.name = result.name || "Gecko" | |
result.gecko = t | |
result.version = result.version || getFirstMatch(/gecko\/(\d+(\.\d+)?)/i) | |
} | |
// set OS flags for platforms that have multiple browsers | |
if (!result.msedge && (android || result.silk)) { | |
result.android = t | |
} else if (iosdevice) { | |
result[iosdevice] = t | |
result.ios = t | |
} | |
// OS version extraction | |
var osVersion = ''; | |
if (result.windowsphone) { | |
osVersion = getFirstMatch(/windows phone (?:os)?\s?(\d+(\.\d+)*)/i); | |
} else if (iosdevice) { | |
osVersion = getFirstMatch(/os (\d+([_\s]\d+)*) like mac os x/i); | |
osVersion = osVersion.replace(/[_\s]/g, '.'); | |
} else if (android) { | |
osVersion = getFirstMatch(/android[ \/-](\d+(\.\d+)*)/i); | |
} else if (result.webos) { | |
osVersion = getFirstMatch(/(?:web|hpw)os\/(\d+(\.\d+)*)/i); | |
} else if (result.blackberry) { | |
osVersion = getFirstMatch(/rim\stablet\sos\s(\d+(\.\d+)*)/i); | |
} else if (result.bada) { | |
osVersion = getFirstMatch(/bada\/(\d+(\.\d+)*)/i); | |
} else if (result.tizen) { | |
osVersion = getFirstMatch(/tizen[\/\s](\d+(\.\d+)*)/i); | |
} | |
if (osVersion) { | |
result.osversion = osVersion; | |
} | |
// device type extraction | |
var osMajorVersion = osVersion.split('.')[0]; | |
if (tablet || iosdevice == 'ipad' || (android && (osMajorVersion == 3 || (osMajorVersion == 4 && !mobile))) || result.silk) { | |
result.tablet = t | |
} else if (mobile || iosdevice == 'iphone' || iosdevice == 'ipod' || android || result.blackberry || result.webos || result.bada) { | |
result.mobile = t | |
} | |
// Graded Browser Support | |
// http://developer.yahoo.com/yui/articles/gbs | |
if (result.msedge || | |
(result.msie && result.version >= 10) || | |
(result.yandexbrowser && result.version >= 15) || | |
(result.chrome && result.version >= 20) || | |
(result.firefox && result.version >= 20.0) || | |
(result.safari && result.version >= 6) || | |
(result.opera && result.version >= 10.0) || | |
(result.ios && result.osversion && result.osversion.split(".")[0] >= 6) || | |
(result.blackberry && result.version >= 10.1) | |
) { | |
result.a = t; | |
} | |
else if ((result.msie && result.version < 10) || | |
(result.chrome && result.version < 20) || | |
(result.firefox && result.version < 20.0) || | |
(result.safari && result.version < 6) || | |
(result.opera && result.version < 10.0) || | |
(result.ios && result.osversion && result.osversion.split(".")[0] < 6) | |
) { | |
result.c = t | |
} else result.x = t | |
return result | |
} | |
var bowser = detect(typeof navigator !== 'undefined' ? navigator.userAgent : '') | |
bowser.test = function (browserList) { | |
for (var i = 0; i < browserList.length; ++i) { | |
var browserItem = browserList[i]; | |
if (typeof browserItem=== 'string') { | |
if (browserItem in bowser) { | |
return true; | |
} | |
} | |
} | |
return false; | |
} | |
/* | |
* Set our detect method to the main bowser object so we can | |
* reuse it to test other user agents. | |
* This is needed to implement future tests. | |
*/ | |
bowser._detect = detect; | |
return bowser | |
}); | |
/***/ }, | |
/* 11 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = function (_ref) { | |
var browser = _ref.browser; | |
var version = _ref.version; | |
var prefix = _ref.prefix; | |
var prefixedKeyframes = 'keyframes'; | |
if (browser === 'chrome' && version < 43 || (browser === 'safari' || browser === 'ios_saf') && version < 9 || browser === 'opera' && version < 30 || browser === 'android' && version <= 4.4 || browser === 'and_uc') { | |
prefixedKeyframes = prefix.css + prefixedKeyframes; | |
} | |
return prefixedKeyframes; | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 12 */ | |
/***/ function(module, exports) { | |
// helper to capitalize strings | |
"use strict"; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports["default"] = function (str) { | |
return str.charAt(0).toUpperCase() + str.slice(1); | |
}; | |
module.exports = exports["default"]; | |
/***/ }, | |
/* 13 */ | |
/***/ function(module, exports) { | |
// leight polyfill for Object.assign | |
"use strict"; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports["default"] = function (base) { | |
var extend = arguments.length <= 1 || arguments[1] === undefined ? {} : arguments[1]; | |
Object.keys(extend).forEach(function (key) { | |
return base[key] = extend[key]; | |
}); | |
return base; | |
}; | |
module.exports = exports["default"]; | |
/***/ }, | |
/* 14 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {// only throw warnings if devmode is enabled | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = function () { | |
if (process.env.NODE_ENV !== 'production') { | |
console.warn.apply(console, arguments); | |
} | |
}; | |
module.exports = exports['default']; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 15 */ | |
/***/ function(module, exports) { | |
var caniuseData = {"chrome":{"transform":35,"transformOrigin":35,"transformOriginX":35,"transformOriginY":35,"backfaceVisibility":35,"perspective":35,"perspectiveOrigin":35,"transformStyle":35,"transformOriginZ":35,"animation":42,"animationDelay":42,"animationDirection":42,"animationFillMode":42,"animationDuration":42,"animationIterationCount":42,"animationName":42,"animationPlayState":42,"animationTimingFunction":42,"appearance":50,"userSelect":50,"fontKerning":32,"textEmphasisPosition":50,"textEmphasis":50,"textEmphasisStyle":50,"textEmphasisColor":50,"boxDecorationBreak":50,"clipPath":50,"maskImage":50,"maskMode":50,"maskRepeat":50,"maskPosition":50,"maskClip":50,"maskOrigin":50,"maskSize":50,"maskComposite":50,"mask":50,"maskBorderSource":50,"maskBorderMode":50,"maskBorderSlice":50,"maskBorderWidth":50,"maskBorderOutset":50,"maskBorderRepeat":50,"maskBorder":50,"maskType":50,"textDecorationStyle":50,"textDecorationSkip":50,"textDecorationLine":50,"textDecorationColor":50,"filter":50,"fontFeatureSettings":47,"breakAfter":50,"breakBefore":50,"breakInside":50,"columnCount":50,"columnFill":50,"columnGap":50,"columnRule":50,"columnRuleColor":50,"columnRuleStyle":50,"columnRuleWidth":50,"columns":50,"columnSpan":50,"columnWidth":50},"safari":{"flex":8,"flexBasis":8,"flexDirection":8,"flexGrow":8,"flexFlow":8,"flexShrink":8,"flexWrap":8,"alignContent":8,"alignItems":8,"alignSelf":8,"justifyContent":8,"order":8,"transition":6,"transitionDelay":6,"transitionDuration":6,"transitionProperty":6,"transitionTimingFunction":6,"transform":8,"transformOrigin":8,"transformOriginX":8,"transformOriginY":8,"backfaceVisibility":8,"perspective":8,"perspectiveOrigin":8,"transformStyle":8,"transformOriginZ":8,"animation":8,"animationDelay":8,"animationDirection":8,"animationFillMode":8,"animationDuration":8,"animationIterationCount":8,"animationName":8,"animationPlayState":8,"animationTimingFunction":8,"appearance":9.1,"userSelect":9.1,"backdropFilter":9.1,"fontKerning":9.1,"scrollSnapType":9.1,"scrollSnapPointsX":9.1,"scrollSnapPointsY":9.1,"scrollSnapDestination":9.1,"scrollSnapCoordinate":9.1,"textEmphasisPosition":7,"textEmphasis":7,"textEmphasisStyle":7,"textEmphasisColor":7,"boxDecorationBreak":9.1,"clipPath":9.1,"maskImage":9.1,"maskMode":9.1,"maskRepeat":9.1,"maskPosition":9.1,"maskClip":9.1,"maskOrigin":9.1,"maskSize":9.1,"maskComposite":9.1,"mask":9.1,"maskBorderSource":9.1,"maskBorderMode":9.1,"maskBorderSlice":9.1,"maskBorderWidth":9.1,"maskBorderOutset":9.1,"maskBorderRepeat":9.1,"maskBorder":9.1,"maskType":9.1,"textDecorationStyle":9.1,"textDecorationSkip":9.1,"textDecorationLine":9.1,"textDecorationColor":9.1,"shapeImageThreshold":9.1,"shapeImageMargin":9.1,"shapeImageOutside":9.1,"filter":9,"hyphens":9.1,"flowInto":9.1,"flowFrom":9.1,"breakBefore":8,"breakAfter":8,"breakInside":8,"regionFragment":9.1,"columnCount":8,"columnFill":8,"columnGap":8,"columnRule":8,"columnRuleColor":8,"columnRuleStyle":8,"columnRuleWidth":8,"columns":8,"columnSpan":8,"columnWidth":8},"firefox":{"appearance":46,"userSelect":46,"boxSizing":28,"textAlignLast":46,"textDecorationStyle":35,"textDecorationSkip":35,"textDecorationLine":35,"textDecorationColor":35,"tabSize":46,"hyphens":42,"fontFeatureSettings":33,"breakAfter":46,"breakBefore":46,"breakInside":46,"columnCount":46,"columnFill":46,"columnGap":46,"columnRule":46,"columnRuleColor":46,"columnRuleStyle":46,"columnRuleWidth":46,"columns":46,"columnSpan":46,"columnWidth":46},"opera":{"flex":16,"flexBasis":16,"flexDirection":16,"flexGrow":16,"flexFlow":16,"flexShrink":16,"flexWrap":16,"alignContent":16,"alignItems":16,"alignSelf":16,"justifyContent":16,"order":16,"transform":22,"transformOrigin":22,"transformOriginX":22,"transformOriginY":22,"backfaceVisibility":22,"perspective":22,"perspectiveOrigin":22,"transformStyle":22,"transformOriginZ":22,"animation":29,"animationDelay":29,"animationDirection":29,"animationFillMode":29,"animationDuration":29,"animationIterationCount":29,"animationName":29,"animationPlayState":29,"animationTimingFunction":29,"appearance":36,"userSelect":36,"fontKerning":19,"textEmphasisPosition":36,"textEmphasis":36,"textEmphasisStyle":36,"textEmphasisColor":36,"boxDecorationBreak":36,"clipPath":36,"maskImage":36,"maskMode":36,"maskRepeat":36,"maskPosition":36,"maskClip":36,"maskOrigin":36,"maskSize":36,"maskComposite":36,"mask":36,"maskBorderSource":36,"maskBorderMode":36,"maskBorderSlice":36,"maskBorderWidth":36,"maskBorderOutset":36,"maskBorderRepeat":36,"maskBorder":36,"maskType":36,"filter":36,"fontFeatureSettings":36,"breakAfter":36,"breakBefore":36,"breakInside":36,"columnCount":36,"columnFill":36,"columnGap":36,"columnRule":36,"columnRuleColor":36,"columnRuleStyle":36,"columnRuleWidth":36,"columns":36,"columnSpan":36,"columnWidth":36},"ie":{"gridArea":11,"gridGap":11,"gridColumnStart":11,"userSelect":11,"grid":11,"breakInside":11,"hyphens":11,"gridTemplateAreas":11,"breakAfter":11,"scrollSnapCoordinate":11,"gridRowStart":11,"gridAutoFlow":11,"scrollSnapDestination":11,"gridTemplate":11,"gridTemplateColumns":11,"transformOrigin":9,"gridAutoRows":11,"gridColumnEnd":11,"transformOriginY":9,"scrollSnapPointsY":11,"breakBefore":11,"gridRowGap":11,"scrollSnapPointsX":11,"regionFragment":11,"flexWrap":10,"wrapFlow":11,"gridRowEnd":11,"flex":10,"flexDirection":10,"flowInto":11,"touchAction":10,"gridColumn":11,"transform":9,"gridTemplateRows":11,"flexFlow":10,"transformOriginX":9,"flowFrom":11,"scrollSnapType":11,"wrapMargin":11,"gridColumnGap":11,"gridRow":11,"wrapThrough":11,"gridAutoColumns":11,"textSizeAdjust":11},"edge":{"userSelect":14,"wrapFlow":14,"wrapThrough":14,"wrapMargin":14,"scrollSnapType":14,"scrollSnapPointsX":14,"scrollSnapPointsY":14,"scrollSnapDestination":14,"scrollSnapCoordinate":14,"hyphens":14,"flowInto":14,"flowFrom":14,"breakBefore":14,"breakAfter":14,"breakInside":14,"regionFragment":14,"gridTemplateColumns":14,"gridTemplateRows":14,"gridTemplateAreas":14,"gridTemplate":14,"gridAutoColumns":14,"gridAutoRows":14,"gridAutoFlow":14,"grid":14,"gridRowStart":14,"gridColumnStart":14,"gridRowEnd":14,"gridRow":14,"gridColumn":14,"gridColumnEnd":14,"gridColumnGap":14,"gridRowGap":14,"gridArea":14,"gridGap":14},"ios_saf":{"flex":8.1,"flexBasis":8.1,"flexDirection":8.1,"flexGrow":8.1,"flexFlow":8.1,"flexShrink":8.1,"flexWrap":8.1,"alignContent":8.1,"alignItems":8.1,"alignSelf":8.1,"justifyContent":8.1,"order":8.1,"transition":6,"transitionDelay":6,"transitionDuration":6,"transitionProperty":6,"transitionTimingFunction":6,"transform":8.1,"transformOrigin":8.1,"transformOriginX":8.1,"transformOriginY":8.1,"backfaceVisibility":8.1,"perspective":8.1,"perspectiveOrigin":8.1,"transformStyle":8.1,"transformOriginZ":8.1,"animation":8.1,"animationDelay":8.1,"animationDirection":8.1,"animationFillMode":8.1,"animationDuration":8.1,"animationIterationCount":8.1,"animationName":8.1,"animationPlayState":8.1,"animationTimingFunction":8.1,"appearance":9.3,"userSelect":9.3,"backdropFilter":9.3,"fontKerning":9.3,"scrollSnapType":9.3,"scrollSnapPointsX":9.3,"scrollSnapPointsY":9.3,"scrollSnapDestination":9.3,"scrollSnapCoordinate":9.3,"boxDecorationBreak":9.3,"clipPath":9.3,"maskImage":9.3,"maskMode":9.3,"maskRepeat":9.3,"maskPosition":9.3,"maskClip":9.3,"maskOrigin":9.3,"maskSize":9.3,"maskComposite":9.3,"mask":9.3,"maskBorderSource":9.3,"maskBorderMode":9.3,"maskBorderSlice":9.3,"maskBorderWidth":9.3,"maskBorderOutset":9.3,"maskBorderRepeat":9.3,"maskBorder":9.3,"maskType":9.3,"textSizeAdjust":9.3,"textDecorationStyle":9.3,"textDecorationSkip":9.3,"textDecorationLine":9.3,"textDecorationColor":9.3,"shapeImageThreshold":9.3,"shapeImageMargin":9.3,"shapeImageOutside":9.3,"filter":9,"hyphens":9.3,"flowInto":9.3,"flowFrom":9.3,"breakBefore":8.1,"breakAfter":8.1,"breakInside":8.1,"regionFragment":9.3,"columnCount":8.1,"columnFill":8.1,"columnGap":8.1,"columnRule":8.1,"columnRuleColor":8.1,"columnRuleStyle":8.1,"columnRuleWidth":8.1,"columns":8.1,"columnSpan":8.1,"columnWidth":8.1},"android":{"borderImage":4.2,"borderImageOutset":4.2,"borderImageRepeat":4.2,"borderImageSlice":4.2,"borderImageSource":4.2,"borderImageWidth":4.2,"flex":4.2,"flexBasis":4.2,"flexDirection":4.2,"flexGrow":4.2,"flexFlow":4.2,"flexShrink":4.2,"flexWrap":4.2,"alignContent":4.2,"alignItems":4.2,"alignSelf":4.2,"justifyContent":4.2,"order":4.2,"transition":4.2,"transitionDelay":4.2,"transitionDuration":4.2,"transitionProperty":4.2,"transitionTimingFunction":4.2,"transform":4.4,"transformOrigin":4.4,"transformOriginX":4.4,"transformOriginY":4.4,"backfaceVisibility":4.4,"perspective":4.4,"perspectiveOrigin":4.4,"transformStyle":4.4,"transformOriginZ":4.4,"animation":4.4,"animationDelay":4.4,"animationDirection":4.4,"animationFillMode":4.4,"animationDuration":4.4,"animationIterationCount":4.4,"animationName":4.4,"animationPlayState":4.4,"animationTimingFunction":4.4,"appearance":46,"userSelect":46,"fontKerning":4.4,"textEmphasisPosition":46,"textEmphasis":46,"textEmphasisStyle":46,"textEmphasisColor":46,"boxDecorationBreak":46,"clipPath":46,"maskImage":46,"maskMode":46,"maskRepeat":46,"maskPosition":46,"maskClip":46,"maskOrigin":46,"maskSize":46,"maskComposite":46,"mask":46,"maskBorderSource":46,"maskBorderMode":46,"maskBorderSlice":46,"maskBorderWidth":46,"maskBorderOutset":46,"maskBorderRepeat":46,"maskBorder":46,"maskType":46,"filter":46,"fontFeatureSettings":46,"breakAfter":46,"breakBefore":46,"breakInside":46,"columnCount":46,"columnFill":46,"columnGap":46,"columnRule":46,"columnRuleColor":46,"columnRuleStyle":46,"columnRuleWidth":46,"columns":46,"columnSpan":46,"columnWidth":46},"and_chr":{"appearance":47,"userSelect":47,"textEmphasisPosition":47,"textEmphasis":47,"textEmphasisStyle":47,"textEmphasisColor":47,"boxDecorationBreak":47,"clipPath":47,"maskImage":47,"maskMode":47,"maskRepeat":47,"maskPosition":47,"maskClip":47,"maskOrigin":47,"maskSize":47,"maskComposite":47,"mask":47,"maskBorderSource":47,"maskBorderMode":47,"maskBorderSlice":47,"maskBorderWidth":47,"maskBorderOutset":47,"maskBorderRepeat":47,"maskBorder":47,"maskType":47,"textDecorationStyle":47,"textDecorationSkip":47,"textDecorationLine":47,"textDecorationColor":47,"filter":47,"fontFeatureSettings":47,"breakAfter":47,"breakBefore":47,"breakInside":47,"columnCount":47,"columnFill":47,"columnGap":47,"columnRule":47,"columnRuleColor":47,"columnRuleStyle":47,"columnRuleWidth":47,"columns":47,"columnSpan":47,"columnWidth":47},"and_uc":{"flex":9.9,"flexBasis":9.9,"flexDirection":9.9,"flexGrow":9.9,"flexFlow":9.9,"flexShrink":9.9,"flexWrap":9.9,"alignContent":9.9,"alignItems":9.9,"alignSelf":9.9,"justifyContent":9.9,"order":9.9,"transition":9.9,"transitionDelay":9.9,"transitionDuration":9.9,"transitionProperty":9.9,"transitionTimingFunction":9.9,"transform":9.9,"transformOrigin":9.9,"transformOriginX":9.9,"transformOriginY":9.9,"backfaceVisibility":9.9,"perspective":9.9,"perspectiveOrigin":9.9,"transformStyle":9.9,"transformOriginZ":9.9,"animation":9.9,"animationDelay":9.9,"animationDirection":9.9,"animationFillMode":9.9,"animationDuration":9.9,"animationIterationCount":9.9,"animationName":9.9,"animationPlayState":9.9,"animationTimingFunction":9.9,"appearance":9.9,"userSelect":9.9,"fontKerning":9.9,"textEmphasisPosition":9.9,"textEmphasis":9.9,"textEmphasisStyle":9.9,"textEmphasisColor":9.9,"maskImage":9.9,"maskMode":9.9,"maskRepeat":9.9,"maskPosition":9.9,"maskClip":9.9,"maskOrigin":9.9,"maskSize":9.9,"maskComposite":9.9,"mask":9.9,"maskBorderSource":9.9,"maskBorderMode":9.9,"maskBorderSlice":9.9,"maskBorderWidth":9.9,"maskBorderOutset":9.9,"maskBorderRepeat":9.9,"maskBorder":9.9,"maskType":9.9,"textSizeAdjust":9.9,"filter":9.9,"hyphens":9.9,"flowInto":9.9,"flowFrom":9.9,"breakBefore":9.9,"breakAfter":9.9,"breakInside":9.9,"regionFragment":9.9,"fontFeatureSettings":9.9,"columnCount":9.9,"columnFill":9.9,"columnGap":9.9,"columnRule":9.9,"columnRuleColor":9.9,"columnRuleStyle":9.9,"columnRuleWidth":9.9,"columns":9.9,"columnSpan":9.9,"columnWidth":9.9},"op_mini":{"borderImage":5,"borderImageOutset":5,"borderImageRepeat":5,"borderImageSlice":5,"borderImageSource":5,"borderImageWidth":5,"tabSize":5,"objectFit":5,"objectPosition":5}}; module.exports = caniuseData | |
/***/ }, | |
/* 16 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } | |
var _pluginsCalc = __webpack_require__(17); | |
var _pluginsCalc2 = _interopRequireDefault(_pluginsCalc); | |
var _pluginsCursor = __webpack_require__(18); | |
var _pluginsCursor2 = _interopRequireDefault(_pluginsCursor); | |
var _pluginsFlex = __webpack_require__(19); | |
var _pluginsFlex2 = _interopRequireDefault(_pluginsFlex); | |
var _pluginsSizing = __webpack_require__(20); | |
var _pluginsSizing2 = _interopRequireDefault(_pluginsSizing); | |
var _pluginsGradient = __webpack_require__(21); | |
var _pluginsGradient2 = _interopRequireDefault(_pluginsGradient); | |
var _pluginsTransition = __webpack_require__(22); | |
var _pluginsTransition2 = _interopRequireDefault(_pluginsTransition); | |
// special flexbox specifications | |
var _pluginsFlexboxIE = __webpack_require__(24); | |
var _pluginsFlexboxIE2 = _interopRequireDefault(_pluginsFlexboxIE); | |
var _pluginsFlexboxOld = __webpack_require__(25); | |
var _pluginsFlexboxOld2 = _interopRequireDefault(_pluginsFlexboxOld); | |
exports['default'] = [_pluginsCalc2['default'], _pluginsCursor2['default'], _pluginsSizing2['default'], _pluginsGradient2['default'], _pluginsTransition2['default'], _pluginsFlexboxIE2['default'], _pluginsFlexboxOld2['default'], | |
// this must be run AFTER the flexbox specs | |
_pluginsFlex2['default']]; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 17 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = calc; | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
function calc(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (typeof value === 'string' && value.indexOf('calc(') > -1 && (forceRun || browser === 'firefox' && version < 15 || browser === 'chrome' && version < 25 || browser === 'safari' && version < 6.1 || browser === 'ios_saf' && version < 7)) { | |
var newValue = forceRun ? | |
// prefix all | |
['-webkit-', '-moz-'].map(function (prefix) { | |
return value.replace(/calc\(/g, prefix + 'calc('); | |
}).join(';' + property + ':') : | |
// default | |
value.replace(/calc\(/g, prefix.css + 'calc('); | |
return _defineProperty({}, property, newValue + (keepUnprefixed ? ';' + property + ':' + value : '')); | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 18 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = cursor; | |
var values = { | |
'zoom-in': true, | |
'zoom-out': true, | |
grab: true, | |
grabbing: true | |
}; | |
function cursor(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (property === 'cursor' && values[value] && (forceRun || browser === 'firefox' && version < 24 || browser === 'chrome' && version < 37 || browser === 'safari' && version < 9 || browser === 'opera' && version < 24)) { | |
var newValue = forceRun ? | |
// prefix all | |
['-webkit-', '-moz-'].map(function (prefix) { | |
return prefix + value; | |
}).join(';' + property + ':') : | |
// default | |
prefix.css + value; | |
return { | |
cursor: newValue + (keepUnprefixed ? ';' + property + ':' + value : '') | |
}; | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 19 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = flex; | |
var values = { flex: true, 'inline-flex': true }; | |
function flex(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (property === 'display' && values[value] && (forceRun || browser === 'chrome' && version < 29 && version > 20 || (browser === 'safari' || browser === 'ios_saf') && version < 9 && version > 6 || browser === 'opera' && (version == 15 || version == 16))) { | |
var newValue = forceRun ? | |
// prefix all | |
['-webkit-box', '-moz-box', '-ms-' + value + 'box', '-webkit-' + value].join(';' + property + ':') : | |
// default | |
'-webkit-' + value; | |
return { | |
display: newValue + (keepUnprefixed ? ';' + property + ':' + value : '') | |
}; | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 20 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = sizing; | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
var properties = { | |
maxHeight: true, | |
maxWidth: true, | |
width: true, | |
height: true, | |
columnWidth: true, | |
minWidth: true, | |
minHeight: true | |
}; | |
var values = { | |
'min-content': true, | |
'max-content': true, | |
'fill-available': true, | |
'fit-content': true, | |
'contain-floats': true | |
}; | |
function sizing(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
// This might change in the future | |
// Keep an eye on it | |
if (properties[property] && values[value]) { | |
var newValue = forceRun ? | |
// prefix all | |
['-webkit-', '-moz-'].map(function (prefix) { | |
return prefix + value; | |
}).join(';' + property + ':') : | |
// default | |
prefix.css + value; | |
return _defineProperty({}, property, newValue + (keepUnprefixed ? ';' + property + ':' + value : '')); | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 21 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = gradient; | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
var values = /linear-gradient|radial-gradient|repeating-linear-gradient|repeating-radial-gradient/; | |
function gradient(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (typeof value === 'string' && value.match(values) !== null && (forceRun || browser === 'firefox' && version < 16 || browser === 'chrome' && version < 26 || (browser === 'safari' || browser === 'ios_saf') && version < 7 || (browser === 'opera' || browser === 'op_mini') && version < 12.1 || browser === 'android' && version < 4.4 || browser === 'and_uc')) { | |
var newValue = forceRun ? | |
// prefix all | |
['-webkit-', '-moz-'].map(function (prefix) { | |
return prefix + value; | |
}).join(';' + property + ':') : | |
// default | |
prefix.css + value; | |
return _defineProperty({}, property, newValue + (keepUnprefixed ? ';' + property + ':' + value : '')); | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 22 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = calc; | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { 'default': obj }; } | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
var _utilsCamelToDashCase = __webpack_require__(23); | |
var _utilsCamelToDashCase2 = _interopRequireDefault(_utilsCamelToDashCase); | |
var _utilsCapitalizeString = __webpack_require__(12); | |
var _utilsCapitalizeString2 = _interopRequireDefault(_utilsCapitalizeString); | |
function calc(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var requiresPrefix = pluginInterface.requiresPrefix; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if ( | |
// also check for already prefixed transitions | |
typeof value === 'string' && (property.toLowerCase().indexOf('transition') > -1 || property.toLowerCase().indexOf('transitionproperty') > -1)) { | |
var _ref; | |
var _ret = (function () { | |
var requiresPrefixDashCased = Object.keys(requiresPrefix).map(function (property) { | |
return (0, _utilsCamelToDashCase2['default'])(property); | |
}); | |
var newValue = value; | |
// only split multi values, not cubic beziers | |
var multipleValues = newValue.split(/,(?![^()]*(?:\([^()]*\))?\))/g); | |
requiresPrefixDashCased.forEach(function (property) { | |
multipleValues.forEach(function (val, index) { | |
if (val.indexOf(property) > -1) { | |
var newVal = forceRun ? | |
// prefix all | |
['-webkit-', '-moz-', '-ms-'].map(function (prefix) { | |
return val.replace(property, prefix + property); | |
}).join(',') : | |
// default | |
val.replace(property, prefix.css + property); | |
multipleValues[index] = newVal + (keepUnprefixed ? ',' + val : ''); | |
} | |
}); | |
}); | |
var outputValue = multipleValues.join(','); | |
if (forceRun) { | |
return { | |
v: (_ref = {}, _defineProperty(_ref, 'Webkit' + (0, _utilsCapitalizeString2['default'])(property), outputValue), _defineProperty(_ref, 'Moz' + (0, _utilsCapitalizeString2['default'])(property), outputValue), _defineProperty(_ref, 'ms' + (0, _utilsCapitalizeString2['default'])(property), outputValue), _defineProperty(_ref, property, outputValue), _ref) | |
}; | |
} | |
return { | |
v: _defineProperty({}, property, outputValue) | |
}; | |
})(); | |
if (typeof _ret === 'object') return _ret.v; | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 23 */ | |
/***/ function(module, exports) { | |
/** | |
* Converts a camel-case string to a dash-case string | |
* @param {string} str - str that gets converted to dash-case | |
*/ | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
exports['default'] = function (str) { | |
return str.replace(/([a-z]|^)([A-Z])/g, function (match, p1, p2) { | |
return p1 + '-' + p2.toLowerCase(); | |
}).replace('ms-', '-ms-'); | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 24 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
var _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; }; | |
exports['default'] = flexboxIE; | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
var alternativeValues = { | |
'space-around': 'distribute', | |
'space-between': 'justify', | |
'flex-start': 'start', | |
'flex-end': 'end', | |
flex: '-ms-flexbox', | |
'inline-flex': '-ms-inline-flexbox' | |
}; | |
var alternativeProps = { | |
alignContent: 'msFlexLinePack', | |
alignSelf: 'msFlexItemAlign', | |
alignItems: 'msFlexAlign', | |
justifyContent: 'msFlexPack', | |
order: 'msFlexOrder', | |
flexGrow: 'msFlexPositive', | |
flexShrink: 'msFlexNegative', | |
flexBasis: 'msPreferredSize' | |
}; | |
var properties = Object.keys(alternativeProps).concat('display').reduce(function (result, prop) { | |
return _extends({}, result, _defineProperty({}, prop, true)); | |
}, {}); | |
function flexboxIE(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var styles = pluginInterface.styles; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (properties[property] && (forceRun || (browser === 'ie_mob' || browser === 'ie') && version == 10)) { | |
if (!keepUnprefixed) { | |
delete styles[property]; | |
} | |
if (alternativeProps[property]) { | |
return _defineProperty({}, alternativeProps[property], alternativeValues[value] || value); | |
} | |
if (alternativeValues[value]) { | |
return _defineProperty({}, property, alternativeValues[value] + (keepUnprefixed ? ';' + property + ':' + value : '')); | |
} | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 25 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, '__esModule', { | |
value: true | |
}); | |
var _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; }; | |
exports['default'] = flexboxOld; | |
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } | |
var alternativeValues = { | |
'space-around': 'justify', | |
'space-between': 'justify', | |
'flex-start': 'start', | |
'flex-end': 'end', | |
'wrap-reverse': 'multiple', | |
wrap: 'multiple', | |
flex: 'box', | |
'inline-flex': 'inline-box' | |
}; | |
var alternativeProps = { | |
alignItems: 'WebkitBoxAlign', | |
justifyContent: 'WebkitBoxPack', | |
flexWrap: 'WebkitBoxLines' | |
}; | |
var properties = Object.keys(alternativeProps).concat(['alignContent', 'alignSelf', 'display', 'order', 'flexGrow', 'flexShrink', 'flexBasis', 'flexDirection']).reduce(function (result, prop) { | |
return _extends({}, result, _defineProperty({}, prop, true)); | |
}, {}); | |
function flexboxOld(pluginInterface) { | |
var property = pluginInterface.property; | |
var value = pluginInterface.value; | |
var styles = pluginInterface.styles; | |
var browserInfo = pluginInterface.browserInfo; | |
var prefix = pluginInterface.prefix; | |
var keepUnprefixed = pluginInterface.keepUnprefixed; | |
var forceRun = pluginInterface.forceRun; | |
var browser = browserInfo.browser; | |
var version = browserInfo.version; | |
if (properties[property] && (forceRun || browser === 'firefox' && version < 22 || browser === 'chrome' && version < 21 || (browser === 'safari' || browser === 'ios_saf') && version <= 6.1 || browser === 'android' && version < 4.4 || browser === 'and_uc')) { | |
if (!keepUnprefixed) { | |
delete styles[property]; | |
} | |
if (property === 'flexDirection') { | |
return { | |
WebkitBoxOrient: value.indexOf('column') > -1 ? 'vertical' : 'horizontal', | |
WebkitBoxDirection: value.indexOf('reverse') > -1 ? 'reverse' : 'normal' | |
}; | |
} | |
if (property === 'display' && alternativeValues[value]) { | |
return { | |
display: prefix.css + alternativeValues[value] + (keepUnprefixed ? ';' + property + ':' + value : '') | |
}; | |
} | |
if (alternativeProps[property]) { | |
return _defineProperty({}, alternativeProps[property], alternativeValues[value] || value); | |
} | |
if (alternativeValues[value]) { | |
return _defineProperty({}, property, alternativeValues[value] + (keepUnprefixed ? ';' + property + ':' + value : '')); | |
} | |
} | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 26 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
*/ | |
'use strict'; | |
/** | |
* Similar to invariant but only logs a warning if the condition is not met. | |
* This can be used to log issues in development environments in critical | |
* paths. Removing the logging code for production environments will keep the | |
* same logic and follow the same code paths. | |
*/ | |
var warning = function() {}; | |
if (process.env.NODE_ENV !== 'production') { | |
warning = function(condition, format, args) { | |
var len = arguments.length; | |
args = new Array(len > 2 ? len - 2 : 0); | |
for (var key = 2; key < len; key++) { | |
args[key - 2] = arguments[key]; | |
} | |
if (format === undefined) { | |
throw new Error( | |
'`warning(condition, format, ...args)` requires a warning ' + | |
'message argument' | |
); | |
} | |
if (format.length < 10 || (/^[s\W]*$/).test(format)) { | |
throw new Error( | |
'The warning format should be able to uniquely identify this ' + | |
'warning. Please, use a more descriptive format than: ' + format | |
); | |
} | |
if (!condition) { | |
var argIndex = 0; | |
var message = 'Warning: ' + | |
format.replace(/%s/g, function() { | |
return args[argIndex++]; | |
}); | |
if (typeof console !== 'undefined') { | |
console.error(message); | |
} | |
try { | |
// This error was thrown as a convenience so that you can use this stack | |
// to find the callsite that caused this warning to fire. | |
throw new Error(message); | |
} catch(x) {} | |
} | |
}; | |
} | |
module.exports = warning; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 27 */ | |
/***/ function(module, exports, __webpack_require__) { | |
module.exports = __webpack_require__(28); | |
/***/ }, | |
/* 28 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule update | |
*/ | |
/* global hasOwnProperty:true */ | |
'use strict'; | |
var assign = __webpack_require__(29); | |
var keyOf = __webpack_require__(30); | |
var invariant = __webpack_require__(31); | |
var hasOwnProperty = ({}).hasOwnProperty; | |
function shallowCopy(x) { | |
if (Array.isArray(x)) { | |
return x.concat(); | |
} else if (x && typeof x === 'object') { | |
return assign(new x.constructor(), x); | |
} else { | |
return x; | |
} | |
} | |
var COMMAND_PUSH = keyOf({ $push: null }); | |
var COMMAND_UNSHIFT = keyOf({ $unshift: null }); | |
var COMMAND_SPLICE = keyOf({ $splice: null }); | |
var COMMAND_SET = keyOf({ $set: null }); | |
var COMMAND_MERGE = keyOf({ $merge: null }); | |
var COMMAND_APPLY = keyOf({ $apply: null }); | |
var ALL_COMMANDS_LIST = [COMMAND_PUSH, COMMAND_UNSHIFT, COMMAND_SPLICE, COMMAND_SET, COMMAND_MERGE, COMMAND_APPLY]; | |
var ALL_COMMANDS_SET = {}; | |
ALL_COMMANDS_LIST.forEach(function (command) { | |
ALL_COMMANDS_SET[command] = true; | |
}); | |
function invariantArrayCase(value, spec, command) { | |
!Array.isArray(value) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): expected target of %s to be an array; got %s.', command, value) : invariant(false) : undefined; | |
var specValue = spec[command]; | |
!Array.isArray(specValue) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): expected spec of %s to be an array; got %s. ' + 'Did you forget to wrap your parameter in an array?', command, specValue) : invariant(false) : undefined; | |
} | |
function update(value, spec) { | |
!(typeof spec === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): You provided a key path to update() that did not contain one ' + 'of %s. Did you forget to include {%s: ...}?', ALL_COMMANDS_LIST.join(', '), COMMAND_SET) : invariant(false) : undefined; | |
if (hasOwnProperty.call(spec, COMMAND_SET)) { | |
!(Object.keys(spec).length === 1) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Cannot have more than one key in an object with %s', COMMAND_SET) : invariant(false) : undefined; | |
return spec[COMMAND_SET]; | |
} | |
var nextValue = shallowCopy(value); | |
if (hasOwnProperty.call(spec, COMMAND_MERGE)) { | |
var mergeObj = spec[COMMAND_MERGE]; | |
!(mergeObj && typeof mergeObj === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): %s expects a spec of type \'object\'; got %s', COMMAND_MERGE, mergeObj) : invariant(false) : undefined; | |
!(nextValue && typeof nextValue === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): %s expects a target of type \'object\'; got %s', COMMAND_MERGE, nextValue) : invariant(false) : undefined; | |
assign(nextValue, spec[COMMAND_MERGE]); | |
} | |
if (hasOwnProperty.call(spec, COMMAND_PUSH)) { | |
invariantArrayCase(value, spec, COMMAND_PUSH); | |
spec[COMMAND_PUSH].forEach(function (item) { | |
nextValue.push(item); | |
}); | |
} | |
if (hasOwnProperty.call(spec, COMMAND_UNSHIFT)) { | |
invariantArrayCase(value, spec, COMMAND_UNSHIFT); | |
spec[COMMAND_UNSHIFT].forEach(function (item) { | |
nextValue.unshift(item); | |
}); | |
} | |
if (hasOwnProperty.call(spec, COMMAND_SPLICE)) { | |
!Array.isArray(value) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected %s target to be an array; got %s', COMMAND_SPLICE, value) : invariant(false) : undefined; | |
!Array.isArray(spec[COMMAND_SPLICE]) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): expected spec of %s to be an array of arrays; got %s. ' + 'Did you forget to wrap your parameters in an array?', COMMAND_SPLICE, spec[COMMAND_SPLICE]) : invariant(false) : undefined; | |
spec[COMMAND_SPLICE].forEach(function (args) { | |
!Array.isArray(args) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): expected spec of %s to be an array of arrays; got %s. ' + 'Did you forget to wrap your parameters in an array?', COMMAND_SPLICE, spec[COMMAND_SPLICE]) : invariant(false) : undefined; | |
nextValue.splice.apply(nextValue, args); | |
}); | |
} | |
if (hasOwnProperty.call(spec, COMMAND_APPLY)) { | |
!(typeof spec[COMMAND_APPLY] === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'update(): expected spec of %s to be a function; got %s.', COMMAND_APPLY, spec[COMMAND_APPLY]) : invariant(false) : undefined; | |
nextValue = spec[COMMAND_APPLY](nextValue); | |
} | |
for (var k in spec) { | |
if (!(ALL_COMMANDS_SET.hasOwnProperty(k) && ALL_COMMANDS_SET[k])) { | |
nextValue[k] = update(value[k], spec[k]); | |
} | |
} | |
return nextValue; | |
} | |
module.exports = update; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 29 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule Object.assign | |
*/ | |
// https://people.mozilla.org/~jorendorff/es6-draft.html#sec-object.assign | |
'use strict'; | |
function assign(target, sources) { | |
if (target == null) { | |
throw new TypeError('Object.assign target cannot be null or undefined'); | |
} | |
var to = Object(target); | |
var hasOwnProperty = Object.prototype.hasOwnProperty; | |
for (var nextIndex = 1; nextIndex < arguments.length; nextIndex++) { | |
var nextSource = arguments[nextIndex]; | |
if (nextSource == null) { | |
continue; | |
} | |
var from = Object(nextSource); | |
// We don't currently support accessors nor proxies. Therefore this | |
// copy cannot throw. If we ever supported this then we must handle | |
// exceptions and side-effects. We don't support symbols so they won't | |
// be transferred. | |
for (var key in from) { | |
if (hasOwnProperty.call(from, key)) { | |
to[key] = from[key]; | |
} | |
} | |
} | |
return to; | |
} | |
module.exports = assign; | |
/***/ }, | |
/* 30 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule keyOf | |
*/ | |
/** | |
* Allows extraction of a minified key. Let's the build system minify keys | |
* without losing the ability to dynamically use key strings as values | |
* themselves. Pass in an object with a single key/val pair and it will return | |
* you the string key of that single record. Suppose you want to grab the | |
* value for a key 'className' inside of an object. Key/val minification may | |
* have aliased that key to be 'xa12'. keyOf({className: null}) will return | |
* 'xa12' in that case. Resolve keys you want to use once at startup time, then | |
* reuse those resolutions. | |
*/ | |
"use strict"; | |
var keyOf = function (oneKeyObj) { | |
var key; | |
for (key in oneKeyObj) { | |
if (!oneKeyObj.hasOwnProperty(key)) { | |
continue; | |
} | |
return key; | |
} | |
return null; | |
}; | |
module.exports = keyOf; | |
/***/ }, | |
/* 31 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule invariant | |
*/ | |
'use strict'; | |
/** | |
* Use invariant() to assert state which your program assumes to be true. | |
* | |
* Provide sprintf-style format (only %s is supported) and arguments | |
* to provide information about what broke and what you were | |
* expecting. | |
* | |
* The invariant message will be stripped in production, but the invariant | |
* will remain to ensure logic does not differ in production. | |
*/ | |
function invariant(condition, format, a, b, c, d, e, f) { | |
if (process.env.NODE_ENV !== 'production') { | |
if (format === undefined) { | |
throw new Error('invariant requires an error message argument'); | |
} | |
} | |
if (!condition) { | |
var error; | |
if (format === undefined) { | |
error = new Error('Minified exception occurred; use the non-minified dev environment ' + 'for the full error message and additional helpful warnings.'); | |
} else { | |
var args = [a, b, c, d, e, f]; | |
var argIndex = 0; | |
error = new Error(format.replace(/%s/g, function () { | |
return args[argIndex++]; | |
})); | |
error.name = 'Invariant Violation'; | |
} | |
error.framesToPop = 1; // we don't care about invariant's own frame | |
throw error; | |
} | |
} | |
module.exports = invariant; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 32 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _events = __webpack_require__(33); | |
var _events2 = _interopRequireDefault(_events); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
exports.default = { | |
componentDidMount: function componentDidMount() { | |
var listeners = this.windowListeners; | |
for (var eventName in listeners) { | |
var callbackName = listeners[eventName]; | |
_events2.default.on(window, eventName, this[callbackName]); | |
} | |
}, | |
componentWillUnmount: function componentWillUnmount() { | |
var listeners = this.windowListeners; | |
for (var eventName in listeners) { | |
var callbackName = listeners[eventName]; | |
_events2.default.off(window, eventName, this[callbackName]); | |
} | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 33 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
once: function once(el, type, callback) { | |
var typeArray = type ? type.split(' ') : []; | |
var recursiveFunction = function recursiveFunction(e) { | |
e.target.removeEventListener(e.type, recursiveFunction); | |
return callback(e); | |
}; | |
for (var i = typeArray.length - 1; i >= 0; i--) { | |
this.on(el, typeArray[i], recursiveFunction); | |
} | |
}, | |
on: function on(el, type, callback) { | |
if (el.addEventListener) { | |
el.addEventListener(type, callback); | |
} else { | |
// IE8+ Support | |
el.attachEvent('on' + type, function () { | |
callback.call(el); | |
}); | |
} | |
}, | |
off: function off(el, type, callback) { | |
if (el.removeEventListener) { | |
el.removeEventListener(type, callback); | |
} else { | |
// IE8+ Support | |
el.detachEvent('on' + type, callback); | |
} | |
}, | |
isKeyboard: function isKeyboard(e) { | |
return ['keydown', 'keypress', 'keyup'].indexOf(e.type) !== -1; | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 34 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _windowListenable = __webpack_require__(32); | |
var _windowListenable2 = _interopRequireDefault(_windowListenable); | |
var _keyCode = __webpack_require__(35); | |
var _keyCode2 = _interopRequireDefault(_keyCode); | |
var _clock = __webpack_require__(36); | |
var _clock2 = _interopRequireDefault(_clock); | |
var _dialog = __webpack_require__(207); | |
var _dialog2 = _interopRequireDefault(_dialog); | |
var _flatButton = __webpack_require__(209); | |
var _flatButton2 = _interopRequireDefault(_flatButton); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var TimePickerDialog = _react2.default.createClass({ | |
displayName: 'TimePickerDialog', | |
propTypes: { | |
autoOk: _react2.default.PropTypes.bool, | |
format: _react2.default.PropTypes.oneOf(['ampm', '24hr']), | |
initialTime: _react2.default.PropTypes.object, | |
onAccept: _react2.default.PropTypes.func, | |
onDismiss: _react2.default.PropTypes.func, | |
onShow: _react2.default.PropTypes.func, | |
wordings: _react2.default.PropTypes.object | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default, _windowListenable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
wordings: { | |
ok: 'OK', | |
cancel: 'Cancel' | |
} | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
open: false, | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
windowListeners: { | |
keyup: '_handleWindowKeyUp' | |
}, | |
getTheme: function getTheme() { | |
return this.state.muiTheme.timePicker; | |
}, | |
show: function show() { | |
if (this.props.onShow && !this.state.open) this.props.onShow(); | |
this.setState({ | |
open: true | |
}); | |
}, | |
dismiss: function dismiss() { | |
if (this.props.onDismiss && this.state.open) this.props.onDismiss(); | |
this.setState({ | |
open: false | |
}); | |
}, | |
_handleOKTouchTap: function _handleOKTouchTap() { | |
this.dismiss(); | |
if (this.props.onAccept) { | |
this.props.onAccept(this.refs.clock.getSelectedTime()); | |
} | |
}, | |
_handleWindowKeyUp: function _handleWindowKeyUp(event) { | |
if (this.state.open) { | |
switch (event.keyCode) { | |
case _keyCode2.default.ENTER: | |
this._handleOKTouchTap(); | |
break; | |
} | |
} | |
}, | |
render: function render() { | |
var _props = this.props; | |
var initialTime = _props.initialTime; | |
var onAccept = _props.onAccept; | |
var format = _props.format; | |
var autoOk = _props.autoOk; | |
var wordings = _props.wordings; | |
var other = _objectWithoutProperties(_props, ['initialTime', 'onAccept', 'format', 'autoOk', 'wordings']); | |
var styles = { | |
root: { | |
fontSize: 14, | |
color: this.getTheme().clockColor | |
}, | |
dialogContent: { | |
width: 280 | |
}, | |
body: { | |
padding: 0 | |
} | |
}; | |
var actions = [_react2.default.createElement(_flatButton2.default, { | |
key: 0, | |
label: wordings.cancel, | |
secondary: true, | |
onTouchTap: this.dismiss | |
})]; | |
if (!autoOk) { | |
actions.push(_react2.default.createElement(_flatButton2.default, { | |
key: 1, | |
label: wordings.ok, | |
secondary: true, | |
onTouchTap: this._handleOKTouchTap | |
})); | |
} | |
var onClockChangeMinutes = autoOk === true ? this._handleOKTouchTap : undefined; | |
return _react2.default.createElement( | |
_dialog2.default, | |
_extends({}, other, { | |
ref: 'dialogWindow', | |
style: this.mergeStyles(styles.root), | |
bodyStyle: styles.body, | |
actions: actions, | |
contentStyle: styles.dialogContent, | |
repositionOnUpdate: false, | |
open: this.state.open, | |
onRequestClose: this.dismiss | |
}), | |
_react2.default.createElement(_clock2.default, { | |
ref: 'clock', | |
format: format, | |
initialTime: initialTime, | |
onChangeMinutes: onClockChangeMinutes | |
}) | |
); | |
} | |
}); | |
exports.default = TimePickerDialog; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 35 */ | |
/***/ function(module, exports) { | |
"use strict"; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
DOWN: 40, | |
ESC: 27, | |
ENTER: 13, | |
LEFT: 37, | |
RIGHT: 39, | |
SPACE: 32, | |
TAB: 9, | |
UP: 38 | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 36 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _timeDisplay = __webpack_require__(37); | |
var _timeDisplay2 = _interopRequireDefault(_timeDisplay); | |
var _clockHours = __webpack_require__(61); | |
var _clockHours2 = _interopRequireDefault(_clockHours); | |
var _clockMinutes = __webpack_require__(206); | |
var _clockMinutes2 = _interopRequireDefault(_clockMinutes); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var Clock = _react2.default.createClass({ | |
displayName: 'Clock', | |
propTypes: { | |
format: _react2.default.PropTypes.oneOf(['ampm', '24hr']), | |
initialTime: _react2.default.PropTypes.object, | |
isActive: _react2.default.PropTypes.bool, | |
mode: _react2.default.PropTypes.oneOf(['hour', 'minute']), | |
onChangeHours: _react2.default.PropTypes.func, | |
onChangeMinutes: _react2.default.PropTypes.func | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
initialTime: new Date() | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)(), | |
selectedTime: this.props.initialTime, | |
mode: 'hour' | |
}; | |
}, | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ | |
muiTheme: newMuiTheme, | |
selectedTime: nextProps.initialTime | |
}); | |
}, | |
_setMode: function _setMode(mode) { | |
var _this = this; | |
setTimeout(function () { | |
_this.setState({ | |
mode: mode | |
}); | |
}, 100); | |
}, | |
_setAffix: function _setAffix(affix) { | |
if (affix === this._getAffix()) return; | |
var hours = this.state.selectedTime.getHours(); | |
if (affix === 'am') { | |
this.handleChangeHours(hours - 12, affix); | |
return; | |
} | |
this.handleChangeHours(hours + 12, affix); | |
}, | |
_getAffix: function _getAffix() { | |
if (this.props.format !== 'ampm') return ''; | |
var hours = this.state.selectedTime.getHours(); | |
if (hours < 12) { | |
return 'am'; | |
} | |
return 'pm'; | |
}, | |
handleChangeHours: function handleChangeHours(hours, finished) { | |
var _this2 = this; | |
var time = new Date(this.state.selectedTime); | |
var affix = undefined; | |
if (typeof finished === 'string') { | |
affix = finished; | |
finished = undefined; | |
} | |
if (!affix) { | |
affix = this._getAffix(); | |
} | |
if (affix === 'pm' && hours < 12) { | |
hours += 12; | |
} | |
time.setHours(hours); | |
this.setState({ | |
selectedTime: time | |
}); | |
var onChangeHours = this.props.onChangeHours; | |
if (finished) { | |
setTimeout(function () { | |
_this2.setState({ | |
mode: 'minute' | |
}); | |
if (typeof onChangeHours === 'function') { | |
onChangeHours(time); | |
} | |
}, 100); | |
} | |
}, | |
handleChangeMinutes: function handleChangeMinutes(minutes) { | |
var time = new Date(this.state.selectedTime); | |
time.setMinutes(minutes); | |
this.setState({ | |
selectedTime: time | |
}); | |
var onChangeMinutes = this.props.onChangeMinutes; | |
if (typeof onChangeMinutes === 'function') { | |
setTimeout(function () { | |
onChangeMinutes(time); | |
}, 0); | |
} | |
}, | |
getSelectedTime: function getSelectedTime() { | |
return this.state.selectedTime; | |
}, | |
render: function render() { | |
var clock = null; | |
var styles = { | |
root: {}, | |
container: { | |
height: 280, | |
padding: 10, | |
position: 'relative' | |
}, | |
circle: { | |
position: 'absolute', | |
top: 20, | |
width: 260, | |
height: 260, | |
borderRadius: '100%', | |
backgroundColor: this.state.muiTheme.timePicker.clockCircleColor | |
} | |
}; | |
if (this.state.mode === 'hour') { | |
clock = _react2.default.createElement(_clockHours2.default, { key: 'hours', | |
format: this.props.format, | |
onChange: this.handleChangeHours, | |
initialHours: this.state.selectedTime.getHours() | |
}); | |
} else { | |
clock = _react2.default.createElement(_clockMinutes2.default, { key: 'minutes', | |
onChange: this.handleChangeMinutes, | |
initialMinutes: this.state.selectedTime.getMinutes() | |
}); | |
} | |
return _react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.root) }, | |
_react2.default.createElement(_timeDisplay2.default, { | |
selectedTime: this.state.selectedTime, | |
mode: this.state.mode, | |
format: this.props.format, | |
affix: this._getAffix(), | |
onSelectAffix: this._setAffix, | |
onSelectHour: this._setMode.bind(this, 'hour'), | |
onSelectMin: this._setMode.bind(this, 'minute') | |
}), | |
_react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.container) }, | |
_react2.default.createElement('div', { style: this.prepareStyles(styles.circle) }), | |
clock | |
) | |
); | |
} | |
}); | |
exports.default = Clock; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 37 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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 _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var TimeDisplay = _react2.default.createClass({ | |
displayName: 'TimeDisplay', | |
propTypes: { | |
affix: _react2.default.PropTypes.oneOf(['', 'pm', 'am']), | |
format: _react2.default.PropTypes.oneOf(['ampm', '24hr']), | |
mode: _react2.default.PropTypes.oneOf(['hour', 'minute']), | |
onSelectAffix: _react2.default.PropTypes.func, | |
onSelectHour: _react2.default.PropTypes.func, | |
onSelectMin: _react2.default.PropTypes.func, | |
selectedTime: _react2.default.PropTypes.object.isRequired | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
mode: 'hour', | |
affix: '' | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
transitionDirection: 'up', | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var direction = undefined; | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
if (nextProps.selectedTime !== this.props.selectedTime) { | |
direction = nextProps.selectedTime > this.props.selectedTime ? 'up' : 'down'; | |
this.setState({ | |
transitionDirection: direction | |
}); | |
} | |
}, | |
sanitizeTime: function sanitizeTime() { | |
var hour = this.props.selectedTime.getHours(); | |
var min = this.props.selectedTime.getMinutes().toString(); | |
if (this.props.format === 'ampm') { | |
hour %= 12; | |
hour = hour || 12; | |
} | |
hour = hour.toString(); | |
if (hour.length < 2) hour = '0' + hour; | |
if (min.length < 2) min = '0' + min; | |
return [hour, min]; | |
}, | |
getTheme: function getTheme() { | |
return this.state.muiTheme.timePicker; | |
}, | |
render: function render() { | |
var _this = this; | |
var _props = this.props; | |
var selectedTime = _props.selectedTime; | |
var mode = _props.mode; | |
var affix = _props.affix; | |
var other = _objectWithoutProperties(_props, ['selectedTime', 'mode', 'affix']); | |
var styles = { | |
root: { | |
position: 'relative', | |
width: 280, | |
height: '100%' | |
}, | |
box: { | |
padding: '14px 0', | |
borderTopLeftRadius: 2, | |
borderTopRightRadius: 2, | |
backgroundColor: this.getTheme().headerColor, | |
color: 'white' | |
}, | |
text: { | |
margin: '6px 0', | |
lineHeight: '58px', | |
height: 58, | |
fontSize: 58, | |
display: 'flex', | |
justifyContent: 'center', | |
alignItems: 'baseline' | |
}, | |
time: { | |
margin: '0 10px' | |
}, | |
affix: { | |
flex: 1, | |
position: 'relative', | |
lineHeight: '17px', | |
height: 17, | |
fontSize: 17 | |
}, | |
affixTop: { | |
position: 'absolute', | |
top: -20, | |
left: 0 | |
}, | |
clickable: { | |
cursor: 'pointer' | |
}, | |
inactive: { | |
opacity: 0.7 | |
} | |
}; | |
var _sanitizeTime = this.sanitizeTime(); | |
var _sanitizeTime2 = _slicedToArray(_sanitizeTime, 2); | |
var hour = _sanitizeTime2[0]; | |
var min = _sanitizeTime2[1]; | |
var buttons = []; | |
if (this.props.format === 'ampm') { | |
buttons = [_react2.default.createElement( | |
'div', | |
{ | |
key: 'pm', | |
style: this.prepareStyles(styles.clickable, affix === 'pm' ? {} : styles.inactive), | |
onTouchTap: function onTouchTap() { | |
return _this.props.onSelectAffix('pm'); | |
} | |
}, | |
"PM" | |
), _react2.default.createElement( | |
'div', | |
{ | |
key: 'am', | |
style: this.prepareStyles(styles.affixTop, styles.clickable, affix === 'am' ? {} : styles.inactive), | |
onTouchTap: function onTouchTap() { | |
return _this.props.onSelectAffix('am'); | |
} | |
}, | |
"AM" | |
)]; | |
} | |
return _react2.default.createElement( | |
'div', | |
_extends({}, other, { style: this.prepareStyles(styles.root) }), | |
_react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.box) }, | |
_react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.text) }, | |
_react2.default.createElement('div', { style: this.prepareStyles(styles.affix) }), | |
_react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.time) }, | |
_react2.default.createElement( | |
'span', | |
{ | |
style: this.prepareStyles(styles.clickable, mode === 'hour' ? {} : styles.inactive), | |
onTouchTap: this.props.onSelectHour | |
}, | |
hour | |
), | |
_react2.default.createElement( | |
'span', | |
null, | |
':' | |
), | |
_react2.default.createElement( | |
'span', | |
{ | |
style: this.prepareStyles(styles.clickable, mode === 'minute' ? {} : styles.inactive), | |
onTouchTap: this.props.onSelectMin | |
}, | |
min | |
) | |
), | |
_react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.affix) }, | |
buttons | |
) | |
) | |
) | |
); | |
} | |
}); | |
exports.default = TimeDisplay; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 38 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = getMuiTheme; | |
var _lodash = __webpack_require__(39); | |
var _lodash2 = _interopRequireDefault(_lodash); | |
var _colors = __webpack_require__(56); | |
var _colors2 = _interopRequireDefault(_colors); | |
var _colorManipulator = __webpack_require__(57); | |
var _colorManipulator2 = _interopRequireDefault(_colorManipulator); | |
var _autoPrefix = __webpack_require__(7); | |
var _autoPrefix2 = _interopRequireDefault(_autoPrefix); | |
var _lightBaseTheme = __webpack_require__(58); | |
var _lightBaseTheme2 = _interopRequireDefault(_lightBaseTheme); | |
var _zIndex = __webpack_require__(60); | |
var _zIndex2 = _interopRequireDefault(_zIndex); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
/** | |
* Get the MUI theme corresponding to a base theme. | |
* It's possible to override the computed theme values | |
* by providing a second argument. The calculated | |
* theme will be deeply merged with the second argument. | |
*/ | |
function getMuiTheme(baseTheme, muiTheme) { | |
baseTheme = (0, _lodash2.default)({}, _lightBaseTheme2.default, baseTheme); | |
var _baseTheme = baseTheme; | |
var palette = _baseTheme.palette; | |
var spacing = _baseTheme.spacing; | |
muiTheme = (0, _lodash2.default)({ | |
isRtl: false, | |
userAgent: undefined, | |
zIndex: _zIndex2.default, | |
baseTheme: baseTheme, | |
rawTheme: baseTheme, // To provide backward compatibility. | |
appBar: { | |
color: palette.primary1Color, | |
textColor: palette.alternateTextColor, | |
height: spacing.desktopKeylineIncrement | |
}, | |
avatar: { | |
borderColor: 'rgba(0, 0, 0, 0.08)' | |
}, | |
badge: { | |
color: palette.alternateTextColor, | |
textColor: palette.textColor, | |
primaryColor: palette.accent1Color, | |
primaryTextColor: palette.alternateTextColor, | |
secondaryColor: palette.primary1Color, | |
secondaryTextColor: palette.alternateTextColor | |
}, | |
button: { | |
height: 36, | |
minWidth: 88, | |
iconButtonSize: spacing.iconSize * 2 | |
}, | |
cardText: { | |
textColor: palette.textColor | |
}, | |
checkbox: { | |
boxColor: palette.textColor, | |
checkedColor: palette.primary1Color, | |
requiredColor: palette.primary1Color, | |
disabledColor: palette.disabledColor, | |
labelColor: palette.textColor, | |
labelDisabledColor: palette.disabledColor | |
}, | |
datePicker: { | |
color: palette.primary1Color, | |
textColor: palette.alternateTextColor, | |
calendarTextColor: palette.textColor, | |
selectColor: palette.primary2Color, | |
selectTextColor: palette.alternateTextColor | |
}, | |
dropDownMenu: { | |
accentColor: palette.borderColor | |
}, | |
flatButton: { | |
color: _colors2.default.transparent, | |
buttonFilterColor: '#999999', | |
disabledTextColor: _colorManipulator2.default.fade(palette.textColor, 0.3), | |
textColor: palette.textColor, | |
primaryTextColor: palette.accent1Color, | |
secondaryTextColor: palette.primary1Color | |
}, | |
floatingActionButton: { | |
buttonSize: 56, | |
miniSize: 40, | |
color: palette.accent1Color, | |
iconColor: palette.alternateTextColor, | |
secondaryColor: palette.primary1Color, | |
secondaryIconColor: palette.alternateTextColor, | |
disabledTextColor: palette.disabledColor | |
}, | |
gridTile: { | |
textColor: _colors2.default.white | |
}, | |
inkBar: { | |
backgroundColor: palette.accent1Color | |
}, | |
leftNav: { | |
width: spacing.desktopKeylineIncrement * 4, | |
color: palette.canvasColor | |
}, | |
listItem: { | |
nestedLevelDepth: 18 | |
}, | |
menu: { | |
backgroundColor: palette.canvasColor, | |
containerBackgroundColor: palette.canvasColor | |
}, | |
menuItem: { | |
dataHeight: 32, | |
height: 48, | |
hoverColor: 'rgba(0, 0, 0, .035)', | |
padding: spacing.desktopGutter, | |
selectedTextColor: palette.accent1Color | |
}, | |
menuSubheader: { | |
padding: spacing.desktopGutter, | |
borderColor: palette.borderColor, | |
textColor: palette.primary1Color | |
}, | |
paper: { | |
backgroundColor: palette.canvasColor, | |
zDepthShadows: [[1, 6, 0.12, 1, 4, 0.12], [3, 10, 0.16, 3, 10, 0.23], [10, 30, 0.19, 6, 10, 0.23], [14, 45, 0.25, 10, 18, 0.22], [19, 60, 0.30, 15, 20, 0.22]].map(function (d) { | |
return '0 ' + d[0] + 'px ' + d[1] + 'px ' + _colorManipulator2.default.fade(palette.shadowColor, d[2]) + ', | |
0 ' + d[3] + 'px ' + d[4] + 'px ' + _colorManipulator2.default.fade(palette.shadowColor, d[5]); | |
}) | |
}, | |
radioButton: { | |
borderColor: palette.textColor, | |
backgroundColor: palette.alternateTextColor, | |
checkedColor: palette.primary1Color, | |
requiredColor: palette.primary1Color, | |
disabledColor: palette.disabledColor, | |
size: 24, | |
labelColor: palette.textColor, | |
labelDisabledColor: palette.disabledColor | |
}, | |
raisedButton: { | |
color: palette.alternateTextColor, | |
textColor: palette.textColor, | |
primaryColor: palette.accent1Color, | |
primaryTextColor: palette.alternateTextColor, | |
secondaryColor: palette.primary1Color, | |
secondaryTextColor: palette.alternateTextColor, | |
disabledColor: _colorManipulator2.default.darken(palette.alternateTextColor, 0.1), | |
disabledTextColor: _colorManipulator2.default.fade(palette.textColor, 0.3) | |
}, | |
refreshIndicator: { | |
strokeColor: palette.borderColor, | |
loadingStrokeColor: palette.primary1Color | |
}, | |
slider: { | |
trackSize: 2, | |
trackColor: palette.primary3Color, | |
trackColorSelected: palette.accent3Color, | |
handleSize: 12, | |
handleSizeDisabled: 8, | |
handleSizeActive: 18, | |
handleColorZero: palette.primary3Color, | |
handleFillColor: palette.alternateTextColor, | |
selectionColor: palette.primary1Color, | |
rippleColor: palette.primary1Color | |
}, | |
snackbar: { | |
textColor: palette.alternateTextColor, | |
backgroundColor: palette.textColor, | |
actionColor: palette.accent1Color | |
}, | |
table: { | |
backgroundColor: palette.canvasColor | |
}, | |
tableHeader: { | |
borderColor: palette.borderColor | |
}, | |
tableHeaderColumn: { | |
textColor: palette.accent3Color, | |
height: 56, | |
spacing: 24 | |
}, | |
tableFooter: { | |
borderColor: palette.borderColor, | |
textColor: palette.accent3Color | |
}, | |
tableRow: { | |
hoverColor: palette.accent2Color, | |
stripeColor: _colorManipulator2.default.lighten(palette.primary1Color, 0.55), | |
selectedColor: palette.borderColor, | |
textColor: palette.textColor, | |
borderColor: palette.borderColor, | |
height: 48 | |
}, | |
tableRowColumn: { | |
height: 48, | |
spacing: 24 | |
}, | |
timePicker: { | |
color: palette.alternateTextColor, | |
textColor: palette.accent3Color, | |
accentColor: palette.primary1Color, | |
clockColor: palette.textColor, | |
clockCircleColor: palette.clockCircleColor, | |
headerColor: palette.pickerHeaderColor || palette.primary1Color, | |
selectColor: palette.primary2Color, | |
selectTextColor: palette.alternateTextColor | |
}, | |
toggle: { | |
thumbOnColor: palette.primary1Color, | |
thumbOffColor: palette.accent2Color, | |
thumbDisabledColor: palette.borderColor, | |
thumbRequiredColor: palette.primary1Color, | |
trackOnColor: _colorManipulator2.default.fade(palette.primary1Color, 0.5), | |
trackOffColor: palette.primary3Color, | |
trackDisabledColor: palette.primary3Color, | |
labelColor: palette.textColor, | |
labelDisabledColor: palette.disabledColor, | |
trackRequiredColor: _colorManipulator2.default.fade(palette.primary1Color, 0.5) | |
}, | |
toolbar: { | |
backgroundColor: _colorManipulator2.default.darken(palette.accent2Color, 0.05), | |
height: 56, | |
titleFontSize: 20, | |
iconColor: 'rgba(0, 0, 0, .40)', | |
separatorColor: 'rgba(0, 0, 0, .175)', | |
menuHoverColor: 'rgba(0, 0, 0, .10)' | |
}, | |
tabs: { | |
backgroundColor: palette.primary1Color, | |
textColor: _colorManipulator2.default.fade(palette.alternateTextColor, 0.6), | |
selectedTextColor: palette.alternateTextColor | |
}, | |
textField: { | |
textColor: palette.textColor, | |
hintColor: palette.disabledColor, | |
floatingLabelColor: palette.textColor, | |
disabledTextColor: palette.disabledColor, | |
errorColor: _colors2.default.red500, | |
focusColor: palette.primary1Color, | |
backgroundColor: 'transparent', | |
borderColor: palette.borderColor | |
} | |
}, muiTheme); | |
muiTheme.prefix = _autoPrefix2.default.getTransform(muiTheme.userAgent); | |
return muiTheme; | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 39 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.3.2 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var arrayCopy = __webpack_require__(40), | |
arrayEach = __webpack_require__(41), | |
createAssigner = __webpack_require__(42), | |
isArguments = __webpack_require__(46), | |
isArray = __webpack_require__(47), | |
isPlainObject = __webpack_require__(48), | |
isTypedArray = __webpack_require__(51), | |
keys = __webpack_require__(52), | |
toPlainObject = __webpack_require__(54); | |
/** | |
* Checks if `value` is object-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
/** | |
* Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) | |
* of an array-like value. | |
*/ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** | |
* The base implementation of `_.merge` without support for argument juggling, | |
* multiple sources, and `this` binding `customizer` functions. | |
* | |
* @private | |
* @param {Object} object The destination object. | |
* @param {Object} source The source object. | |
* @param {Function} [customizer] The function to customize merged values. | |
* @param {Array} [stackA=[]] Tracks traversed source objects. | |
* @param {Array} [stackB=[]] Associates values with source counterparts. | |
* @returns {Object} Returns `object`. | |
*/ | |
function baseMerge(object, source, customizer, stackA, stackB) { | |
if (!isObject(object)) { | |
return object; | |
} | |
var isSrcArr = isArrayLike(source) && (isArray(source) || isTypedArray(source)), | |
props = isSrcArr ? undefined : keys(source); | |
arrayEach(props || source, function(srcValue, key) { | |
if (props) { | |
key = srcValue; | |
srcValue = source[key]; | |
} | |
if (isObjectLike(srcValue)) { | |
stackA || (stackA = []); | |
stackB || (stackB = []); | |
baseMergeDeep(object, source, key, baseMerge, customizer, stackA, stackB); | |
} | |
else { | |
var value = object[key], | |
result = customizer ? customizer(value, srcValue, key, object, source) : undefined, | |
isCommon = result === undefined; | |
if (isCommon) { | |
result = srcValue; | |
} | |
if ((result !== undefined || (isSrcArr && !(key in object))) && | |
(isCommon || (result === result ? (result !== value) : (value === value)))) { | |
object[key] = result; | |
} | |
} | |
}); | |
return object; | |
} | |
/** | |
* A specialized version of `baseMerge` for arrays and objects which performs | |
* deep merges and tracks traversed objects enabling objects with circular | |
* references to be merged. | |
* | |
* @private | |
* @param {Object} object The destination object. | |
* @param {Object} source The source object. | |
* @param {string} key The key of the value to merge. | |
* @param {Function} mergeFunc The function to merge values. | |
* @param {Function} [customizer] The function to customize merged values. | |
* @param {Array} [stackA=[]] Tracks traversed source objects. | |
* @param {Array} [stackB=[]] Associates values with source counterparts. | |
* @returns {boolean} Returns `true` if the objects are equivalent, else `false`. | |
*/ | |
function baseMergeDeep(object, source, key, mergeFunc, customizer, stackA, stackB) { | |
var length = stackA.length, | |
srcValue = source[key]; | |
while (length--) { | |
if (stackA[length] == srcValue) { | |
object[key] = stackB[length]; | |
return; | |
} | |
} | |
var value = object[key], | |
result = customizer ? customizer(value, srcValue, key, object, source) : undefined, | |
isCommon = result === undefined; | |
if (isCommon) { | |
result = srcValue; | |
if (isArrayLike(srcValue) && (isArray(srcValue) || isTypedArray(srcValue))) { | |
result = isArray(value) | |
? value | |
: (isArrayLike(value) ? arrayCopy(value) : []); | |
} | |
else if (isPlainObject(srcValue) || isArguments(srcValue)) { | |
result = isArguments(value) | |
? toPlainObject(value) | |
: (isPlainObject(value) ? value : {}); | |
} | |
else { | |
isCommon = false; | |
} | |
} | |
// Add the source value to the stack of traversed objects and associate | |
// it with its merged value. | |
stackA.push(srcValue); | |
stackB.push(result); | |
if (isCommon) { | |
// Recursively merge objects and arrays (susceptible to call stack limits). | |
object[key] = mergeFunc(result, srcValue, customizer, stackA, stackB); | |
} else if (result === result ? (result !== value) : (value === value)) { | |
object[key] = result; | |
} | |
} | |
/** | |
* The base implementation of `_.property` without support for deep paths. | |
* | |
* @private | |
* @param {string} key The key of the property to get. | |
* @returns {Function} Returns the new function. | |
*/ | |
function baseProperty(key) { | |
return function(object) { | |
return object == null ? undefined : object[key]; | |
}; | |
} | |
/** | |
* Gets the "length" property value of `object`. | |
* | |
* **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) | |
* that affects Safari on at least iOS 8.1-8.3 ARM64. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @returns {*} Returns the "length" value. | |
*/ | |
var getLength = baseProperty('length'); | |
/** | |
* Checks if `value` is array-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is array-like, else `false`. | |
*/ | |
function isArrayLike(value) { | |
return value != null && isLength(getLength(value)); | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Recursively merges own enumerable properties of the source object(s), that | |
* don't resolve to `undefined` into the destination object. Subsequent sources | |
* overwrite property assignments of previous sources. If `customizer` is | |
* provided it is invoked to produce the merged values of the destination and | |
* source properties. If `customizer` returns `undefined` merging is handled | |
* by the method instead. The `customizer` is bound to `thisArg` and invoked | |
* with five arguments: (objectValue, sourceValue, key, object, source). | |
* | |
* @static | |
* @memberOf _ | |
* @category Object | |
* @param {Object} object The destination object. | |
* @param {...Object} [sources] The source objects. | |
* @param {Function} [customizer] The function to customize assigned values. | |
* @param {*} [thisArg] The `this` binding of `customizer`. | |
* @returns {Object} Returns `object`. | |
* @example | |
* | |
* var users = { | |
* 'data': [{ 'user': 'barney' }, { 'user': 'fred' }] | |
* }; | |
* | |
* var ages = { | |
* 'data': [{ 'age': 36 }, { 'age': 40 }] | |
* }; | |
* | |
* _.merge(users, ages); | |
* // => { 'data': [{ 'user': 'barney', 'age': 36 }, { 'user': 'fred', 'age': 40 }] } | |
* | |
* // using a customizer callback | |
* var object = { | |
* 'fruits': ['apple'], | |
* 'vegetables': ['beet'] | |
* }; | |
* | |
* var other = { | |
* 'fruits': ['banana'], | |
* 'vegetables': ['carrot'] | |
* }; | |
* | |
* _.merge(object, other, function(a, b) { | |
* if (_.isArray(a)) { | |
* return a.concat(b); | |
* } | |
* }); | |
* // => { 'fruits': ['apple', 'banana'], 'vegetables': ['beet', 'carrot'] } | |
*/ | |
var merge = createAssigner(baseMerge); | |
module.exports = merge; | |
/***/ }, | |
/* 40 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.0 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.7.0 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** | |
* Copies the values of `source` to `array`. | |
* | |
* @private | |
* @param {Array} source The array to copy values from. | |
* @param {Array} [array=[]] The array to copy values to. | |
* @returns {Array} Returns `array`. | |
*/ | |
function arrayCopy(source, array) { | |
var index = -1, | |
length = source.length; | |
array || (array = Array(length)); | |
while (++index < length) { | |
array[index] = source[index]; | |
} | |
return array; | |
} | |
module.exports = arrayCopy; | |
/***/ }, | |
/* 41 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.0 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.7.0 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** | |
* A specialized version of `_.forEach` for arrays without support for callback | |
* shorthands or `this` binding. | |
* | |
* @private | |
* @param {Array} array The array to iterate over. | |
* @param {Function} iteratee The function invoked per iteration. | |
* @returns {Array} Returns `array`. | |
*/ | |
function arrayEach(array, iteratee) { | |
var index = -1, | |
length = array.length; | |
while (++index < length) { | |
if (iteratee(array[index], index, array) === false) { | |
break; | |
} | |
} | |
return array; | |
} | |
module.exports = arrayEach; | |
/***/ }, | |
/* 42 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.1.1 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var bindCallback = __webpack_require__(43), | |
isIterateeCall = __webpack_require__(44), | |
restParam = __webpack_require__(45); | |
/** | |
* Creates a function that assigns properties of source object(s) to a given | |
* destination object. | |
* | |
* **Note:** This function is used to create `_.assign`, `_.defaults`, and `_.merge`. | |
* | |
* @private | |
* @param {Function} assigner The function to assign values. | |
* @returns {Function} Returns the new assigner function. | |
*/ | |
function createAssigner(assigner) { | |
return restParam(function(object, sources) { | |
var index = -1, | |
length = object == null ? 0 : sources.length, | |
customizer = length > 2 ? sources[length - 2] : undefined, | |
guard = length > 2 ? sources[2] : undefined, | |
thisArg = length > 1 ? sources[length - 1] : undefined; | |
if (typeof customizer == 'function') { | |
customizer = bindCallback(customizer, thisArg, 5); | |
length -= 2; | |
} else { | |
customizer = typeof thisArg == 'function' ? thisArg : undefined; | |
length -= (customizer ? 1 : 0); | |
} | |
if (guard && isIterateeCall(sources[0], sources[1], guard)) { | |
customizer = length < 3 ? undefined : customizer; | |
length = 1; | |
} | |
while (++index < length) { | |
var source = sources[index]; | |
if (source) { | |
assigner(object, source, customizer); | |
} | |
} | |
return object; | |
}); | |
} | |
module.exports = createAssigner; | |
/***/ }, | |
/* 43 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.1 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** | |
* A specialized version of `baseCallback` which only supports `this` binding | |
* and specifying the number of arguments to provide to `func`. | |
* | |
* @private | |
* @param {Function} func The function to bind. | |
* @param {*} thisArg The `this` binding of `func`. | |
* @param {number} [argCount] The number of arguments to provide to `func`. | |
* @returns {Function} Returns the callback. | |
*/ | |
function bindCallback(func, thisArg, argCount) { | |
if (typeof func != 'function') { | |
return identity; | |
} | |
if (thisArg === undefined) { | |
return func; | |
} | |
switch (argCount) { | |
case 1: return function(value) { | |
return func.call(thisArg, value); | |
}; | |
case 3: return function(value, index, collection) { | |
return func.call(thisArg, value, index, collection); | |
}; | |
case 4: return function(accumulator, value, index, collection) { | |
return func.call(thisArg, accumulator, value, index, collection); | |
}; | |
case 5: return function(value, other, key, object, source) { | |
return func.call(thisArg, value, other, key, object, source); | |
}; | |
} | |
return function() { | |
return func.apply(thisArg, arguments); | |
}; | |
} | |
/** | |
* This method returns the first argument provided to it. | |
* | |
* @static | |
* @memberOf _ | |
* @category Utility | |
* @param {*} value Any value. | |
* @returns {*} Returns `value`. | |
* @example | |
* | |
* var object = { 'user': 'fred' }; | |
* | |
* _.identity(object) === object; | |
* // => true | |
*/ | |
function identity(value) { | |
return value; | |
} | |
module.exports = bindCallback; | |
/***/ }, | |
/* 44 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.9 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** Used to detect unsigned integer values. */ | |
var reIsUint = /^\d+$/; | |
/** | |
* Used as the [maximum length](https://people.mozilla.org/~jorendorff/es6-draft.html#sec-number.max_safe_integer) | |
* of an array-like value. | |
*/ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** | |
* The base implementation of `_.property` without support for deep paths. | |
* | |
* @private | |
* @param {string} key The key of the property to get. | |
* @returns {Function} Returns the new function. | |
*/ | |
function baseProperty(key) { | |
return function(object) { | |
return object == null ? undefined : object[key]; | |
}; | |
} | |
/** | |
* Gets the "length" property value of `object`. | |
* | |
* **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) | |
* that affects Safari on at least iOS 8.1-8.3 ARM64. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @returns {*} Returns the "length" value. | |
*/ | |
var getLength = baseProperty('length'); | |
/** | |
* Checks if `value` is array-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is array-like, else `false`. | |
*/ | |
function isArrayLike(value) { | |
return value != null && isLength(getLength(value)); | |
} | |
/** | |
* Checks if `value` is a valid array-like index. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. | |
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`. | |
*/ | |
function isIndex(value, length) { | |
value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; | |
length = length == null ? MAX_SAFE_INTEGER : length; | |
return value > -1 && value % 1 == 0 && value < length; | |
} | |
/** | |
* Checks if the provided arguments are from an iteratee call. | |
* | |
* @private | |
* @param {*} value The potential iteratee value argument. | |
* @param {*} index The potential iteratee index or key argument. | |
* @param {*} object The potential iteratee object argument. | |
* @returns {boolean} Returns `true` if the arguments are from an iteratee call, else `false`. | |
*/ | |
function isIterateeCall(value, index, object) { | |
if (!isObject(object)) { | |
return false; | |
} | |
var type = typeof index; | |
if (type == 'number' | |
? (isArrayLike(object) && isIndex(index, object.length)) | |
: (type == 'string' && index in object)) { | |
var other = object[index]; | |
return value === value ? (value === other) : (other !== other); | |
} | |
return false; | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is based on [`ToLength`](https://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength). | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
module.exports = isIterateeCall; | |
/***/ }, | |
/* 45 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.6.1 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** Used as the `TypeError` message for "Functions" methods. */ | |
var FUNC_ERROR_TEXT = 'Expected a function'; | |
/* Native method references for those with the same name as other `lodash` methods. */ | |
var nativeMax = Math.max; | |
/** | |
* Creates a function that invokes `func` with the `this` binding of the | |
* created function and arguments from `start` and beyond provided as an array. | |
* | |
* **Note:** This method is based on the [rest parameter](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions/rest_parameters). | |
* | |
* @static | |
* @memberOf _ | |
* @category Function | |
* @param {Function} func The function to apply a rest parameter to. | |
* @param {number} [start=func.length-1] The start position of the rest parameter. | |
* @returns {Function} Returns the new function. | |
* @example | |
* | |
* var say = _.restParam(function(what, names) { | |
* return what + ' ' + _.initial(names).join(', ') + | |
* (_.size(names) > 1 ? ', & ' : '') + _.last(names); | |
* }); | |
* | |
* say('hello', 'fred', 'barney', 'pebbles'); | |
* // => 'hello fred, barney, & pebbles' | |
*/ | |
function restParam(func, start) { | |
if (typeof func != 'function') { | |
throw new TypeError(FUNC_ERROR_TEXT); | |
} | |
start = nativeMax(start === undefined ? (func.length - 1) : (+start || 0), 0); | |
return function() { | |
var args = arguments, | |
index = -1, | |
length = nativeMax(args.length - start, 0), | |
rest = Array(length); | |
while (++index < length) { | |
rest[index] = args[start + index]; | |
} | |
switch (start) { | |
case 0: return func.call(this, rest); | |
case 1: return func.call(this, args[0], rest); | |
case 2: return func.call(this, args[0], args[1], rest); | |
} | |
var otherArgs = Array(start + 1); | |
index = -1; | |
while (++index < start) { | |
otherArgs[index] = args[index]; | |
} | |
otherArgs[start] = rest; | |
return func.apply(this, otherArgs); | |
}; | |
} | |
module.exports = restParam; | |
/***/ }, | |
/* 46 */ | |
/***/ function(module, exports) { | |
/* WEBPACK VAR INJECTION */(function(global) {/** | |
* lodash 3.0.5 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modularize exports="npm" -o ./` | |
* Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** Used as references for various `Number` constants. */ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** `Object#toString` result references. */ | |
var argsTag = '[object Arguments]', | |
funcTag = '[object Function]', | |
genTag = '[object GeneratorFunction]'; | |
/** Used for built-in method references. */ | |
var objectProto = global.Object.prototype; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/** | |
* Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) | |
* of values. | |
*/ | |
var objectToString = objectProto.toString; | |
/** Built-in value references. */ | |
var propertyIsEnumerable = objectProto.propertyIsEnumerable; | |
/** | |
* The base implementation of `_.property` without support for deep paths. | |
* | |
* @private | |
* @param {string} key The key of the property to get. | |
* @returns {Function} Returns the new function. | |
*/ | |
function baseProperty(key) { | |
return function(object) { | |
return object == null ? undefined : object[key]; | |
}; | |
} | |
/** | |
* Gets the "length" property value of `object`. | |
* | |
* **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) | |
* that affects Safari on at least iOS 8.1-8.3 ARM64. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @returns {*} Returns the "length" value. | |
*/ | |
var getLength = baseProperty('length'); | |
/** | |
* Checks if `value` is likely an `arguments` object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isArguments(function() { return arguments; }()); | |
* // => true | |
* | |
* _.isArguments([1, 2, 3]); | |
* // => false | |
*/ | |
function isArguments(value) { | |
// Safari 8.1 incorrectly makes `arguments.callee` enumerable in strict mode. | |
return isArrayLikeObject(value) && hasOwnProperty.call(value, 'callee') && | |
(!propertyIsEnumerable.call(value, 'callee') || objectToString.call(value) == argsTag); | |
} | |
/** | |
* Checks if `value` is array-like. A value is considered array-like if it's | |
* not a function and has a `value.length` that's an integer greater than or | |
* equal to `0` and less than or equal to `Number.MAX_SAFE_INTEGER`. | |
* | |
* @static | |
* @memberOf _ | |
* @type Function | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is array-like, else `false`. | |
* @example | |
* | |
* _.isArrayLike([1, 2, 3]); | |
* // => true | |
* | |
* _.isArrayLike(document.body.children); | |
* // => true | |
* | |
* _.isArrayLike('abc'); | |
* // => true | |
* | |
* _.isArrayLike(_.noop); | |
* // => false | |
*/ | |
function isArrayLike(value) { | |
return value != null && | |
!(typeof value == 'function' && isFunction(value)) && isLength(getLength(value)); | |
} | |
/** | |
* This method is like `_.isArrayLike` except that it also checks if `value` | |
* is an object. | |
* | |
* @static | |
* @memberOf _ | |
* @type Function | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an array-like object, else `false`. | |
* @example | |
* | |
* _.isArrayLikeObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isArrayLikeObject(document.body.children); | |
* // => true | |
* | |
* _.isArrayLikeObject('abc'); | |
* // => false | |
* | |
* _.isArrayLikeObject(_.noop); | |
* // => false | |
*/ | |
function isArrayLikeObject(value) { | |
return isObjectLike(value) && isArrayLike(value); | |
} | |
/** | |
* Checks if `value` is classified as a `Function` object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isFunction(_); | |
* // => true | |
* | |
* _.isFunction(/abc/); | |
* // => false | |
*/ | |
function isFunction(value) { | |
// The use of `Object#toString` avoids issues with the `typeof` operator | |
// in Safari 8 which returns 'object' for typed array constructors, and | |
// PhantomJS 1.9 which returns 'function' for `NodeList` instances. | |
var tag = isObject(value) ? objectToString.call(value) : ''; | |
return tag == funcTag || tag == genTag; | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
* @example | |
* | |
* _.isLength(3); | |
* // => true | |
* | |
* _.isLength(Number.MIN_VALUE); | |
* // => false | |
* | |
* _.isLength(Infinity); | |
* // => false | |
* | |
* _.isLength('3'); | |
* // => false | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(_.noop); | |
* // => true | |
* | |
* _.isObject(null); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Checks if `value` is object-like. A value is object-like if it's not `null` | |
* and has a `typeof` result of "object". | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
* @example | |
* | |
* _.isObjectLike({}); | |
* // => true | |
* | |
* _.isObjectLike([1, 2, 3]); | |
* // => true | |
* | |
* _.isObjectLike(_.noop); | |
* // => false | |
* | |
* _.isObjectLike(null); | |
* // => false | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
module.exports = isArguments; | |
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) | |
/***/ }, | |
/* 47 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.4 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** `Object#toString` result references. */ | |
var arrayTag = '[object Array]', | |
funcTag = '[object Function]'; | |
/** Used to detect host constructors (Safari > 5). */ | |
var reIsHostCtor = /^\[object .+?Constructor\]$/; | |
/** | |
* Checks if `value` is object-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
/** Used for native method references. */ | |
var objectProto = Object.prototype; | |
/** Used to resolve the decompiled source of functions. */ | |
var fnToString = Function.prototype.toString; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/** | |
* Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) | |
* of values. | |
*/ | |
var objToString = objectProto.toString; | |
/** Used to detect if a method is native. */ | |
var reIsNative = RegExp('^' + | |
fnToString.call(hasOwnProperty).replace(/[\^$.*+?()[\]{}|]/g, '\$&') | |
.replace(/hasOwnProperty|(function).*?(?=\\()| for .+?(?=\\])/g, '$1.*?') + '$' | |
); | |
/* Native method references for those with the same name as other `lodash` methods. */ | |
var nativeIsArray = getNative(Array, 'isArray'); | |
/** | |
* Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) | |
* of an array-like value. | |
*/ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** | |
* Gets the native function at `key` of `object`. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @param {string} key The key of the method to get. | |
* @returns {*} Returns the function if it's native, else `undefined`. | |
*/ | |
function getNative(object, key) { | |
var value = object == null ? undefined : object[key]; | |
return isNative(value) ? value : undefined; | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is classified as an `Array` object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isArray([1, 2, 3]); | |
* // => true | |
* | |
* _.isArray(function() { return arguments; }()); | |
* // => false | |
*/ | |
var isArray = nativeIsArray || function(value) { | |
return isObjectLike(value) && isLength(value.length) && objToString.call(value) == arrayTag; | |
}; | |
/** | |
* Checks if `value` is classified as a `Function` object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isFunction(_); | |
* // => true | |
* | |
* _.isFunction(/abc/); | |
* // => false | |
*/ | |
function isFunction(value) { | |
// The use of `Object#toString` avoids issues with the `typeof` operator | |
// in older versions of Chrome and Safari which return 'function' for regexes | |
// and Safari 8 equivalents which return 'object' for typed array constructors. | |
return isObject(value) && objToString.call(value) == funcTag; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Checks if `value` is a native function. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a native function, else `false`. | |
* @example | |
* | |
* _.isNative(Array.prototype.push); | |
* // => true | |
* | |
* _.isNative(_); | |
* // => false | |
*/ | |
function isNative(value) { | |
if (value == null) { | |
return false; | |
} | |
if (isFunction(value)) { | |
return reIsNative.test(fnToString.call(value)); | |
} | |
return isObjectLike(value) && reIsHostCtor.test(value); | |
} | |
module.exports = isArray; | |
/***/ }, | |
/* 48 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.2.0 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var baseFor = __webpack_require__(49), | |
isArguments = __webpack_require__(46), | |
keysIn = __webpack_require__(50); | |
/** `Object#toString` result references. */ | |
var objectTag = '[object Object]'; | |
/** | |
* Checks if `value` is object-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
/** Used for native method references. */ | |
var objectProto = Object.prototype; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/** | |
* Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) | |
* of values. | |
*/ | |
var objToString = objectProto.toString; | |
/** | |
* The base implementation of `_.forIn` without support for callback | |
* shorthands and `this` binding. | |
* | |
* @private | |
* @param {Object} object The object to iterate over. | |
* @param {Function} iteratee The function invoked per iteration. | |
* @returns {Object} Returns `object`. | |
*/ | |
function baseForIn(object, iteratee) { | |
return baseFor(object, iteratee, keysIn); | |
} | |
/** | |
* Checks if `value` is a plain object, that is, an object created by the | |
* `Object` constructor or one with a `[[Prototype]]` of `null`. | |
* | |
* **Note:** This method assumes objects created by the `Object` constructor | |
* have no inherited enumerable properties. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a plain object, else `false`. | |
* @example | |
* | |
* function Foo() { | |
* this.a = 1; | |
* } | |
* | |
* _.isPlainObject(new Foo); | |
* // => false | |
* | |
* _.isPlainObject([1, 2, 3]); | |
* // => false | |
* | |
* _.isPlainObject({ 'x': 0, 'y': 0 }); | |
* // => true | |
* | |
* _.isPlainObject(Object.create(null)); | |
* // => true | |
*/ | |
function isPlainObject(value) { | |
var Ctor; | |
// Exit early for non `Object` objects. | |
if (!(isObjectLike(value) && objToString.call(value) == objectTag && !isArguments(value)) || | |
(!hasOwnProperty.call(value, 'constructor') && (Ctor = value.constructor, typeof Ctor == 'function' && !(Ctor instanceof Ctor)))) { | |
return false; | |
} | |
// IE < 9 iterates inherited properties before own properties. If the first | |
// iterated property is an object's own property then there are no inherited | |
// enumerable properties. | |
var result; | |
// In most environments an object's own properties are iterated before | |
// its inherited properties. If the last iterated property is an object's | |
// own property then there are no inherited enumerable properties. | |
baseForIn(value, function(subValue, key) { | |
result = key; | |
}); | |
return result === undefined || hasOwnProperty.call(value, result); | |
} | |
module.exports = isPlainObject; | |
/***/ }, | |
/* 49 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.3 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modularize exports="npm" -o ./` | |
* Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** | |
* The base implementation of `baseForIn` and `baseForOwn` which iterates | |
* over `object` properties returned by `keysFunc` invoking `iteratee` for | |
* each property. Iteratee functions may exit iteration early by explicitly | |
* returning `false`. | |
* | |
* @private | |
* @param {Object} object The object to iterate over. | |
* @param {Function} iteratee The function invoked per iteration. | |
* @param {Function} keysFunc The function to get the keys of `object`. | |
* @returns {Object} Returns `object`. | |
*/ | |
var baseFor = createBaseFor(); | |
/** | |
* Creates a base function for methods like `_.forIn`. | |
* | |
* @private | |
* @param {boolean} [fromRight] Specify iterating from right to left. | |
* @returns {Function} Returns the new base function. | |
*/ | |
function createBaseFor(fromRight) { | |
return function(object, iteratee, keysFunc) { | |
var index = -1, | |
iterable = Object(object), | |
props = keysFunc(object), | |
length = props.length; | |
while (length--) { | |
var key = props[fromRight ? length : ++index]; | |
if (iteratee(iterable[key], key, iterable) === false) { | |
break; | |
} | |
} | |
return object; | |
}; | |
} | |
module.exports = baseFor; | |
/***/ }, | |
/* 50 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.0.8 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var isArguments = __webpack_require__(46), | |
isArray = __webpack_require__(47); | |
/** Used to detect unsigned integer values. */ | |
var reIsUint = /^\d+$/; | |
/** Used for native method references. */ | |
var objectProto = Object.prototype; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/** | |
* Used as the [maximum length](https://people.mozilla.org/~jorendorff/es6-draft.html#sec-number.max_safe_integer) | |
* of an array-like value. | |
*/ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** | |
* Checks if `value` is a valid array-like index. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. | |
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`. | |
*/ | |
function isIndex(value, length) { | |
value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; | |
length = length == null ? MAX_SAFE_INTEGER : length; | |
return value > -1 && value % 1 == 0 && value < length; | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is based on [`ToLength`](https://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength). | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Creates an array of the own and inherited enumerable property names of `object`. | |
* | |
* **Note:** Non-object values are coerced to objects. | |
* | |
* @static | |
* @memberOf _ | |
* @category Object | |
* @param {Object} object The object to query. | |
* @returns {Array} Returns the array of property names. | |
* @example | |
* | |
* function Foo() { | |
* this.a = 1; | |
* this.b = 2; | |
* } | |
* | |
* Foo.prototype.c = 3; | |
* | |
* _.keysIn(new Foo); | |
* // => ['a', 'b', 'c'] (iteration order is not guaranteed) | |
*/ | |
function keysIn(object) { | |
if (object == null) { | |
return []; | |
} | |
if (!isObject(object)) { | |
object = Object(object); | |
} | |
var length = object.length; | |
length = (length && isLength(length) && | |
(isArray(object) || isArguments(object)) && length) || 0; | |
var Ctor = object.constructor, | |
index = -1, | |
isProto = typeof Ctor == 'function' && Ctor.prototype === object, | |
result = Array(length), | |
skipIndexes = length > 0; | |
while (++index < length) { | |
result[index] = (index + ''); | |
} | |
for (var key in object) { | |
if (!(skipIndexes && isIndex(key, length)) && | |
!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { | |
result.push(key); | |
} | |
} | |
return result; | |
} | |
module.exports = keysIn; | |
/***/ }, | |
/* 51 */ | |
/***/ function(module, exports) { | |
/* WEBPACK VAR INJECTION */(function(global) {/** | |
* lodash 3.0.3 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modularize exports="npm" -o ./` | |
* Copyright 2012-2016 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** Used as references for various `Number` constants. */ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** `Object#toString` result references. */ | |
var argsTag = '[object Arguments]', | |
arrayTag = '[object Array]', | |
boolTag = '[object Boolean]', | |
dateTag = '[object Date]', | |
errorTag = '[object Error]', | |
funcTag = '[object Function]', | |
mapTag = '[object Map]', | |
numberTag = '[object Number]', | |
objectTag = '[object Object]', | |
regexpTag = '[object RegExp]', | |
setTag = '[object Set]', | |
stringTag = '[object String]', | |
weakMapTag = '[object WeakMap]'; | |
var arrayBufferTag = '[object ArrayBuffer]', | |
float32Tag = '[object Float32Array]', | |
float64Tag = '[object Float64Array]', | |
int8Tag = '[object Int8Array]', | |
int16Tag = '[object Int16Array]', | |
int32Tag = '[object Int32Array]', | |
uint8Tag = '[object Uint8Array]', | |
uint8ClampedTag = '[object Uint8ClampedArray]', | |
uint16Tag = '[object Uint16Array]', | |
uint32Tag = '[object Uint32Array]'; | |
/** Used to identify `toStringTag` values of typed arrays. */ | |
var typedArrayTags = {}; | |
typedArrayTags[float32Tag] = typedArrayTags[float64Tag] = | |
typedArrayTags[int8Tag] = typedArrayTags[int16Tag] = | |
typedArrayTags[int32Tag] = typedArrayTags[uint8Tag] = | |
typedArrayTags[uint8ClampedTag] = typedArrayTags[uint16Tag] = | |
typedArrayTags[uint32Tag] = true; | |
typedArrayTags[argsTag] = typedArrayTags[arrayTag] = | |
typedArrayTags[arrayBufferTag] = typedArrayTags[boolTag] = | |
typedArrayTags[dateTag] = typedArrayTags[errorTag] = | |
typedArrayTags[funcTag] = typedArrayTags[mapTag] = | |
typedArrayTags[numberTag] = typedArrayTags[objectTag] = | |
typedArrayTags[regexpTag] = typedArrayTags[setTag] = | |
typedArrayTags[stringTag] = typedArrayTags[weakMapTag] = false; | |
/** Used for built-in method references. */ | |
var objectProto = global.Object.prototype; | |
/** | |
* Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) | |
* of values. | |
*/ | |
var objectToString = objectProto.toString; | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is loosely based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
* @example | |
* | |
* _.isLength(3); | |
* // => true | |
* | |
* _.isLength(Number.MIN_VALUE); | |
* // => false | |
* | |
* _.isLength(Infinity); | |
* // => false | |
* | |
* _.isLength('3'); | |
* // => false | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* Checks if `value` is object-like. A value is object-like if it's not `null` | |
* and has a `typeof` result of "object". | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
* @example | |
* | |
* _.isObjectLike({}); | |
* // => true | |
* | |
* _.isObjectLike([1, 2, 3]); | |
* // => true | |
* | |
* _.isObjectLike(_.noop); | |
* // => false | |
* | |
* _.isObjectLike(null); | |
* // => false | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
/** | |
* Checks if `value` is classified as a typed array. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isTypedArray(new Uint8Array); | |
* // => true | |
* | |
* _.isTypedArray([]); | |
* // => false | |
*/ | |
function isTypedArray(value) { | |
return isObjectLike(value) && isLength(value.length) && !!typedArrayTags[objectToString.call(value)]; | |
} | |
module.exports = isTypedArray; | |
/* WEBPACK VAR INJECTION */}.call(exports, (function() { return this; }()))) | |
/***/ }, | |
/* 52 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.1.2 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var getNative = __webpack_require__(53), | |
isArguments = __webpack_require__(46), | |
isArray = __webpack_require__(47); | |
/** Used to detect unsigned integer values. */ | |
var reIsUint = /^\d+$/; | |
/** Used for native method references. */ | |
var objectProto = Object.prototype; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/* Native method references for those with the same name as other `lodash` methods. */ | |
var nativeKeys = getNative(Object, 'keys'); | |
/** | |
* Used as the [maximum length](http://ecma-international.org/ecma-262/6.0/#sec-number.max_safe_integer) | |
* of an array-like value. | |
*/ | |
var MAX_SAFE_INTEGER = 9007199254740991; | |
/** | |
* The base implementation of `_.property` without support for deep paths. | |
* | |
* @private | |
* @param {string} key The key of the property to get. | |
* @returns {Function} Returns the new function. | |
*/ | |
function baseProperty(key) { | |
return function(object) { | |
return object == null ? undefined : object[key]; | |
}; | |
} | |
/** | |
* Gets the "length" property value of `object`. | |
* | |
* **Note:** This function is used to avoid a [JIT bug](https://bugs.webkit.org/show_bug.cgi?id=142792) | |
* that affects Safari on at least iOS 8.1-8.3 ARM64. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @returns {*} Returns the "length" value. | |
*/ | |
var getLength = baseProperty('length'); | |
/** | |
* Checks if `value` is array-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is array-like, else `false`. | |
*/ | |
function isArrayLike(value) { | |
return value != null && isLength(getLength(value)); | |
} | |
/** | |
* Checks if `value` is a valid array-like index. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @param {number} [length=MAX_SAFE_INTEGER] The upper bounds of a valid index. | |
* @returns {boolean} Returns `true` if `value` is a valid index, else `false`. | |
*/ | |
function isIndex(value, length) { | |
value = (typeof value == 'number' || reIsUint.test(value)) ? +value : -1; | |
length = length == null ? MAX_SAFE_INTEGER : length; | |
return value > -1 && value % 1 == 0 && value < length; | |
} | |
/** | |
* Checks if `value` is a valid array-like length. | |
* | |
* **Note:** This function is based on [`ToLength`](http://ecma-international.org/ecma-262/6.0/#sec-tolength). | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a valid length, else `false`. | |
*/ | |
function isLength(value) { | |
return typeof value == 'number' && value > -1 && value % 1 == 0 && value <= MAX_SAFE_INTEGER; | |
} | |
/** | |
* A fallback implementation of `Object.keys` which creates an array of the | |
* own enumerable property names of `object`. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @returns {Array} Returns the array of property names. | |
*/ | |
function shimKeys(object) { | |
var props = keysIn(object), | |
propsLength = props.length, | |
length = propsLength && object.length; | |
var allowIndexes = !!length && isLength(length) && | |
(isArray(object) || isArguments(object)); | |
var index = -1, | |
result = []; | |
while (++index < propsLength) { | |
var key = props[index]; | |
if ((allowIndexes && isIndex(key, length)) || hasOwnProperty.call(object, key)) { | |
result.push(key); | |
} | |
} | |
return result; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Creates an array of the own enumerable property names of `object`. | |
* | |
* **Note:** Non-object values are coerced to objects. See the | |
* [ES spec](http://ecma-international.org/ecma-262/6.0/#sec-object.keys) | |
* for more details. | |
* | |
* @static | |
* @memberOf _ | |
* @category Object | |
* @param {Object} object The object to query. | |
* @returns {Array} Returns the array of property names. | |
* @example | |
* | |
* function Foo() { | |
* this.a = 1; | |
* this.b = 2; | |
* } | |
* | |
* Foo.prototype.c = 3; | |
* | |
* _.keys(new Foo); | |
* // => ['a', 'b'] (iteration order is not guaranteed) | |
* | |
* _.keys('hi'); | |
* // => ['0', '1'] | |
*/ | |
var keys = !nativeKeys ? shimKeys : function(object) { | |
var Ctor = object == null ? undefined : object.constructor; | |
if ((typeof Ctor == 'function' && Ctor.prototype === object) || | |
(typeof object != 'function' && isArrayLike(object))) { | |
return shimKeys(object); | |
} | |
return isObject(object) ? nativeKeys(object) : []; | |
}; | |
/** | |
* Creates an array of the own and inherited enumerable property names of `object`. | |
* | |
* **Note:** Non-object values are coerced to objects. | |
* | |
* @static | |
* @memberOf _ | |
* @category Object | |
* @param {Object} object The object to query. | |
* @returns {Array} Returns the array of property names. | |
* @example | |
* | |
* function Foo() { | |
* this.a = 1; | |
* this.b = 2; | |
* } | |
* | |
* Foo.prototype.c = 3; | |
* | |
* _.keysIn(new Foo); | |
* // => ['a', 'b', 'c'] (iteration order is not guaranteed) | |
*/ | |
function keysIn(object) { | |
if (object == null) { | |
return []; | |
} | |
if (!isObject(object)) { | |
object = Object(object); | |
} | |
var length = object.length; | |
length = (length && isLength(length) && | |
(isArray(object) || isArguments(object)) && length) || 0; | |
var Ctor = object.constructor, | |
index = -1, | |
isProto = typeof Ctor == 'function' && Ctor.prototype === object, | |
result = Array(length), | |
skipIndexes = length > 0; | |
while (++index < length) { | |
result[index] = (index + ''); | |
} | |
for (var key in object) { | |
if (!(skipIndexes && isIndex(key, length)) && | |
!(key == 'constructor' && (isProto || !hasOwnProperty.call(object, key)))) { | |
result.push(key); | |
} | |
} | |
return result; | |
} | |
module.exports = keys; | |
/***/ }, | |
/* 53 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.9.1 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** `Object#toString` result references. */ | |
var funcTag = '[object Function]'; | |
/** Used to detect host constructors (Safari > 5). */ | |
var reIsHostCtor = /^\[object .+?Constructor\]$/; | |
/** | |
* Checks if `value` is object-like. | |
* | |
* @private | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is object-like, else `false`. | |
*/ | |
function isObjectLike(value) { | |
return !!value && typeof value == 'object'; | |
} | |
/** Used for native method references. */ | |
var objectProto = Object.prototype; | |
/** Used to resolve the decompiled source of functions. */ | |
var fnToString = Function.prototype.toString; | |
/** Used to check objects for own properties. */ | |
var hasOwnProperty = objectProto.hasOwnProperty; | |
/** | |
* Used to resolve the [`toStringTag`](http://ecma-international.org/ecma-262/6.0/#sec-object.prototype.tostring) | |
* of values. | |
*/ | |
var objToString = objectProto.toString; | |
/** Used to detect if a method is native. */ | |
var reIsNative = RegExp('^' + | |
fnToString.call(hasOwnProperty).replace(/[\^$.*+?()[\]{}|]/g, '\$&') | |
.replace(/hasOwnProperty|(function).*?(?=\\()| for .+?(?=\\])/g, '$1.*?') + '$' | |
); | |
/** | |
* Gets the native function at `key` of `object`. | |
* | |
* @private | |
* @param {Object} object The object to query. | |
* @param {string} key The key of the method to get. | |
* @returns {*} Returns the function if it's native, else `undefined`. | |
*/ | |
function getNative(object, key) { | |
var value = object == null ? undefined : object[key]; | |
return isNative(value) ? value : undefined; | |
} | |
/** | |
* Checks if `value` is classified as a `Function` object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is correctly classified, else `false`. | |
* @example | |
* | |
* _.isFunction(_); | |
* // => true | |
* | |
* _.isFunction(/abc/); | |
* // => false | |
*/ | |
function isFunction(value) { | |
// The use of `Object#toString` avoids issues with the `typeof` operator | |
// in older versions of Chrome and Safari which return 'function' for regexes | |
// and Safari 8 equivalents which return 'object' for typed array constructors. | |
return isObject(value) && objToString.call(value) == funcTag; | |
} | |
/** | |
* Checks if `value` is the [language type](https://es5.github.io/#x8) of `Object`. | |
* (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`) | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is an object, else `false`. | |
* @example | |
* | |
* _.isObject({}); | |
* // => true | |
* | |
* _.isObject([1, 2, 3]); | |
* // => true | |
* | |
* _.isObject(1); | |
* // => false | |
*/ | |
function isObject(value) { | |
// Avoid a V8 JIT bug in Chrome 19-20. | |
// See https://code.google.com/p/v8/issues/detail?id=2291 for more details. | |
var type = typeof value; | |
return !!value && (type == 'object' || type == 'function'); | |
} | |
/** | |
* Checks if `value` is a native function. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to check. | |
* @returns {boolean} Returns `true` if `value` is a native function, else `false`. | |
* @example | |
* | |
* _.isNative(Array.prototype.push); | |
* // => true | |
* | |
* _.isNative(_); | |
* // => false | |
*/ | |
function isNative(value) { | |
if (value == null) { | |
return false; | |
} | |
if (isFunction(value)) { | |
return reIsNative.test(fnToString.call(value)); | |
} | |
return isObjectLike(value) && reIsHostCtor.test(value); | |
} | |
module.exports = getNative; | |
/***/ }, | |
/* 54 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* lodash 3.0.0 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.7.0 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
var baseCopy = __webpack_require__(55), | |
keysIn = __webpack_require__(50); | |
/** | |
* Converts `value` to a plain object flattening inherited enumerable | |
* properties of `value` to own properties of the plain object. | |
* | |
* @static | |
* @memberOf _ | |
* @category Lang | |
* @param {*} value The value to convert. | |
* @returns {Object} Returns the converted plain object. | |
* @example | |
* | |
* function Foo() { | |
* this.b = 2; | |
* } | |
* | |
* Foo.prototype.c = 3; | |
* | |
* _.assign({ 'a': 1 }, new Foo); | |
* // => { 'a': 1, 'b': 2 } | |
* | |
* _.assign({ 'a': 1 }, _.toPlainObject(new Foo)); | |
* // => { 'a': 1, 'b': 2, 'c': 3 } | |
*/ | |
function toPlainObject(value) { | |
return baseCopy(value, keysIn(value)); | |
} | |
module.exports = toPlainObject; | |
/***/ }, | |
/* 55 */ | |
/***/ function(module, exports) { | |
/** | |
* lodash 3.0.1 (Custom Build) <https://lodash.com/> | |
* Build: `lodash modern modularize exports="npm" -o ./` | |
* Copyright 2012-2015 The Dojo Foundation <http://dojofoundation.org/> | |
* Based on Underscore.js 1.8.3 <http://underscorejs.org/LICENSE> | |
* Copyright 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors | |
* Available under MIT license <https://lodash.com/license> | |
*/ | |
/** | |
* Copies properties of `source` to `object`. | |
* | |
* @private | |
* @param {Object} source The object to copy properties from. | |
* @param {Array} props The property names to copy. | |
* @param {Object} [object={}] The object to copy properties to. | |
* @returns {Object} Returns `object`. | |
*/ | |
function baseCopy(source, props, object) { | |
object || (object = {}); | |
var index = -1, | |
length = props.length; | |
while (++index < length) { | |
var key = props[index]; | |
object[key] = source[key]; | |
} | |
return object; | |
} | |
module.exports = baseCopy; | |
/***/ }, | |
/* 56 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
red50: '#ffebee', | |
red100: '#ffcdd2', | |
red200: '#ef9a9a', | |
red300: '#e57373', | |
red400: '#ef5350', | |
red500: '#f44336', | |
red600: '#e53935', | |
red700: '#d32f2f', | |
red800: '#c62828', | |
red900: '#b71c1c', | |
redA100: '#ff8a80', | |
redA200: '#ff5252', | |
redA400: '#ff1744', | |
redA700: '#d50000', | |
pink50: '#fce4ec', | |
pink100: '#f8bbd0', | |
pink200: '#f48fb1', | |
pink300: '#f06292', | |
pink400: '#ec407a', | |
pink500: '#e91e63', | |
pink600: '#d81b60', | |
pink700: '#c2185b', | |
pink800: '#ad1457', | |
pink900: '#880e4f', | |
pinkA100: '#ff80ab', | |
pinkA200: '#ff4081', | |
pinkA400: '#f50057', | |
pinkA700: '#c51162', | |
purple50: '#f3e5f5', | |
purple100: '#e1bee7', | |
purple200: '#ce93d8', | |
purple300: '#ba68c8', | |
purple400: '#ab47bc', | |
purple500: '#9c27b0', | |
purple600: '#8e24aa', | |
purple700: '#7b1fa2', | |
purple800: '#6a1b9a', | |
purple900: '#4a148c', | |
purpleA100: '#ea80fc', | |
purpleA200: '#e040fb', | |
purpleA400: '#d500f9', | |
purpleA700: '#aa00ff', | |
deepPurple50: '#ede7f6', | |
deepPurple100: '#d1c4e9', | |
deepPurple200: '#b39ddb', | |
deepPurple300: '#9575cd', | |
deepPurple400: '#7e57c2', | |
deepPurple500: '#673ab7', | |
deepPurple600: '#5e35b1', | |
deepPurple700: '#512da8', | |
deepPurple800: '#4527a0', | |
deepPurple900: '#311b92', | |
deepPurpleA100: '#b388ff', | |
deepPurpleA200: '#7c4dff', | |
deepPurpleA400: '#651fff', | |
deepPurpleA700: '#6200ea', | |
indigo50: '#e8eaf6', | |
indigo100: '#c5cae9', | |
indigo200: '#9fa8da', | |
indigo300: '#7986cb', | |
indigo400: '#5c6bc0', | |
indigo500: '#3f51b5', | |
indigo600: '#3949ab', | |
indigo700: '#303f9f', | |
indigo800: '#283593', | |
indigo900: '#1a237e', | |
indigoA100: '#8c9eff', | |
indigoA200: '#536dfe', | |
indigoA400: '#3d5afe', | |
indigoA700: '#304ffe', | |
blue50: '#e3f2fd', | |
blue100: '#bbdefb', | |
blue200: '#90caf9', | |
blue300: '#64b5f6', | |
blue400: '#42a5f5', | |
blue500: '#2196f3', | |
blue600: '#1e88e5', | |
blue700: '#1976d2', | |
blue800: '#1565c0', | |
blue900: '#0d47a1', | |
blueA100: '#82b1ff', | |
blueA200: '#448aff', | |
blueA400: '#2979ff', | |
blueA700: '#2962ff', | |
lightBlue50: '#e1f5fe', | |
lightBlue100: '#b3e5fc', | |
lightBlue200: '#81d4fa', | |
lightBlue300: '#4fc3f7', | |
lightBlue400: '#29b6f6', | |
lightBlue500: '#03a9f4', | |
lightBlue600: '#039be5', | |
lightBlue700: '#0288d1', | |
lightBlue800: '#0277bd', | |
lightBlue900: '#01579b', | |
lightBlueA100: '#80d8ff', | |
lightBlueA200: '#40c4ff', | |
lightBlueA400: '#00b0ff', | |
lightBlueA700: '#0091ea', | |
cyan50: '#e0f7fa', | |
cyan100: '#b2ebf2', | |
cyan200: '#80deea', | |
cyan300: '#4dd0e1', | |
cyan400: '#26c6da', | |
cyan500: '#00bcd4', | |
cyan600: '#00acc1', | |
cyan700: '#0097a7', | |
cyan800: '#00838f', | |
cyan900: '#006064', | |
cyanA100: '#84ffff', | |
cyanA200: '#18ffff', | |
cyanA400: '#00e5ff', | |
cyanA700: '#00b8d4', | |
teal50: '#e0f2f1', | |
teal100: '#b2dfdb', | |
teal200: '#80cbc4', | |
teal300: '#4db6ac', | |
teal400: '#26a69a', | |
teal500: '#009688', | |
teal600: '#00897b', | |
teal700: '#00796b', | |
teal800: '#00695c', | |
teal900: '#004d40', | |
tealA100: '#a7ffeb', | |
tealA200: '#64ffda', | |
tealA400: '#1de9b6', | |
tealA700: '#00bfa5', | |
green50: '#e8f5e9', | |
green100: '#c8e6c9', | |
green200: '#a5d6a7', | |
green300: '#81c784', | |
green400: '#66bb6a', | |
green500: '#4caf50', | |
green600: '#43a047', | |
green700: '#388e3c', | |
green800: '#2e7d32', | |
green900: '#1b5e20', | |
greenA100: '#b9f6ca', | |
greenA200: '#69f0ae', | |
greenA400: '#00e676', | |
greenA700: '#00c853', | |
lightGreen50: '#f1f8e9', | |
lightGreen100: '#dcedc8', | |
lightGreen200: '#c5e1a5', | |
lightGreen300: '#aed581', | |
lightGreen400: '#9ccc65', | |
lightGreen500: '#8bc34a', | |
lightGreen600: '#7cb342', | |
lightGreen700: '#689f38', | |
lightGreen800: '#558b2f', | |
lightGreen900: '#33691e', | |
lightGreenA100: '#ccff90', | |
lightGreenA200: '#b2ff59', | |
lightGreenA400: '#76ff03', | |
lightGreenA700: '#64dd17', | |
lime50: '#f9fbe7', | |
lime100: '#f0f4c3', | |
lime200: '#e6ee9c', | |
lime300: '#dce775', | |
lime400: '#d4e157', | |
lime500: '#cddc39', | |
lime600: '#c0ca33', | |
lime700: '#afb42b', | |
lime800: '#9e9d24', | |
lime900: '#827717', | |
limeA100: '#f4ff81', | |
limeA200: '#eeff41', | |
limeA400: '#c6ff00', | |
limeA700: '#aeea00', | |
yellow50: '#fffde7', | |
yellow100: '#fff9c4', | |
yellow200: '#fff59d', | |
yellow300: '#fff176', | |
yellow400: '#ffee58', | |
yellow500: '#ffeb3b', | |
yellow600: '#fdd835', | |
yellow700: '#fbc02d', | |
yellow800: '#f9a825', | |
yellow900: '#f57f17', | |
yellowA100: '#ffff8d', | |
yellowA200: '#ffff00', | |
yellowA400: '#ffea00', | |
yellowA700: '#ffd600', | |
amber50: '#fff8e1', | |
amber100: '#ffecb3', | |
amber200: '#ffe082', | |
amber300: '#ffd54f', | |
amber400: '#ffca28', | |
amber500: '#ffc107', | |
amber600: '#ffb300', | |
amber700: '#ffa000', | |
amber800: '#ff8f00', | |
amber900: '#ff6f00', | |
amberA100: '#ffe57f', | |
amberA200: '#ffd740', | |
amberA400: '#ffc400', | |
amberA700: '#ffab00', | |
orange50: '#fff3e0', | |
orange100: '#ffe0b2', | |
orange200: '#ffcc80', | |
orange300: '#ffb74d', | |
orange400: '#ffa726', | |
orange500: '#ff9800', | |
orange600: '#fb8c00', | |
orange700: '#f57c00', | |
orange800: '#ef6c00', | |
orange900: '#e65100', | |
orangeA100: '#ffd180', | |
orangeA200: '#ffab40', | |
orangeA400: '#ff9100', | |
orangeA700: '#ff6d00', | |
deepOrange50: '#fbe9e7', | |
deepOrange100: '#ffccbc', | |
deepOrange200: '#ffab91', | |
deepOrange300: '#ff8a65', | |
deepOrange400: '#ff7043', | |
deepOrange500: '#ff5722', | |
deepOrange600: '#f4511e', | |
deepOrange700: '#e64a19', | |
deepOrange800: '#d84315', | |
deepOrange900: '#bf360c', | |
deepOrangeA100: '#ff9e80', | |
deepOrangeA200: '#ff6e40', | |
deepOrangeA400: '#ff3d00', | |
deepOrangeA700: '#dd2c00', | |
brown50: '#efebe9', | |
brown100: '#d7ccc8', | |
brown200: '#bcaaa4', | |
brown300: '#a1887f', | |
brown400: '#8d6e63', | |
brown500: '#795548', | |
brown600: '#6d4c41', | |
brown700: '#5d4037', | |
brown800: '#4e342e', | |
brown900: '#3e2723', | |
blueGrey50: '#eceff1', | |
blueGrey100: '#cfd8dc', | |
blueGrey200: '#b0bec5', | |
blueGrey300: '#90a4ae', | |
blueGrey400: '#78909c', | |
blueGrey500: '#607d8b', | |
blueGrey600: '#546e7a', | |
blueGrey700: '#455a64', | |
blueGrey800: '#37474f', | |
blueGrey900: '#263238', | |
grey50: '#fafafa', | |
grey100: '#f5f5f5', | |
grey200: '#eeeeee', | |
grey300: '#e0e0e0', | |
grey400: '#bdbdbd', | |
grey500: '#9e9e9e', | |
grey600: '#757575', | |
grey700: '#616161', | |
grey800: '#424242', | |
grey900: '#212121', | |
black: '#000000', | |
white: '#ffffff', | |
transparent: 'rgba(0, 0, 0, 0)', | |
fullBlack: 'rgba(0, 0, 0, 1)', | |
darkBlack: 'rgba(0, 0, 0, 0.87)', | |
lightBlack: 'rgba(0, 0, 0, 0.54)', | |
minBlack: 'rgba(0, 0, 0, 0.26)', | |
faintBlack: 'rgba(0, 0, 0, 0.12)', | |
fullWhite: 'rgba(255, 255, 255, 1)', | |
darkWhite: 'rgba(255, 255, 255, 0.87)', | |
lightWhite: 'rgba(255, 255, 255, 0.54)' | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 57 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _warning = __webpack_require__(26); | |
var _warning2 = _interopRequireDefault(_warning); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
exports.default = { | |
/** | |
* The relative brightness of any point in a colorspace, normalized to 0 for | |
* darkest black and 1 for lightest white. RGB colors only. Does not take | |
* into account alpha values. | |
* | |
* TODO: | |
* - Take into account alpha values. | |
* - Identify why there are minor discrepancies for some use cases | |
* (i.e. #F0F & #FFF). Note that these cases rarely occur. | |
* | |
* Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef | |
*/ | |
_luminance: function _luminance(color) { | |
color = this._decomposeColor(color); | |
if (color.type.indexOf('rgb') > -1) { | |
var rgb = color.values.map(function (val) { | |
val /= 255; // normalized | |
return val <= 0.03928 ? val / 12.92 : Math.pow((val + 0.055) / 1.055, 2.4); | |
}); | |
return 0.2126 * rgb[0] + 0.7152 * rgb[1] + 0.0722 * rgb[2]; | |
} else { | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'Calculating the relative luminance is not available | |
for HSL and HSLA.') : undefined; | |
return -1; | |
} | |
}, | |
/** | |
* @params: | |
* additionalValue = An extra value that has been calculated but not included | |
* with the original color object, such as an alpha value. | |
*/ | |
_convertColorToString: function _convertColorToString(color, additonalValue) { | |
var str = color.type + '(' + parseInt(color.values[0]) + ',' + parseInt(color.values[1]) + ',' + parseInt(color.values[2]); | |
if (additonalValue !== undefined) { | |
str += ',' + additonalValue + ')'; | |
} else if (color.values.length === 4) { | |
str += ',' + color.values[3] + ')'; | |
} else { | |
str += ')'; | |
} | |
return str; | |
}, | |
// Converts a color from hex format to rgb format. | |
_convertHexToRGB: function _convertHexToRGB(color) { | |
if (color.length === 4) { | |
var extendedColor = '#'; | |
for (var i = 1; i < color.length; i++) { | |
extendedColor += color.charAt(i) + color.charAt(i); | |
} | |
color = extendedColor; | |
} | |
var values = { | |
r: parseInt(color.substr(1, 2), 16), | |
g: parseInt(color.substr(3, 2), 16), | |
b: parseInt(color.substr(5, 2), 16) | |
}; | |
return 'rgb(' + values.r + ',' + values.g + ',' + values.b + ')'; | |
}, | |
// Returns the type and values of a color of any given type. | |
_decomposeColor: function _decomposeColor(color) { | |
if (color.charAt(0) === '#') { | |
return this._decomposeColor(this._convertHexToRGB(color)); | |
} | |
var marker = color.indexOf('('); | |
var type = color.substring(0, marker); | |
var values = color.substring(marker + 1, color.length - 1).split(','); | |
return { type: type, values: values }; | |
}, | |
// Set the absolute transparency of a color. | |
// Any existing alpha values are overwritten. | |
fade: function fade(color, amount) { | |
color = this._decomposeColor(color); | |
if (color.type === 'rgb' || color.type === 'hsl') color.type += 'a'; | |
return this._convertColorToString(color, amount); | |
}, | |
// Desaturates rgb and sets opacity to 0.15 | |
lighten: function lighten(color, amount) { | |
color = this._decomposeColor(color); | |
if (color.type.indexOf('hsl') > -1) { | |
color.values[2] += amount; | |
return this._decomposeColor(this._convertColorToString(color)); | |
} else if (color.type.indexOf('rgb') > -1) { | |
for (var i = 0; i < 3; i++) { | |
color.values[i] *= 1 + amount; | |
if (color.values[i] > 255) color.values[i] = 255; | |
} | |
} | |
if (color.type.indexOf('a') <= -1) color.type += 'a'; | |
return this._convertColorToString(color, '0.15'); | |
}, | |
darken: function darken(color, amount) { | |
color = this._decomposeColor(color); | |
if (color.type.indexOf('hsl') > -1) { | |
color.values[2] += amount; | |
return this._decomposeColor(this._convertColorToString(color)); | |
} else if (color.type.indexOf('rgb') > -1) { | |
for (var i = 0; i < 3; i++) { | |
color.values[i] *= 1 - amount; | |
if (color.values[i] < 0) color.values[i] = 0; | |
} | |
} | |
return this._convertColorToString(color); | |
}, | |
// Calculates the contrast ratio between two colors. | |
// | |
// Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef | |
contrastRatio: function contrastRatio(background, foreground) { | |
var lumA = this._luminance(background); | |
var lumB = this._luminance(foreground); | |
if (lumA >= lumB) { | |
return ((lumA + 0.05) / (lumB + 0.05)).toFixed(2); | |
} else { | |
return ((lumB + 0.05) / (lumA + 0.05)).toFixed(2); | |
} | |
}, | |
/** | |
* Determines how readable a color combination is based on its level. | |
* Levels are defined from @LeaVerou: | |
* https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/contrast-ratio.js | |
*/ | |
contrastRatioLevel: function contrastRatioLevel(background, foreground) { | |
var levels = { | |
'fail': { | |
range: [0, 3], | |
color: 'hsl(0, 100%, 40%)' | |
}, | |
'aa-large': { | |
range: [3, 4.5], | |
color: 'hsl(40, 100%, 45%)' | |
}, | |
'aa': { | |
range: [4.5, 7], | |
color: 'hsl(80, 60%, 45%)' | |
}, | |
'aaa': { | |
range: [7, 22], | |
color: 'hsl(95, 60%, 41%)' | |
} | |
}; | |
var ratio = this.contrastRatio(background, foreground); | |
for (var level in levels) { | |
var range = levels[level].range; | |
if (ratio >= range[0] && ratio <= range[1]) return level; | |
} | |
} | |
}; | |
module.exports = exports['default']; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 58 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _colors = __webpack_require__(56); | |
var _colors2 = _interopRequireDefault(_colors); | |
var _colorManipulator = __webpack_require__(57); | |
var _colorManipulator2 = _interopRequireDefault(_colorManipulator); | |
var _spacing = __webpack_require__(59); | |
var _spacing2 = _interopRequireDefault(_spacing); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
/* | |
* Light Theme is the default theme used in material-ui. It is guaranteed to | |
* have all theme variables needed for every component. Variables not defined | |
* in a custom theme will default to these values. | |
*/ | |
exports.default = { | |
spacing: _spacing2.default, | |
fontFamily: 'Roboto, sans-serif', | |
palette: { | |
primary1Color: _colors2.default.cyan500, | |
primary2Color: _colors2.default.cyan700, | |
primary3Color: _colors2.default.grey400, | |
accent1Color: _colors2.default.pinkA200, | |
accent2Color: _colors2.default.grey100, | |
accent3Color: _colors2.default.grey500, | |
textColor: _colors2.default.darkBlack, | |
alternateTextColor: _colors2.default.white, | |
canvasColor: _colors2.default.white, | |
borderColor: _colors2.default.grey300, | |
disabledColor: _colorManipulator2.default.fade(_colors2.default.darkBlack, 0.3), | |
pickerHeaderColor: _colors2.default.cyan500, | |
clockCircleColor: _colorManipulator2.default.fade(_colors2.default.darkBlack, 0.07), | |
shadowColor: _colors2.default.fullBlack | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 59 */ | |
/***/ function(module, exports) { | |
"use strict"; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
iconSize: 24, | |
desktopGutter: 24, | |
desktopGutterMore: 32, | |
desktopGutterLess: 16, | |
desktopGutterMini: 8, | |
desktopKeylineIncrement: 64, | |
desktopDropDownMenuItemHeight: 32, | |
desktopDropDownMenuFontSize: 15, | |
desktopLeftNavMenuItemHeight: 48, | |
desktopSubheaderHeight: 48, | |
desktopToolbarHeight: 56 | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 60 */ | |
/***/ function(module, exports) { | |
"use strict"; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
menu: 1000, | |
appBar: 1100, | |
leftNavOverlay: 1200, | |
leftNav: 1300, | |
dialogOverlay: 1400, | |
dialog: 1500, | |
layer: 2000, | |
popover: 2100, | |
snackbar: 2900, | |
tooltip: 3000 | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 61 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactDom = __webpack_require__(62); | |
var _reactDom2 = _interopRequireDefault(_reactDom); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _clockNumber = __webpack_require__(204); | |
var _clockNumber2 = _interopRequireDefault(_clockNumber); | |
var _clockPointer = __webpack_require__(205); | |
var _clockPointer2 = _interopRequireDefault(_clockPointer); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function rad2deg(rad) { | |
return rad * 57.29577951308232; | |
} | |
function getTouchEventOffsetValues(e) { | |
var el = e.target; | |
var boundingRect = el.getBoundingClientRect(); | |
var offset = { | |
offsetX: e.clientX - boundingRect.left, | |
offsetY: e.clientY - boundingRect.top | |
}; | |
return offset; | |
} | |
var ClockHours = _react2.default.createClass({ | |
displayName: 'ClockHours', | |
propTypes: { | |
format: _react2.default.PropTypes.oneOf(['ampm', '24hr']), | |
initialHours: _react2.default.PropTypes.number, | |
onChange: _react2.default.PropTypes.func | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
initialHours: new Date().getHours(), | |
onChange: function onChange() {}, | |
format: 'ampm' | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentDidMount: function componentDidMount() { | |
var clockElement = _reactDom2.default.findDOMNode(this.refs.mask); | |
this.center = { | |
x: clockElement.offsetWidth / 2, | |
y: clockElement.offsetHeight / 2 | |
}; | |
this.basePoint = { | |
x: this.center.x, | |
y: 0 | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
center: { x: 0, y: 0 }, | |
basePoint: { x: 0, y: 0 }, | |
isMousePressed: function isMousePressed(e) { | |
if (typeof e.buttons === 'undefined') { | |
return e.nativeEvent.which; | |
} | |
return e.buttons; | |
}, | |
handleUp: function handleUp(e) { | |
e.preventDefault(); | |
this.setClock(e.nativeEvent, true); | |
}, | |
handleMove: function handleMove(e) { | |
e.preventDefault(); | |
if (this.isMousePressed(e) !== 1) return; | |
this.setClock(e.nativeEvent, false); | |
}, | |
handleTouchMove: function handleTouchMove(e) { | |
e.preventDefault(); | |
this.setClock(e.changedTouches[0], false); | |
}, | |
handleTouchEnd: function handleTouchEnd(e) { | |
e.preventDefault(); | |
this.setClock(e.changedTouches[0], true); | |
}, | |
setClock: function setClock(e, finish) { | |
if (typeof e.offsetX === 'undefined') { | |
var offset = getTouchEventOffsetValues(e); | |
e.offsetX = offset.offsetX; | |
e.offsetY = offset.offsetY; | |
} | |
var hours = this.getHours(e.offsetX, e.offsetY); | |
this.props.onChange(hours, finish); | |
}, | |
getHours: function getHours(offsetX, offsetY) { | |
var step = 30; | |
var x = offsetX - this.center.x; | |
var y = offsetY - this.center.y; | |
var cx = this.basePoint.x - this.center.x; | |
var cy = this.basePoint.y - this.center.y; | |
var atan = Math.atan2(cx, cy) - Math.atan2(x, y); | |
var deg = rad2deg(atan); | |
deg = Math.round(deg / step) * step; | |
deg %= 360; | |
var value = Math.floor(deg / step) || 0; | |
var delta = Math.pow(x, 2) + Math.pow(y, 2); | |
var distance = Math.sqrt(delta); | |
value = value || 12; | |
if (this.props.format === '24hr') { | |
if (distance < 90) { | |
value += 12; | |
value %= 24; | |
} | |
} else { | |
value %= 12; | |
} | |
return value; | |
}, | |
_getSelected: function _getSelected() { | |
var hour = this.props.initialHours; | |
if (this.props.format === 'ampm') { | |
hour %= 12; | |
hour = hour || 12; | |
} | |
return hour; | |
}, | |
_getHourNumbers: function _getHourNumbers() { | |
var _this = this; | |
var style = { | |
pointerEvents: 'none' | |
}; | |
var hourSize = this.props.format === 'ampm' ? 12 : 24; | |
var hours = []; | |
for (var i = 1; i <= hourSize; i++) { | |
hours.push(i % 24); | |
} | |
return hours.map(function (hour) { | |
var isSelected = _this._getSelected() === hour; | |
return _react2.default.createElement(_clockNumber2.default, { | |
key: hour, | |
style: style, | |
isSelected: isSelected, | |
type: 'hour', | |
value: hour | |
}); | |
}); | |
}, | |
render: function render() { | |
var styles = { | |
root: { | |
height: '100%', | |
width: '100%', | |
borderRadius: '100%', | |
position: 'relative', | |
pointerEvents: 'none', | |
boxSizing: 'border-box' | |
}, | |
hitMask: { | |
height: '100%', | |
width: '100%', | |
pointerEvents: 'auto' | |
} | |
}; | |
var hours = this._getSelected(); | |
var numbers = this._getHourNumbers(); | |
return _react2.default.createElement( | |
'div', | |
{ ref: 'clock', style: this.prepareStyles(styles.root) }, | |
_react2.default.createElement(_clockPointer2.default, { hasSelected: true, value: hours, type: 'hour' }), | |
numbers, | |
_react2.default.createElement('div', { | |
ref: 'mask', style: this.prepareStyles(styles.hitMask), onTouchMove: this.handleTouchMove, | |
onTouchEnd: this.handleTouchEnd, onMouseUp: this.handleUp, onMouseMove: this.handleMove | |
}) | |
); | |
} | |
}); | |
exports.default = ClockHours; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 62 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
module.exports = __webpack_require__(63); | |
/***/ }, | |
/* 63 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOM | |
*/ | |
/* globals __REACT_DEVTOOLS_GLOBAL_HOOK__*/ | |
'use strict'; | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactDOMTextComponent = __webpack_require__(65); | |
var ReactDefaultInjection = __webpack_require__(128); | |
var ReactInstanceHandles = __webpack_require__(102); | |
var ReactMount = __webpack_require__(86); | |
var ReactPerf = __webpack_require__(76); | |
var ReactReconciler = __webpack_require__(107); | |
var ReactUpdates = __webpack_require__(111); | |
var ReactVersion = __webpack_require__(202); | |
var findDOMNode = __webpack_require__(147); | |
var renderSubtreeIntoContainer = __webpack_require__(203); | |
var warning = __webpack_require__(83); | |
ReactDefaultInjection.inject(); | |
var render = ReactPerf.measure('React', 'render', ReactMount.render); | |
var React = { | |
findDOMNode: findDOMNode, | |
render: render, | |
unmountComponentAtNode: ReactMount.unmountComponentAtNode, | |
version: ReactVersion, | |
/* eslint-disable camelcase */ | |
unstable_batchedUpdates: ReactUpdates.batchedUpdates, | |
unstable_renderSubtreeIntoContainer: renderSubtreeIntoContainer | |
}; | |
// Inject the runtime into a devtools global hook regardless of browser. | |
// Allows for debugging when the hook is injected on the page. | |
/* eslint-enable camelcase */ | |
if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' && typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.inject === 'function') { | |
__REACT_DEVTOOLS_GLOBAL_HOOK__.inject({ | |
CurrentOwner: ReactCurrentOwner, | |
InstanceHandles: ReactInstanceHandles, | |
Mount: ReactMount, | |
Reconciler: ReactReconciler, | |
TextComponent: ReactDOMTextComponent | |
}); | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
var ExecutionEnvironment = __webpack_require__(68); | |
if (ExecutionEnvironment.canUseDOM && window.top === window.self) { | |
// First check if devtools is not installed | |
if (typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ === 'undefined') { | |
// If we're in Chrome or Firefox, provide a download link if not installed. | |
if (navigator.userAgent.indexOf('Chrome') > -1 && navigator.userAgent.indexOf('Edge') === -1 || navigator.userAgent.indexOf('Firefox') > -1) { | |
console.debug('Download the React DevTools for a better development experience: ' + 'https://fb.me/react-devtools'); | |
} | |
} | |
// If we're in IE8, check to see if we are in compatibility mode and provide | |
// information on preventing compatibility mode | |
var ieCompatibilityMode = document.documentMode && document.documentMode < 8; | |
process.env.NODE_ENV !== 'production' ? warning(!ieCompatibilityMode, 'Internet Explorer is running in compatibility mode; please add the ' + 'following tag to your HTML to prevent this from happening: ' + '<meta http-equiv="X-UA-Compatible" content="IE=edge" />') : undefined; | |
var expectedFeatures = [ | |
// shims | |
Array.isArray, Array.prototype.every, Array.prototype.forEach, Array.prototype.indexOf, Array.prototype.map, Date.now, Function.prototype.bind, Object.keys, String.prototype.split, String.prototype.trim, | |
// shams | |
Object.create, Object.freeze]; | |
for (var i = 0; i < expectedFeatures.length; i++) { | |
if (!expectedFeatures[i]) { | |
console.error('One or more ES5 shim/shams expected by React are not available: ' + 'https://fb.me/react-warning-polyfills'); | |
break; | |
} | |
} | |
} | |
} | |
module.exports = React; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 64 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactCurrentOwner | |
*/ | |
'use strict'; | |
/** | |
* Keeps track of the current owner. | |
* | |
* The current owner is the component who should own any components that are | |
* currently being constructed. | |
*/ | |
var ReactCurrentOwner = { | |
/** | |
* @internal | |
* @type {ReactComponent} | |
*/ | |
current: null | |
}; | |
module.exports = ReactCurrentOwner; | |
/***/ }, | |
/* 65 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMTextComponent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var DOMChildrenOperations = __webpack_require__(66); | |
var DOMPropertyOperations = __webpack_require__(80); | |
var ReactComponentBrowserEnvironment = __webpack_require__(84); | |
var ReactMount = __webpack_require__(86); | |
var assign = __webpack_require__(29); | |
var escapeTextContentForBrowser = __webpack_require__(79); | |
var setTextContent = __webpack_require__(78); | |
var validateDOMNesting = __webpack_require__(127); | |
/** | |
* Text nodes violate a couple assumptions that React makes about components: | |
* | |
* - When mounting text into the DOM, adjacent text nodes are merged. | |
* - Text nodes cannot be assigned a React root ID. | |
* | |
* This component is used to wrap strings in elements so that they can undergo | |
* the same reconciliation that is applied to elements. | |
* | |
* TODO: Investigate representing React components in the DOM with text nodes. | |
* | |
* @class ReactDOMTextComponent | |
* @extends ReactComponent | |
* @internal | |
*/ | |
var ReactDOMTextComponent = function (props) { | |
// This constructor and its argument is currently used by mocks. | |
}; | |
assign(ReactDOMTextComponent.prototype, { | |
/** | |
* @param {ReactText} text | |
* @internal | |
*/ | |
construct: function (text) { | |
// TODO: This is really a ReactText (ReactNode), not a ReactElement | |
this._currentElement = text; | |
this._stringText = '' + text; | |
// Properties | |
this._rootNodeID = null; | |
this._mountIndex = 0; | |
}, | |
/** | |
* Creates the markup for this text node. This node is not intended to have | |
* any features besides containing text content. | |
* | |
* @param {string} rootID DOM ID of the root node. | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @return {string} Markup for this text node. | |
* @internal | |
*/ | |
mountComponent: function (rootID, transaction, context) { | |
if (process.env.NODE_ENV !== 'production') { | |
if (context[validateDOMNesting.ancestorInfoContextKey]) { | |
validateDOMNesting('span', null, context[validateDOMNesting.ancestorInfoContextKey]); | |
} | |
} | |
this._rootNodeID = rootID; | |
if (transaction.useCreateElement) { | |
var ownerDocument = context[ReactMount.ownerDocumentContextKey]; | |
var el = ownerDocument.createElement('span'); | |
DOMPropertyOperations.setAttributeForID(el, rootID); | |
// Populate node cache | |
ReactMount.getID(el); | |
setTextContent(el, this._stringText); | |
return el; | |
} else { | |
var escapedText = escapeTextContentForBrowser(this._stringText); | |
if (transaction.renderToStaticMarkup) { | |
// Normally we'd wrap this in a `span` for the reasons stated above, but | |
// since this is a situation where React won't take over (static pages), | |
// we can simply return the text as it is. | |
return escapedText; | |
} | |
return '<span ' + DOMPropertyOperations.createMarkupForID(rootID) + '>' + escapedText + '</span>'; | |
} | |
}, | |
/** | |
* Updates this component by updating the text content. | |
* | |
* @param {ReactText} nextText The next text content | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
*/ | |
receiveComponent: function (nextText, transaction) { | |
if (nextText !== this._currentElement) { | |
this._currentElement = nextText; | |
var nextStringText = '' + nextText; | |
if (nextStringText !== this._stringText) { | |
// TODO: Save this as pending props and use performUpdateIfNecessary | |
// and/or updateComponent to do the actual update for consistency with | |
// other component types? | |
this._stringText = nextStringText; | |
var node = ReactMount.getNode(this._rootNodeID); | |
DOMChildrenOperations.updateTextContent(node, nextStringText); | |
} | |
} | |
}, | |
unmountComponent: function () { | |
ReactComponentBrowserEnvironment.unmountIDFromEnvironment(this._rootNodeID); | |
} | |
}); | |
module.exports = ReactDOMTextComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 66 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule DOMChildrenOperations | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var Danger = __webpack_require__(67); | |
var ReactMultiChildUpdateTypes = __webpack_require__(74); | |
var ReactPerf = __webpack_require__(76); | |
var setInnerHTML = __webpack_require__(77); | |
var setTextContent = __webpack_require__(78); | |
var invariant = __webpack_require__(31); | |
/** | |
* Inserts `childNode` as a child of `parentNode` at the `index`. | |
* | |
* @param {DOMElement} parentNode Parent node in which to insert. | |
* @param {DOMElement} childNode Child node to insert. | |
* @param {number} index Index at which to insert the child. | |
* @internal | |
*/ | |
function insertChildAt(parentNode, childNode, index) { | |
// By exploiting arrays returning `undefined` for an undefined index, we can | |
// rely exclusively on `insertBefore(node, null)` instead of also using | |
// `appendChild(node)`. However, using `undefined` is not allowed by all | |
// browsers so we must replace it with `null`. | |
// fix render order error in safari | |
// IE8 will throw error when index out of list size. | |
var beforeChild = index >= parentNode.childNodes.length ? null : parentNode.childNodes.item(index); | |
parentNode.insertBefore(childNode, beforeChild); | |
} | |
/** | |
* Operations for updating with DOM children. | |
*/ | |
var DOMChildrenOperations = { | |
dangerouslyReplaceNodeWithMarkup: Danger.dangerouslyReplaceNodeWithMarkup, | |
updateTextContent: setTextContent, | |
/** | |
* Updates a component's children by processing a series of updates. The | |
* update configurations are each expected to have a `parentNode` property. | |
* | |
* @param {array<object>} updates List of update configurations. | |
* @param {array<string>} markupList List of markup strings. | |
* @internal | |
*/ | |
processUpdates: function (updates, markupList) { | |
var update; | |
// Mapping from parent IDs to initial child orderings. | |
var initialChildren = null; | |
// List of children that will be moved or removed. | |
var updatedChildren = null; | |
for (var i = 0; i < updates.length; i++) { | |
update = updates[i]; | |
if (update.type === ReactMultiChildUpdateTypes.MOVE_EXISTING || update.type === ReactMultiChildUpdateTypes.REMOVE_NODE) { | |
var updatedIndex = update.fromIndex; | |
var updatedChild = update.parentNode.childNodes[updatedIndex]; | |
var parentID = update.parentID; | |
!updatedChild ? process.env.NODE_ENV !== 'production' ? invariant(false, 'processUpdates(): Unable to find child %s of element. This ' + 'probably means the DOM was unexpectedly mutated (e.g., by the ' + 'browser), usually due to forgetting a <tbody> when using tables, ' + 'nesting tags like <form>, <p>, or <a>, or using non-SVG elements ' + 'in an <svg> parent. Try inspecting the child nodes of the element ' + 'with React ID `%s`.', updatedIndex, parentID) : invariant(false) : undefined; | |
initialChildren = initialChildren || {}; | |
initialChildren[parentID] = initialChildren[parentID] || []; | |
initialChildren[parentID][updatedIndex] = updatedChild; | |
updatedChildren = updatedChildren || []; | |
updatedChildren.push(updatedChild); | |
} | |
} | |
var renderedMarkup; | |
// markupList is either a list of markup or just a list of elements | |
if (markupList.length && typeof markupList[0] === 'string') { | |
renderedMarkup = Danger.dangerouslyRenderMarkup(markupList); | |
} else { | |
renderedMarkup = markupList; | |
} | |
// Remove updated children first so that `toIndex` is consistent. | |
if (updatedChildren) { | |
for (var j = 0; j < updatedChildren.length; j++) { | |
updatedChildren[j].parentNode.removeChild(updatedChildren[j]); | |
} | |
} | |
for (var k = 0; k < updates.length; k++) { | |
update = updates[k]; | |
switch (update.type) { | |
case ReactMultiChildUpdateTypes.INSERT_MARKUP: | |
insertChildAt(update.parentNode, renderedMarkup[update.markupIndex], update.toIndex); | |
break; | |
case ReactMultiChildUpdateTypes.MOVE_EXISTING: | |
insertChildAt(update.parentNode, initialChildren[update.parentID][update.fromIndex], update.toIndex); | |
break; | |
case ReactMultiChildUpdateTypes.SET_MARKUP: | |
setInnerHTML(update.parentNode, update.content); | |
break; | |
case ReactMultiChildUpdateTypes.TEXT_CONTENT: | |
setTextContent(update.parentNode, update.content); | |
break; | |
case ReactMultiChildUpdateTypes.REMOVE_NODE: | |
// Already removed by the for-loop above. | |
break; | |
} | |
} | |
} | |
}; | |
ReactPerf.measureMethods(DOMChildrenOperations, 'DOMChildrenOperations', { | |
updateTextContent: 'updateTextContent' | |
}); | |
module.exports = DOMChildrenOperations; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 67 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule Danger | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var createNodesFromMarkup = __webpack_require__(69); | |
var emptyFunction = __webpack_require__(73); | |
var getMarkupWrap = __webpack_require__(72); | |
var invariant = __webpack_require__(31); | |
var OPEN_TAG_NAME_EXP = /^(<[^ \/>]+)/; | |
var RESULT_INDEX_ATTR = 'data-danger-index'; | |
/** | |
* Extracts the `nodeName` from a string of markup. | |
* | |
* NOTE: Extracting the `nodeName` does not require a regular expression match | |
* because we make assumptions about React-generated markup (i.e. there are no | |
* spaces surrounding the opening tag and there is at least one attribute). | |
* | |
* @param {string} markup String of markup. | |
* @return {string} Node name of the supplied markup. | |
* @see http://jsperf.com/extract-nodename | |
*/ | |
function getNodeName(markup) { | |
return markup.substring(1, markup.indexOf(' ')); | |
} | |
var Danger = { | |
/** | |
* Renders markup into an array of nodes. The markup is expected to render | |
* into a list of root nodes. Also, the length of `resultList` and | |
* `markupList` should be the same. | |
* | |
* @param {array<string>} markupList List of markup strings to render. | |
* @return {array<DOMElement>} List of rendered nodes. | |
* @internal | |
*/ | |
dangerouslyRenderMarkup: function (markupList) { | |
!ExecutionEnvironment.canUseDOM ? process.env.NODE_ENV !== 'production' ? invariant(false, 'dangerouslyRenderMarkup(...): Cannot render markup in a worker ' + 'thread. Make sure `window` and `document` are available globally ' + 'before requiring React when unit testing or use ' + 'ReactDOMServer.renderToString for server rendering.') : invariant(false) : undefined; | |
var nodeName; | |
var markupByNodeName = {}; | |
// Group markup by `nodeName` if a wrap is necessary, else by '*'. | |
for (var i = 0; i < markupList.length; i++) { | |
!markupList[i] ? process.env.NODE_ENV !== 'production' ? invariant(false, 'dangerouslyRenderMarkup(...): Missing markup.') : invariant(false) : undefined; | |
nodeName = getNodeName(markupList[i]); | |
nodeName = getMarkupWrap(nodeName) ? nodeName : '*'; | |
markupByNodeName[nodeName] = markupByNodeName[nodeName] || []; | |
markupByNodeName[nodeName][i] = markupList[i]; | |
} | |
var resultList = []; | |
var resultListAssignmentCount = 0; | |
for (nodeName in markupByNodeName) { | |
if (!markupByNodeName.hasOwnProperty(nodeName)) { | |
continue; | |
} | |
var markupListByNodeName = markupByNodeName[nodeName]; | |
// This for-in loop skips the holes of the sparse array. The order of | |
// iteration should follow the order of assignment, which happens to match | |
// numerical index order, but we don't rely on that. | |
var resultIndex; | |
for (resultIndex in markupListByNodeName) { | |
if (markupListByNodeName.hasOwnProperty(resultIndex)) { | |
var markup = markupListByNodeName[resultIndex]; | |
// Push the requested markup with an additional RESULT_INDEX_ATTR | |
// attribute. If the markup does not start with a < character, it | |
// will be discarded below (with an appropriate console.error). | |
markupListByNodeName[resultIndex] = markup.replace(OPEN_TAG_NAME_EXP, | |
// This index will be parsed back out below. | |
'$1 ' + RESULT_INDEX_ATTR + '="' + resultIndex + '" '); | |
} | |
} | |
// Render each group of markup with similar wrapping `nodeName`. | |
var renderNodes = createNodesFromMarkup(markupListByNodeName.join(''), emptyFunction // Do nothing special with <script> tags. | |
); | |
for (var j = 0; j < renderNodes.length; ++j) { | |
var renderNode = renderNodes[j]; | |
if (renderNode.hasAttribute && renderNode.hasAttribute(RESULT_INDEX_ATTR)) { | |
resultIndex = +renderNode.getAttribute(RESULT_INDEX_ATTR); | |
renderNode.removeAttribute(RESULT_INDEX_ATTR); | |
!!resultList.hasOwnProperty(resultIndex) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Danger: Assigning to an already-occupied result index.') : invariant(false) : undefined; | |
resultList[resultIndex] = renderNode; | |
// This should match resultList.length and markupList.length when | |
// we're done. | |
resultListAssignmentCount += 1; | |
} else if (process.env.NODE_ENV !== 'production') { | |
console.error('Danger: Discarding unexpected node:', renderNode); | |
} | |
} | |
} | |
// Although resultList was populated out of order, it should now be a dense | |
// array. | |
!(resultListAssignmentCount === resultList.length) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Danger: Did not assign to every index of resultList.') : invariant(false) : undefined; | |
!(resultList.length === markupList.length) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Danger: Expected markup to render %s nodes, but rendered %s.', markupList.length, resultList.length) : invariant(false) : undefined; | |
return resultList; | |
}, | |
/** | |
* Replaces a node with a string of markup at its current position within its | |
* parent. The markup must render into a single root node. | |
* | |
* @param {DOMElement} oldChild Child node to replace. | |
* @param {string} markup Markup to render in place of the child node. | |
* @internal | |
*/ | |
dangerouslyReplaceNodeWithMarkup: function (oldChild, markup) { | |
!ExecutionEnvironment.canUseDOM ? process.env.NODE_ENV !== 'production' ? invariant(false, 'dangerouslyReplaceNodeWithMarkup(...): Cannot render markup in a ' + 'worker thread. Make sure `window` and `document` are available ' + 'globally before requiring React when unit testing or use ' + 'ReactDOMServer.renderToString() for server rendering.') : invariant(false) : undefined; | |
!markup ? process.env.NODE_ENV !== 'production' ? invariant(false, 'dangerouslyReplaceNodeWithMarkup(...): Missing markup.') : invariant(false) : undefined; | |
!(oldChild.tagName.toLowerCase() !== 'html') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'dangerouslyReplaceNodeWithMarkup(...): Cannot replace markup of the ' + '<html> node. This is because browser quirks make this unreliable ' + 'and/or slow. If you want to render to the root you must use ' + 'server rendering. See ReactDOMServer.renderToString().') : invariant(false) : undefined; | |
var newChild; | |
if (typeof markup === 'string') { | |
newChild = createNodesFromMarkup(markup, emptyFunction)[0]; | |
} else { | |
newChild = markup; | |
} | |
oldChild.parentNode.replaceChild(newChild, oldChild); | |
} | |
}; | |
module.exports = Danger; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 68 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ExecutionEnvironment | |
*/ | |
'use strict'; | |
var canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement); | |
/** | |
* Simple, lightweight module assisting with the detection and context of | |
* Worker. Helps avoid circular dependencies and allows code to reason about | |
* whether or not they are in a Worker, even if they never include the main | |
* `ReactWorker` dependency. | |
*/ | |
var ExecutionEnvironment = { | |
canUseDOM: canUseDOM, | |
canUseWorkers: typeof Worker !== 'undefined', | |
canUseEventListeners: canUseDOM && !!(window.addEventListener || window.attachEvent), | |
canUseViewport: canUseDOM && !!window.screen, | |
isInWorker: !canUseDOM // For now, this is true - might change in the future. | |
}; | |
module.exports = ExecutionEnvironment; | |
/***/ }, | |
/* 69 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule createNodesFromMarkup | |
* @typechecks | |
*/ | |
/*eslint-disable fb-www/unsafe-html*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var createArrayFromMixed = __webpack_require__(70); | |
var getMarkupWrap = __webpack_require__(72); | |
var invariant = __webpack_require__(31); | |
/** | |
* Dummy container used to render all markup. | |
*/ | |
var dummyNode = ExecutionEnvironment.canUseDOM ? document.createElement('div') : null; | |
/** | |
* Pattern used by `getNodeName`. | |
*/ | |
var nodeNamePattern = /^\s*<(\w+)/; | |
/** | |
* Extracts the `nodeName` of the first element in a string of markup. | |
* | |
* @param {string} markup String of markup. | |
* @return {?string} Node name of the supplied markup. | |
*/ | |
function getNodeName(markup) { | |
var nodeNameMatch = markup.match(nodeNamePattern); | |
return nodeNameMatch && nodeNameMatch[1].toLowerCase(); | |
} | |
/** | |
* Creates an array containing the nodes rendered from the supplied markup. The | |
* optionally supplied `handleScript` function will be invoked once for each | |
* <script> element that is rendered. If no `handleScript` function is supplied, | |
* an exception is thrown if any <script> elements are rendered. | |
* | |
* @param {string} markup A string of valid HTML markup. | |
* @param {?function} handleScript Invoked once for each rendered <script>. | |
* @return {array<DOMElement|DOMTextNode>} An array of rendered nodes. | |
*/ | |
function createNodesFromMarkup(markup, handleScript) { | |
var node = dummyNode; | |
!!!dummyNode ? process.env.NODE_ENV !== 'production' ? invariant(false, 'createNodesFromMarkup dummy not initialized') : invariant(false) : undefined; | |
var nodeName = getNodeName(markup); | |
var wrap = nodeName && getMarkupWrap(nodeName); | |
if (wrap) { | |
node.innerHTML = wrap[1] + markup + wrap[2]; | |
var wrapDepth = wrap[0]; | |
while (wrapDepth--) { | |
node = node.lastChild; | |
} | |
} else { | |
node.innerHTML = markup; | |
} | |
var scripts = node.getElementsByTagName('script'); | |
if (scripts.length) { | |
!handleScript ? process.env.NODE_ENV !== 'production' ? invariant(false, 'createNodesFromMarkup(...): Unexpected <script> element rendered.') : invariant(false) : undefined; | |
createArrayFromMixed(scripts).forEach(handleScript); | |
} | |
var nodes = createArrayFromMixed(node.childNodes); | |
while (node.lastChild) { | |
node.removeChild(node.lastChild); | |
} | |
return nodes; | |
} | |
module.exports = createNodesFromMarkup; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 70 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule createArrayFromMixed | |
* @typechecks | |
*/ | |
'use strict'; | |
var toArray = __webpack_require__(71); | |
/** | |
* Perform a heuristic test to determine if an object is "array-like". | |
* | |
* A monk asked Joshu, a Zen master, "Has a dog Buddha nature?" | |
* Joshu replied: "Mu." | |
* | |
* This function determines if its argument has "array nature": it returns | |
* true if the argument is an actual array, an `arguments' object, or an | |
* HTMLCollection (e.g. node.childNodes or node.getElementsByTagName()). | |
* | |
* It will return false for other array-like objects like Filelist. | |
* | |
* @param {*} obj | |
* @return {boolean} | |
*/ | |
function hasArrayNature(obj) { | |
return( | |
// not null/false | |
!!obj && ( | |
// arrays are objects, NodeLists are functions in Safari | |
typeof obj == 'object' || typeof obj == 'function') && | |
// quacks like an array | |
'length' in obj && | |
// not window | |
!('setInterval' in obj) && | |
// no DOM node should be considered an array-like | |
// a 'select' element has 'length' and 'item' properties on IE8 | |
typeof obj.nodeType != 'number' && ( | |
// a real array | |
Array.isArray(obj) || | |
// arguments | |
'callee' in obj || | |
// HTMLCollection/NodeList | |
'item' in obj) | |
); | |
} | |
/** | |
* Ensure that the argument is an array by wrapping it in an array if it is not. | |
* Creates a copy of the argument if it is already an array. | |
* | |
* This is mostly useful idiomatically: | |
* | |
* var createArrayFromMixed = require('createArrayFromMixed'); | |
* | |
* function takesOneOrMoreThings(things) { | |
* things = createArrayFromMixed(things); | |
* ... | |
* } | |
* | |
* This allows you to treat `things' as an array, but accept scalars in the API. | |
* | |
* If you need to convert an array-like object, like `arguments`, into an array | |
* use toArray instead. | |
* | |
* @param {*} obj | |
* @return {array} | |
*/ | |
function createArrayFromMixed(obj) { | |
if (!hasArrayNature(obj)) { | |
return [obj]; | |
} else if (Array.isArray(obj)) { | |
return obj.slice(); | |
} else { | |
return toArray(obj); | |
} | |
} | |
module.exports = createArrayFromMixed; | |
/***/ }, | |
/* 71 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule toArray | |
* @typechecks | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* Convert array-like objects to arrays. | |
* | |
* This API assumes the caller knows the contents of the data type. For less | |
* well defined inputs use createArrayFromMixed. | |
* | |
* @param {object|function|filelist} obj | |
* @return {array} | |
*/ | |
function toArray(obj) { | |
var length = obj.length; | |
// Some browse builtin objects can report typeof 'function' (e.g. NodeList in | |
// old versions of Safari). | |
!(!Array.isArray(obj) && (typeof obj === 'object' || typeof obj === 'function')) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'toArray: Array-like object expected') : invariant(false) : undefined; | |
!(typeof length === 'number') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'toArray: Object needs a length property') : invariant(false) : undefined; | |
!(length === 0 || length - 1 in obj) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'toArray: Object should have keys for indices') : invariant(false) : undefined; | |
// Old IE doesn't give collections access to hasOwnProperty. Assume inputs | |
// without method will throw during the slice call and skip straight to the | |
// fallback. | |
if (obj.hasOwnProperty) { | |
try { | |
return Array.prototype.slice.call(obj); | |
} catch (e) { | |
// IE < 9 does not support Array#slice on collections objects | |
} | |
} | |
// Fall back to copying key by key. This assumes all keys have a value, | |
// so will not preserve sparsely populated inputs. | |
var ret = Array(length); | |
for (var ii = 0; ii < length; ii++) { | |
ret[ii] = obj[ii]; | |
} | |
return ret; | |
} | |
module.exports = toArray; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 72 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getMarkupWrap | |
*/ | |
/*eslint-disable fb-www/unsafe-html */ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var invariant = __webpack_require__(31); | |
/** | |
* Dummy container used to detect which wraps are necessary. | |
*/ | |
var dummyNode = ExecutionEnvironment.canUseDOM ? document.createElement('div') : null; | |
/** | |
* Some browsers cannot use `innerHTML` to render certain elements standalone, | |
* so we wrap them, render the wrapped nodes, then extract the desired node. | |
* | |
* In IE8, certain elements cannot render alone, so wrap all elements ('*'). | |
*/ | |
var shouldWrap = {}; | |
var selectWrap = [1, '<select multiple="true">', '</select>']; | |
var tableWrap = [1, '<table>', '</table>']; | |
var trWrap = [3, '<table><tbody><tr>', '</tr></tbody></table>']; | |
var svgWrap = [1, '<svg xmlns="http://www.w3.org/2000/svg">', '</svg>']; | |
var markupWrap = { | |
'*': [1, '?<div>', '</div>'], | |
'area': [1, '<map>', '</map>'], | |
'col': [2, '<table><tbody></tbody><colgroup>', '</colgroup></table>'], | |
'legend': [1, '<fieldset>', '</fieldset>'], | |
'param': [1, '<object>', '</object>'], | |
'tr': [2, '<table><tbody>', '</tbody></table>'], | |
'optgroup': selectWrap, | |
'option': selectWrap, | |
'caption': tableWrap, | |
'colgroup': tableWrap, | |
'tbody': tableWrap, | |
'tfoot': tableWrap, | |
'thead': tableWrap, | |
'td': trWrap, | |
'th': trWrap | |
}; | |
// Initialize the SVG elements since we know they'll always need to be wrapped | |
// consistently. If they are created inside a <div> they will be initialized in | |
// the wrong namespace (and will not display). | |
var svgElements = ['circle', 'clipPath', 'defs', 'ellipse', 'g', 'image', 'line', 'linearGradient', 'mask', 'path', 'pattern', 'polygon', 'polyline', 'radialGradient', 'rect', 'stop', 'text', 'tspan']; | |
svgElements.forEach(function (nodeName) { | |
markupWrap[nodeName] = svgWrap; | |
shouldWrap[nodeName] = true; | |
}); | |
/** | |
* Gets the markup wrap configuration for the supplied `nodeName`. | |
* | |
* NOTE: This lazily detects which wraps are necessary for the current browser. | |
* | |
* @param {string} nodeName Lowercase `nodeName`. | |
* @return {?array} Markup wrap configuration, if applicable. | |
*/ | |
function getMarkupWrap(nodeName) { | |
!!!dummyNode ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Markup wrapping node not initialized') : invariant(false) : undefined; | |
if (!markupWrap.hasOwnProperty(nodeName)) { | |
nodeName = '*'; | |
} | |
if (!shouldWrap.hasOwnProperty(nodeName)) { | |
if (nodeName === '*') { | |
dummyNode.innerHTML = '<link />'; | |
} else { | |
dummyNode.innerHTML = '<' + nodeName + '></' + nodeName + '>'; | |
} | |
shouldWrap[nodeName] = !dummyNode.firstChild; | |
} | |
return shouldWrap[nodeName] ? markupWrap[nodeName] : null; | |
} | |
module.exports = getMarkupWrap; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 73 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule emptyFunction | |
*/ | |
"use strict"; | |
function makeEmptyFunction(arg) { | |
return function () { | |
return arg; | |
}; | |
} | |
/** | |
* This function accepts and discards inputs; it has no side effects. This is | |
* primarily useful idiomatically for overridable function endpoints which | |
* always need to be callable, since JS lacks a null-call idiom ala Cocoa. | |
*/ | |
function emptyFunction() {} | |
emptyFunction.thatReturns = makeEmptyFunction; | |
emptyFunction.thatReturnsFalse = makeEmptyFunction(false); | |
emptyFunction.thatReturnsTrue = makeEmptyFunction(true); | |
emptyFunction.thatReturnsNull = makeEmptyFunction(null); | |
emptyFunction.thatReturnsThis = function () { | |
return this; | |
}; | |
emptyFunction.thatReturnsArgument = function (arg) { | |
return arg; | |
}; | |
module.exports = emptyFunction; | |
/***/ }, | |
/* 74 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactMultiChildUpdateTypes | |
*/ | |
'use strict'; | |
var keyMirror = __webpack_require__(75); | |
/** | |
* When a component's children are updated, a series of update configuration | |
* objects are created in order to batch and serialize the required changes. | |
* | |
* Enumerates all the possible types of update configurations. | |
* | |
* @internal | |
*/ | |
var ReactMultiChildUpdateTypes = keyMirror({ | |
INSERT_MARKUP: null, | |
MOVE_EXISTING: null, | |
REMOVE_NODE: null, | |
SET_MARKUP: null, | |
TEXT_CONTENT: null | |
}); | |
module.exports = ReactMultiChildUpdateTypes; | |
/***/ }, | |
/* 75 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule keyMirror | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* Constructs an enumeration with keys equal to their value. | |
* | |
* For example: | |
* | |
* var COLORS = keyMirror({blue: null, red: null}); | |
* var myColor = COLORS.blue; | |
* var isColorValid = !!COLORS[myColor]; | |
* | |
* The last line could not be performed if the values of the generated enum were | |
* not equal to their keys. | |
* | |
* Input: {key1: val1, key2: val2} | |
* Output: {key1: key1, key2: key2} | |
* | |
* @param {object} obj | |
* @return {object} | |
*/ | |
var keyMirror = function (obj) { | |
var ret = {}; | |
var key; | |
!(obj instanceof Object && !Array.isArray(obj)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'keyMirror(...): Argument must be an object.') : invariant(false) : undefined; | |
for (key in obj) { | |
if (!obj.hasOwnProperty(key)) { | |
continue; | |
} | |
ret[key] = key; | |
} | |
return ret; | |
}; | |
module.exports = keyMirror; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 76 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactPerf | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* ReactPerf is a general AOP system designed to measure performance. This | |
* module only has the hooks: see ReactDefaultPerf for the analysis tool. | |
*/ | |
var ReactPerf = { | |
/** | |
* Boolean to enable/disable measurement. Set to false by default to prevent | |
* accidental logging and perf loss. | |
*/ | |
enableMeasure: false, | |
/** | |
* Holds onto the measure function in use. By default, don't measure | |
* anything, but we'll override this if we inject a measure function. | |
*/ | |
storedMeasure: _noMeasure, | |
/** | |
* @param {object} object | |
* @param {string} objectName | |
* @param {object<string>} methodNames | |
*/ | |
measureMethods: function (object, objectName, methodNames) { | |
if (process.env.NODE_ENV !== 'production') { | |
for (var key in methodNames) { | |
if (!methodNames.hasOwnProperty(key)) { | |
continue; | |
} | |
object[key] = ReactPerf.measure(objectName, methodNames[key], object[key]); | |
} | |
} | |
}, | |
/** | |
* Use this to wrap methods you want to measure. Zero overhead in production. | |
* | |
* @param {string} objName | |
* @param {string} fnName | |
* @param {function} func | |
* @return {function} | |
*/ | |
measure: function (objName, fnName, func) { | |
if (process.env.NODE_ENV !== 'production') { | |
var measuredFunc = null; | |
var wrapper = function () { | |
if (ReactPerf.enableMeasure) { | |
if (!measuredFunc) { | |
measuredFunc = ReactPerf.storedMeasure(objName, fnName, func); | |
} | |
return measuredFunc.apply(this, arguments); | |
} | |
return func.apply(this, arguments); | |
}; | |
wrapper.displayName = objName + '_' + fnName; | |
return wrapper; | |
} | |
return func; | |
}, | |
injection: { | |
/** | |
* @param {function} measure | |
*/ | |
injectMeasure: function (measure) { | |
ReactPerf.storedMeasure = measure; | |
} | |
} | |
}; | |
/** | |
* Simply passes through the measured function, without measuring it. | |
* | |
* @param {string} objName | |
* @param {string} fnName | |
* @param {function} func | |
* @return {function} | |
*/ | |
function _noMeasure(objName, fnName, func) { | |
return func; | |
} | |
module.exports = ReactPerf; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 77 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule setInnerHTML | |
*/ | |
/* globals MSApp */ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var WHITESPACE_TEST = /^[ | |
]/; | |
var NONVISIBLE_TEST = /<(!--|link|noscript|meta|script|style)[ | |
\/>]/; | |
/** | |
* Set the innerHTML property of a node, ensuring that whitespace is preserved | |
* even in IE8. | |
* | |
* @param {DOMElement} node | |
* @param {string} html | |
* @internal | |
*/ | |
var setInnerHTML = function (node, html) { | |
node.innerHTML = html; | |
}; | |
// Win8 apps: Allow all html to be inserted | |
if (typeof MSApp !== 'undefined' && MSApp.execUnsafeLocalFunction) { | |
setInnerHTML = function (node, html) { | |
MSApp.execUnsafeLocalFunction(function () { | |
node.innerHTML = html; | |
}); | |
}; | |
} | |
if (ExecutionEnvironment.canUseDOM) { | |
// IE8: When updating a just created node with innerHTML only leading | |
// whitespace is removed. When updating an existing node with innerHTML | |
// whitespace in root TextNodes is also collapsed. | |
// @see quirksmode.org/bugreports/archives/2004/11/innerhtml_and_t.html | |
// Feature detection; only IE8 is known to behave improperly like this. | |
var testElement = document.createElement('div'); | |
testElement.innerHTML = ' '; | |
if (testElement.innerHTML === '') { | |
setInnerHTML = function (node, html) { | |
// Magic theory: IE8 supposedly differentiates between added and updated | |
// nodes when processing innerHTML, innerHTML on updated nodes suffers | |
// from worse whitespace behavior. Re-adding a node like this triggers | |
// the initial and more favorable whitespace behavior. | |
// TODO: What to do on a detached node? | |
if (node.parentNode) { | |
node.parentNode.replaceChild(node, node); | |
} | |
// We also implement a workaround for non-visible tags disappearing into | |
// thin air on IE8, this only happens if there is no visible text | |
// in-front of the non-visible tags. Piggyback on the whitespace fix | |
// and simply check if any non-visible tags appear in the source. | |
if (WHITESPACE_TEST.test(html) || html[0] === '<' && NONVISIBLE_TEST.test(html)) { | |
// Recover leading whitespace by temporarily prepending any character. | |
// has the potential advantage of being zero-width/invisible. | |
// UglifyJS drops U+FEFF chars when parsing, so use String.fromCharCode | |
// in hopes that this is preserved even if "" is transformed to | |
// the actual Unicode character (by Babel, for example). | |
// https://github.com/mishoo/UglifyJS2/blob/v2.4.20/lib/parse.js#L216 | |
node.innerHTML = String.fromCharCode(0xFEFF) + html; | |
// deleteData leaves an empty `TextNode` which offsets the index of all | |
// children. Definitely want to avoid this. | |
var textNode = node.firstChild; | |
if (textNode.data.length === 1) { | |
node.removeChild(textNode); | |
} else { | |
textNode.deleteData(0, 1); | |
} | |
} else { | |
node.innerHTML = html; | |
} | |
}; | |
} | |
} | |
module.exports = setInnerHTML; | |
/***/ }, | |
/* 78 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule setTextContent | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var escapeTextContentForBrowser = __webpack_require__(79); | |
var setInnerHTML = __webpack_require__(77); | |
/** | |
* Set the textContent property of a node, ensuring that whitespace is preserved | |
* even in IE8. innerText is a poor substitute for textContent and, among many | |
* issues, inserts <br> instead of the literal newline chars. innerHTML behaves | |
* as it should. | |
* | |
* @param {DOMElement} node | |
* @param {string} text | |
* @internal | |
*/ | |
var setTextContent = function (node, text) { | |
node.textContent = text; | |
}; | |
if (ExecutionEnvironment.canUseDOM) { | |
if (!('textContent' in document.documentElement)) { | |
setTextContent = function (node, text) { | |
setInnerHTML(node, escapeTextContentForBrowser(text)); | |
}; | |
} | |
} | |
module.exports = setTextContent; | |
/***/ }, | |
/* 79 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule escapeTextContentForBrowser | |
*/ | |
'use strict'; | |
var ESCAPE_LOOKUP = { | |
'&': '&', | |
'>': '>', | |
'<': '<', | |
'"': '"', | |
'\'': ''' | |
}; | |
var ESCAPE_REGEX = /[&><"']/g; | |
function escaper(match) { | |
return ESCAPE_LOOKUP[match]; | |
} | |
/** | |
* Escapes text to prevent scripting attacks. | |
* | |
* @param {*} text Text value to escape. | |
* @return {string} An escaped string. | |
*/ | |
function escapeTextContentForBrowser(text) { | |
return ('' + text).replace(ESCAPE_REGEX, escaper); | |
} | |
module.exports = escapeTextContentForBrowser; | |
/***/ }, | |
/* 80 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule DOMPropertyOperations | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var ReactPerf = __webpack_require__(76); | |
var quoteAttributeValueForBrowser = __webpack_require__(82); | |
var warning = __webpack_require__(83); | |
// Simplified subset | |
var VALID_ATTRIBUTE_NAME_REGEX = /^[a-zA-Z_][\w\.\-]*$/; | |
var illegalAttributeNameCache = {}; | |
var validatedAttributeNameCache = {}; | |
function isAttributeNameSafe(attributeName) { | |
if (validatedAttributeNameCache.hasOwnProperty(attributeName)) { | |
return true; | |
} | |
if (illegalAttributeNameCache.hasOwnProperty(attributeName)) { | |
return false; | |
} | |
if (VALID_ATTRIBUTE_NAME_REGEX.test(attributeName)) { | |
validatedAttributeNameCache[attributeName] = true; | |
return true; | |
} | |
illegalAttributeNameCache[attributeName] = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Invalid attribute name: `%s`', attributeName) : undefined; | |
return false; | |
} | |
function shouldIgnoreValue(propertyInfo, value) { | |
return value == null || propertyInfo.hasBooleanValue && !value || propertyInfo.hasNumericValue && isNaN(value) || propertyInfo.hasPositiveNumericValue && value < 1 || propertyInfo.hasOverloadedBooleanValue && value === false; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
var reactProps = { | |
children: true, | |
dangerouslySetInnerHTML: true, | |
key: true, | |
ref: true | |
}; | |
var warnedProperties = {}; | |
var warnUnknownProperty = function (name) { | |
if (reactProps.hasOwnProperty(name) && reactProps[name] || warnedProperties.hasOwnProperty(name) && warnedProperties[name]) { | |
return; | |
} | |
warnedProperties[name] = true; | |
var lowerCasedName = name.toLowerCase(); | |
// data-* attributes should be lowercase; suggest the lowercase version | |
var standardName = DOMProperty.isCustomAttribute(lowerCasedName) ? lowerCasedName : DOMProperty.getPossibleStandardName.hasOwnProperty(lowerCasedName) ? DOMProperty.getPossibleStandardName[lowerCasedName] : null; | |
// For now, only warn when we have a suggested correction. This prevents | |
// logging too much when using transferPropsTo. | |
process.env.NODE_ENV !== 'production' ? warning(standardName == null, 'Unknown DOM property %s. Did you mean %s?', name, standardName) : undefined; | |
}; | |
} | |
/** | |
* Operations for dealing with DOM properties. | |
*/ | |
var DOMPropertyOperations = { | |
/** | |
* Creates markup for the ID property. | |
* | |
* @param {string} id Unescaped ID. | |
* @return {string} Markup string. | |
*/ | |
createMarkupForID: function (id) { | |
return DOMProperty.ID_ATTRIBUTE_NAME + '=' + quoteAttributeValueForBrowser(id); | |
}, | |
setAttributeForID: function (node, id) { | |
node.setAttribute(DOMProperty.ID_ATTRIBUTE_NAME, id); | |
}, | |
/** | |
* Creates markup for a property. | |
* | |
* @param {string} name | |
* @param {*} value | |
* @return {?string} Markup string, or null if the property was invalid. | |
*/ | |
createMarkupForProperty: function (name, value) { | |
var propertyInfo = DOMProperty.properties.hasOwnProperty(name) ? DOMProperty.properties[name] : null; | |
if (propertyInfo) { | |
if (shouldIgnoreValue(propertyInfo, value)) { | |
return ''; | |
} | |
var attributeName = propertyInfo.attributeName; | |
if (propertyInfo.hasBooleanValue || propertyInfo.hasOverloadedBooleanValue && value === true) { | |
return attributeName + '=""'; | |
} | |
return attributeName + '=' + quoteAttributeValueForBrowser(value); | |
} else if (DOMProperty.isCustomAttribute(name)) { | |
if (value == null) { | |
return ''; | |
} | |
return name + '=' + quoteAttributeValueForBrowser(value); | |
} else if (process.env.NODE_ENV !== 'production') { | |
warnUnknownProperty(name); | |
} | |
return null; | |
}, | |
/** | |
* Creates markup for a custom property. | |
* | |
* @param {string} name | |
* @param {*} value | |
* @return {string} Markup string, or empty string if the property was invalid. | |
*/ | |
createMarkupForCustomAttribute: function (name, value) { | |
if (!isAttributeNameSafe(name) || value == null) { | |
return ''; | |
} | |
return name + '=' + quoteAttributeValueForBrowser(value); | |
}, | |
/** | |
* Sets the value for a property on a node. | |
* | |
* @param {DOMElement} node | |
* @param {string} name | |
* @param {*} value | |
*/ | |
setValueForProperty: function (node, name, value) { | |
var propertyInfo = DOMProperty.properties.hasOwnProperty(name) ? DOMProperty.properties[name] : null; | |
if (propertyInfo) { | |
var mutationMethod = propertyInfo.mutationMethod; | |
if (mutationMethod) { | |
mutationMethod(node, value); | |
} else if (shouldIgnoreValue(propertyInfo, value)) { | |
this.deleteValueForProperty(node, name); | |
} else if (propertyInfo.mustUseAttribute) { | |
var attributeName = propertyInfo.attributeName; | |
var namespace = propertyInfo.attributeNamespace; | |
// `setAttribute` with objects becomes only `[object]` in IE8/9, | |
// ('' + value) makes it output the correct toString()-value. | |
if (namespace) { | |
node.setAttributeNS(namespace, attributeName, '' + value); | |
} else if (propertyInfo.hasBooleanValue || propertyInfo.hasOverloadedBooleanValue && value === true) { | |
node.setAttribute(attributeName, ''); | |
} else { | |
node.setAttribute(attributeName, '' + value); | |
} | |
} else { | |
var propName = propertyInfo.propertyName; | |
// Must explicitly cast values for HAS_SIDE_EFFECTS-properties to the | |
// property type before comparing; only `value` does and is string. | |
if (!propertyInfo.hasSideEffects || '' + node[propName] !== '' + value) { | |
// Contrary to `setAttribute`, object properties are properly | |
// `toString`ed by IE8/9. | |
node[propName] = value; | |
} | |
} | |
} else if (DOMProperty.isCustomAttribute(name)) { | |
DOMPropertyOperations.setValueForAttribute(node, name, value); | |
} else if (process.env.NODE_ENV !== 'production') { | |
warnUnknownProperty(name); | |
} | |
}, | |
setValueForAttribute: function (node, name, value) { | |
if (!isAttributeNameSafe(name)) { | |
return; | |
} | |
if (value == null) { | |
node.removeAttribute(name); | |
} else { | |
node.setAttribute(name, '' + value); | |
} | |
}, | |
/** | |
* Deletes the value for a property on a node. | |
* | |
* @param {DOMElement} node | |
* @param {string} name | |
*/ | |
deleteValueForProperty: function (node, name) { | |
var propertyInfo = DOMProperty.properties.hasOwnProperty(name) ? DOMProperty.properties[name] : null; | |
if (propertyInfo) { | |
var mutationMethod = propertyInfo.mutationMethod; | |
if (mutationMethod) { | |
mutationMethod(node, undefined); | |
} else if (propertyInfo.mustUseAttribute) { | |
node.removeAttribute(propertyInfo.attributeName); | |
} else { | |
var propName = propertyInfo.propertyName; | |
var defaultValue = DOMProperty.getDefaultValueForProperty(node.nodeName, propName); | |
if (!propertyInfo.hasSideEffects || '' + node[propName] !== defaultValue) { | |
node[propName] = defaultValue; | |
} | |
} | |
} else if (DOMProperty.isCustomAttribute(name)) { | |
node.removeAttribute(name); | |
} else if (process.env.NODE_ENV !== 'production') { | |
warnUnknownProperty(name); | |
} | |
} | |
}; | |
ReactPerf.measureMethods(DOMPropertyOperations, 'DOMPropertyOperations', { | |
setValueForProperty: 'setValueForProperty', | |
setValueForAttribute: 'setValueForAttribute', | |
deleteValueForProperty: 'deleteValueForProperty' | |
}); | |
module.exports = DOMPropertyOperations; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 81 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule DOMProperty | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
function checkMask(value, bitmask) { | |
return (value & bitmask) === bitmask; | |
} | |
var DOMPropertyInjection = { | |
/** | |
* Mapping from normalized, camelcased property names to a configuration that | |
* specifies how the associated DOM property should be accessed or rendered. | |
*/ | |
MUST_USE_ATTRIBUTE: 0x1, | |
MUST_USE_PROPERTY: 0x2, | |
HAS_SIDE_EFFECTS: 0x4, | |
HAS_BOOLEAN_VALUE: 0x8, | |
HAS_NUMERIC_VALUE: 0x10, | |
HAS_POSITIVE_NUMERIC_VALUE: 0x20 | 0x10, | |
HAS_OVERLOADED_BOOLEAN_VALUE: 0x40, | |
/** | |
* Inject some specialized knowledge about the DOM. This takes a config object | |
* with the following properties: | |
* | |
* isCustomAttribute: function that given an attribute name will return true | |
* if it can be inserted into the DOM verbatim. Useful for data-* or aria-* | |
* attributes where it's impossible to enumerate all of the possible | |
* attribute names, | |
* | |
* Properties: object mapping DOM property name to one of the | |
* DOMPropertyInjection constants or null. If your attribute isn't in here, | |
* it won't get written to the DOM. | |
* | |
* DOMAttributeNames: object mapping React attribute name to the DOM | |
* attribute name. Attribute names not specified use the **lowercase** | |
* normalized name. | |
* | |
* DOMAttributeNamespaces: object mapping React attribute name to the DOM | |
* attribute namespace URL. (Attribute names not specified use no namespace.) | |
* | |
* DOMPropertyNames: similar to DOMAttributeNames but for DOM properties. | |
* Property names not specified use the normalized name. | |
* | |
* DOMMutationMethods: Properties that require special mutation methods. If | |
* `value` is undefined, the mutation method should unset the property. | |
* | |
* @param {object} domPropertyConfig the config as described above. | |
*/ | |
injectDOMPropertyConfig: function (domPropertyConfig) { | |
var Injection = DOMPropertyInjection; | |
var Properties = domPropertyConfig.Properties || {}; | |
var DOMAttributeNamespaces = domPropertyConfig.DOMAttributeNamespaces || {}; | |
var DOMAttributeNames = domPropertyConfig.DOMAttributeNames || {}; | |
var DOMPropertyNames = domPropertyConfig.DOMPropertyNames || {}; | |
var DOMMutationMethods = domPropertyConfig.DOMMutationMethods || {}; | |
if (domPropertyConfig.isCustomAttribute) { | |
DOMProperty._isCustomAttributeFunctions.push(domPropertyConfig.isCustomAttribute); | |
} | |
for (var propName in Properties) { | |
!!DOMProperty.properties.hasOwnProperty(propName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'injectDOMPropertyConfig(...): You\'re trying to inject DOM property ' + '\'%s\' which has already been injected. You may be accidentally ' + 'injecting the same DOM property config twice, or you may be ' + 'injecting two configs that have conflicting property names.', propName) : invariant(false) : undefined; | |
var lowerCased = propName.toLowerCase(); | |
var propConfig = Properties[propName]; | |
var propertyInfo = { | |
attributeName: lowerCased, | |
attributeNamespace: null, | |
propertyName: propName, | |
mutationMethod: null, | |
mustUseAttribute: checkMask(propConfig, Injection.MUST_USE_ATTRIBUTE), | |
mustUseProperty: checkMask(propConfig, Injection.MUST_USE_PROPERTY), | |
hasSideEffects: checkMask(propConfig, Injection.HAS_SIDE_EFFECTS), | |
hasBooleanValue: checkMask(propConfig, Injection.HAS_BOOLEAN_VALUE), | |
hasNumericValue: checkMask(propConfig, Injection.HAS_NUMERIC_VALUE), | |
hasPositiveNumericValue: checkMask(propConfig, Injection.HAS_POSITIVE_NUMERIC_VALUE), | |
hasOverloadedBooleanValue: checkMask(propConfig, Injection.HAS_OVERLOADED_BOOLEAN_VALUE) | |
}; | |
!(!propertyInfo.mustUseAttribute || !propertyInfo.mustUseProperty) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'DOMProperty: Cannot require using both attribute and property: %s', propName) : invariant(false) : undefined; | |
!(propertyInfo.mustUseProperty || !propertyInfo.hasSideEffects) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'DOMProperty: Properties that have side effects must use property: %s', propName) : invariant(false) : undefined; | |
!(propertyInfo.hasBooleanValue + propertyInfo.hasNumericValue + propertyInfo.hasOverloadedBooleanValue <= 1) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'DOMProperty: Value can be one of boolean, overloaded boolean, or ' + 'numeric value, but not a combination: %s', propName) : invariant(false) : undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
DOMProperty.getPossibleStandardName[lowerCased] = propName; | |
} | |
if (DOMAttributeNames.hasOwnProperty(propName)) { | |
var attributeName = DOMAttributeNames[propName]; | |
propertyInfo.attributeName = attributeName; | |
if (process.env.NODE_ENV !== 'production') { | |
DOMProperty.getPossibleStandardName[attributeName] = propName; | |
} | |
} | |
if (DOMAttributeNamespaces.hasOwnProperty(propName)) { | |
propertyInfo.attributeNamespace = DOMAttributeNamespaces[propName]; | |
} | |
if (DOMPropertyNames.hasOwnProperty(propName)) { | |
propertyInfo.propertyName = DOMPropertyNames[propName]; | |
} | |
if (DOMMutationMethods.hasOwnProperty(propName)) { | |
propertyInfo.mutationMethod = DOMMutationMethods[propName]; | |
} | |
DOMProperty.properties[propName] = propertyInfo; | |
} | |
} | |
}; | |
var defaultValueCache = {}; | |
/** | |
* DOMProperty exports lookup objects that can be used like functions: | |
* | |
* > DOMProperty.isValid['id'] | |
* true | |
* > DOMProperty.isValid['foobar'] | |
* undefined | |
* | |
* Although this may be confusing, it performs better in general. | |
* | |
* @see http://jsperf.com/key-exists | |
* @see http://jsperf.com/key-missing | |
*/ | |
var DOMProperty = { | |
ID_ATTRIBUTE_NAME: 'data-reactid', | |
/** | |
* Map from property "standard name" to an object with info about how to set | |
* the property in the DOM. Each object contains: | |
* | |
* attributeName: | |
* Used when rendering markup or with `*Attribute()`. | |
* attributeNamespace | |
* propertyName: | |
* Used on DOM node instances. (This includes properties that mutate due to | |
* external factors.) | |
* mutationMethod: | |
* If non-null, used instead of the property or `setAttribute()` after | |
* initial render. | |
* mustUseAttribute: | |
* Whether the property must be accessed and mutated using `*Attribute()`. | |
* (This includes anything that fails `<propName> in <element>`.) | |
* mustUseProperty: | |
* Whether the property must be accessed and mutated as an object property. | |
* hasSideEffects: | |
* Whether or not setting a value causes side effects such as triggering | |
* resources to be loaded or text selection changes. If true, we read from | |
* the DOM before updating to ensure that the value is only set if it has | |
* changed. | |
* hasBooleanValue: | |
* Whether the property should be removed when set to a falsey value. | |
* hasNumericValue: | |
* Whether the property must be numeric or parse as a numeric and should be | |
* removed when set to a falsey value. | |
* hasPositiveNumericValue: | |
* Whether the property must be positive numeric or parse as a positive | |
* numeric and should be removed when set to a falsey value. | |
* hasOverloadedBooleanValue: | |
* Whether the property can be used as a flag as well as with a value. | |
* Removed when strictly equal to false; present without a value when | |
* strictly equal to true; present with a value otherwise. | |
*/ | |
properties: {}, | |
/** | |
* Mapping from lowercase property names to the properly cased version, used | |
* to warn in the case of missing properties. Available only in __DEV__. | |
* @type {Object} | |
*/ | |
getPossibleStandardName: process.env.NODE_ENV !== 'production' ? {} : null, | |
/** | |
* All of the isCustomAttribute() functions that have been injected. | |
*/ | |
_isCustomAttributeFunctions: [], | |
/** | |
* Checks whether a property name is a custom attribute. | |
* @method | |
*/ | |
isCustomAttribute: function (attributeName) { | |
for (var i = 0; i < DOMProperty._isCustomAttributeFunctions.length; i++) { | |
var isCustomAttributeFn = DOMProperty._isCustomAttributeFunctions[i]; | |
if (isCustomAttributeFn(attributeName)) { | |
return true; | |
} | |
} | |
return false; | |
}, | |
/** | |
* Returns the default property value for a DOM property (i.e., not an | |
* attribute). Most default values are '' or false, but not all. Worse yet, | |
* some (in particular, `type`) vary depending on the type of element. | |
* | |
* TODO: Is it better to grab all the possible properties when creating an | |
* element to avoid having to create the same element twice? | |
*/ | |
getDefaultValueForProperty: function (nodeName, prop) { | |
var nodeDefaults = defaultValueCache[nodeName]; | |
var testElement; | |
if (!nodeDefaults) { | |
defaultValueCache[nodeName] = nodeDefaults = {}; | |
} | |
if (!(prop in nodeDefaults)) { | |
testElement = document.createElement(nodeName); | |
nodeDefaults[prop] = testElement[prop]; | |
} | |
return nodeDefaults[prop]; | |
}, | |
injection: DOMPropertyInjection | |
}; | |
module.exports = DOMProperty; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 82 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule quoteAttributeValueForBrowser | |
*/ | |
'use strict'; | |
var escapeTextContentForBrowser = __webpack_require__(79); | |
/** | |
* Escapes attribute value to prevent scripting attacks. | |
* | |
* @param {*} value Value to escape. | |
* @return {string} An escaped string. | |
*/ | |
function quoteAttributeValueForBrowser(value) { | |
return '"' + escapeTextContentForBrowser(value) + '"'; | |
} | |
module.exports = quoteAttributeValueForBrowser; | |
/***/ }, | |
/* 83 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule warning | |
*/ | |
'use strict'; | |
var emptyFunction = __webpack_require__(73); | |
/** | |
* Similar to invariant but only logs a warning if the condition is not met. | |
* This can be used to log issues in development environments in critical | |
* paths. Removing the logging code for production environments will keep the | |
* same logic and follow the same code paths. | |
*/ | |
var warning = emptyFunction; | |
if (process.env.NODE_ENV !== 'production') { | |
warning = function (condition, format) { | |
for (var _len = arguments.length, args = Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) { | |
args[_key - 2] = arguments[_key]; | |
} | |
if (format === undefined) { | |
throw new Error('`warning(condition, format, ...args)` requires a warning ' + 'message argument'); | |
} | |
if (format.indexOf('Failed Composite propType: ') === 0) { | |
return; // Ignore CompositeComponent proptype check. | |
} | |
if (!condition) { | |
var argIndex = 0; | |
var message = 'Warning: ' + format.replace(/%s/g, function () { | |
return args[argIndex++]; | |
}); | |
if (typeof console !== 'undefined') { | |
console.error(message); | |
} | |
try { | |
// --- Welcome to debugging React --- | |
// This error was thrown as a convenience so that you can use this stack | |
// to find the callsite that caused this warning to fire. | |
throw new Error(message); | |
} catch (x) {} | |
} | |
}; | |
} | |
module.exports = warning; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 84 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactComponentBrowserEnvironment | |
*/ | |
'use strict'; | |
var ReactDOMIDOperations = __webpack_require__(85); | |
var ReactMount = __webpack_require__(86); | |
/** | |
* Abstracts away all functionality of the reconciler that requires knowledge of | |
* the browser context. TODO: These callers should be refactored to avoid the | |
* need for this injection. | |
*/ | |
var ReactComponentBrowserEnvironment = { | |
processChildrenUpdates: ReactDOMIDOperations.dangerouslyProcessChildrenUpdates, | |
replaceNodeWithMarkupByID: ReactDOMIDOperations.dangerouslyReplaceNodeWithMarkupByID, | |
/** | |
* If a particular environment requires that some resources be cleaned up, | |
* specify this in the injected Mixin. In the DOM, we would likely want to | |
* purge any cached node ID lookups. | |
* | |
* @private | |
*/ | |
unmountIDFromEnvironment: function (rootNodeID) { | |
ReactMount.purgeID(rootNodeID); | |
} | |
}; | |
module.exports = ReactComponentBrowserEnvironment; | |
/***/ }, | |
/* 85 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMIDOperations | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var DOMChildrenOperations = __webpack_require__(66); | |
var DOMPropertyOperations = __webpack_require__(80); | |
var ReactMount = __webpack_require__(86); | |
var ReactPerf = __webpack_require__(76); | |
var invariant = __webpack_require__(31); | |
/** | |
* Errors for properties that should not be updated with `updatePropertyByID()`. | |
* | |
* @type {object} | |
* @private | |
*/ | |
var INVALID_PROPERTY_ERRORS = { | |
dangerouslySetInnerHTML: '`dangerouslySetInnerHTML` must be set using `updateInnerHTMLByID()`.', | |
style: '`style` must be set using `updateStylesByID()`.' | |
}; | |
/** | |
* Operations used to process updates to DOM nodes. | |
*/ | |
var ReactDOMIDOperations = { | |
/** | |
* Updates a DOM node with new property values. This should only be used to | |
* update DOM properties in `DOMProperty`. | |
* | |
* @param {string} id ID of the node to update. | |
* @param {string} name A valid property name, see `DOMProperty`. | |
* @param {*} value New value of the property. | |
* @internal | |
*/ | |
updatePropertyByID: function (id, name, value) { | |
var node = ReactMount.getNode(id); | |
!!INVALID_PROPERTY_ERRORS.hasOwnProperty(name) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'updatePropertyByID(...): %s', INVALID_PROPERTY_ERRORS[name]) : invariant(false) : undefined; | |
// If we're updating to null or undefined, we should remove the property | |
// from the DOM node instead of inadvertantly setting to a string. This | |
// brings us in line with the same behavior we have on initial render. | |
if (value != null) { | |
DOMPropertyOperations.setValueForProperty(node, name, value); | |
} else { | |
DOMPropertyOperations.deleteValueForProperty(node, name); | |
} | |
}, | |
/** | |
* Replaces a DOM node that exists in the document with markup. | |
* | |
* @param {string} id ID of child to be replaced. | |
* @param {string} markup Dangerous markup to inject in place of child. | |
* @internal | |
* @see {Danger.dangerouslyReplaceNodeWithMarkup} | |
*/ | |
dangerouslyReplaceNodeWithMarkupByID: function (id, markup) { | |
var node = ReactMount.getNode(id); | |
DOMChildrenOperations.dangerouslyReplaceNodeWithMarkup(node, markup); | |
}, | |
/** | |
* Updates a component's children by processing a series of updates. | |
* | |
* @param {array<object>} updates List of update configurations. | |
* @param {array<string>} markup List of markup strings. | |
* @internal | |
*/ | |
dangerouslyProcessChildrenUpdates: function (updates, markup) { | |
for (var i = 0; i < updates.length; i++) { | |
updates[i].parentNode = ReactMount.getNode(updates[i].parentID); | |
} | |
DOMChildrenOperations.processUpdates(updates, markup); | |
} | |
}; | |
ReactPerf.measureMethods(ReactDOMIDOperations, 'ReactDOMIDOperations', { | |
dangerouslyReplaceNodeWithMarkupByID: 'dangerouslyReplaceNodeWithMarkupByID', | |
dangerouslyProcessChildrenUpdates: 'dangerouslyProcessChildrenUpdates' | |
}); | |
module.exports = ReactDOMIDOperations; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 86 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactMount | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var ReactBrowserEventEmitter = __webpack_require__(87); | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactDOMFeatureFlags = __webpack_require__(98); | |
var ReactElement = __webpack_require__(99); | |
var ReactEmptyComponentRegistry = __webpack_require__(101); | |
var ReactInstanceHandles = __webpack_require__(102); | |
var ReactInstanceMap = __webpack_require__(104); | |
var ReactMarkupChecksum = __webpack_require__(105); | |
var ReactPerf = __webpack_require__(76); | |
var ReactReconciler = __webpack_require__(107); | |
var ReactUpdateQueue = __webpack_require__(110); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var emptyObject = __webpack_require__(115); | |
var containsNode = __webpack_require__(116); | |
var instantiateReactComponent = __webpack_require__(119); | |
var invariant = __webpack_require__(31); | |
var setInnerHTML = __webpack_require__(77); | |
var shouldUpdateReactComponent = __webpack_require__(124); | |
var validateDOMNesting = __webpack_require__(127); | |
var warning = __webpack_require__(83); | |
var ATTR_NAME = DOMProperty.ID_ATTRIBUTE_NAME; | |
var nodeCache = {}; | |
var ELEMENT_NODE_TYPE = 1; | |
var DOC_NODE_TYPE = 9; | |
var DOCUMENT_FRAGMENT_NODE_TYPE = 11; | |
var ownerDocumentContextKey = '__ReactMount_ownerDocument$' + Math.random().toString(36).slice(2); | |
/** Mapping from reactRootID to React component instance. */ | |
var instancesByReactRootID = {}; | |
/** Mapping from reactRootID to `container` nodes. */ | |
var containersByReactRootID = {}; | |
if (process.env.NODE_ENV !== 'production') { | |
/** __DEV__-only mapping from reactRootID to root elements. */ | |
var rootElementsByReactRootID = {}; | |
} | |
// Used to store breadth-first search state in findComponentRoot. | |
var findComponentRootReusableArray = []; | |
/** | |
* Finds the index of the first character | |
* that's not common between the two given strings. | |
* | |
* @return {number} the index of the character where the strings diverge | |
*/ | |
function firstDifferenceIndex(string1, string2) { | |
var minLen = Math.min(string1.length, string2.length); | |
for (var i = 0; i < minLen; i++) { | |
if (string1.charAt(i) !== string2.charAt(i)) { | |
return i; | |
} | |
} | |
return string1.length === string2.length ? -1 : minLen; | |
} | |
/** | |
* @param {DOMElement|DOMDocument} container DOM element that may contain | |
* a React component | |
* @return {?*} DOM element that may have the reactRoot ID, or null. | |
*/ | |
function getReactRootElementInContainer(container) { | |
if (!container) { | |
return null; | |
} | |
if (container.nodeType === DOC_NODE_TYPE) { | |
return container.documentElement; | |
} else { | |
return container.firstChild; | |
} | |
} | |
/** | |
* @param {DOMElement} container DOM element that may contain a React component. | |
* @return {?string} A "reactRoot" ID, if a React component is rendered. | |
*/ | |
function getReactRootID(container) { | |
var rootElement = getReactRootElementInContainer(container); | |
return rootElement && ReactMount.getID(rootElement); | |
} | |
/** | |
* Accessing node[ATTR_NAME] or calling getAttribute(ATTR_NAME) on a form | |
* element can return its control whose name or ID equals ATTR_NAME. All | |
* DOM nodes support `getAttributeNode` but this can also get called on | |
* other objects so just return '' if we're given something other than a | |
* DOM node (such as window). | |
* | |
* @param {?DOMElement|DOMWindow|DOMDocument|DOMTextNode} node DOM node. | |
* @return {string} ID of the supplied `domNode`. | |
*/ | |
function getID(node) { | |
var id = internalGetID(node); | |
if (id) { | |
if (nodeCache.hasOwnProperty(id)) { | |
var cached = nodeCache[id]; | |
if (cached !== node) { | |
!!isValid(cached, id) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactMount: Two valid but unequal nodes with the same `%s`: %s', ATTR_NAME, id) : invariant(false) : undefined; | |
nodeCache[id] = node; | |
} | |
} else { | |
nodeCache[id] = node; | |
} | |
} | |
return id; | |
} | |
function internalGetID(node) { | |
// If node is something like a window, document, or text node, none of | |
// which support attributes or a .getAttribute method, gracefully return | |
// the empty string, as if the attribute were missing. | |
return node && node.getAttribute && node.getAttribute(ATTR_NAME) || ''; | |
} | |
/** | |
* Sets the React-specific ID of the given node. | |
* | |
* @param {DOMElement} node The DOM node whose ID will be set. | |
* @param {string} id The value of the ID attribute. | |
*/ | |
function setID(node, id) { | |
var oldID = internalGetID(node); | |
if (oldID !== id) { | |
delete nodeCache[oldID]; | |
} | |
node.setAttribute(ATTR_NAME, id); | |
nodeCache[id] = node; | |
} | |
/** | |
* Finds the node with the supplied React-generated DOM ID. | |
* | |
* @param {string} id A React-generated DOM ID. | |
* @return {DOMElement} DOM node with the suppled `id`. | |
* @internal | |
*/ | |
function getNode(id) { | |
if (!nodeCache.hasOwnProperty(id) || !isValid(nodeCache[id], id)) { | |
nodeCache[id] = ReactMount.findReactNodeByID(id); | |
} | |
return nodeCache[id]; | |
} | |
/** | |
* Finds the node with the supplied public React instance. | |
* | |
* @param {*} instance A public React instance. | |
* @return {?DOMElement} DOM node with the suppled `id`. | |
* @internal | |
*/ | |
function getNodeFromInstance(instance) { | |
var id = ReactInstanceMap.get(instance)._rootNodeID; | |
if (ReactEmptyComponentRegistry.isNullComponentID(id)) { | |
return null; | |
} | |
if (!nodeCache.hasOwnProperty(id) || !isValid(nodeCache[id], id)) { | |
nodeCache[id] = ReactMount.findReactNodeByID(id); | |
} | |
return nodeCache[id]; | |
} | |
/** | |
* A node is "valid" if it is contained by a currently mounted container. | |
* | |
* This means that the node does not have to be contained by a document in | |
* order to be considered valid. | |
* | |
* @param {?DOMElement} node The candidate DOM node. | |
* @param {string} id The expected ID of the node. | |
* @return {boolean} Whether the node is contained by a mounted container. | |
*/ | |
function isValid(node, id) { | |
if (node) { | |
!(internalGetID(node) === id) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactMount: Unexpected modification of `%s`', ATTR_NAME) : invariant(false) : undefined; | |
var container = ReactMount.findReactContainerForID(id); | |
if (container && containsNode(container, node)) { | |
return true; | |
} | |
} | |
return false; | |
} | |
/** | |
* Causes the cache to forget about one React-specific ID. | |
* | |
* @param {string} id The ID to forget. | |
*/ | |
function purgeID(id) { | |
delete nodeCache[id]; | |
} | |
var deepestNodeSoFar = null; | |
function findDeepestCachedAncestorImpl(ancestorID) { | |
var ancestor = nodeCache[ancestorID]; | |
if (ancestor && isValid(ancestor, ancestorID)) { | |
deepestNodeSoFar = ancestor; | |
} else { | |
// This node isn't populated in the cache, so presumably none of its | |
// descendants are. Break out of the loop. | |
return false; | |
} | |
} | |
/** | |
* Return the deepest cached node whose ID is a prefix of `targetID`. | |
*/ | |
function findDeepestCachedAncestor(targetID) { | |
deepestNodeSoFar = null; | |
ReactInstanceHandles.traverseAncestors(targetID, findDeepestCachedAncestorImpl); | |
var foundNode = deepestNodeSoFar; | |
deepestNodeSoFar = null; | |
return foundNode; | |
} | |
/** | |
* Mounts this component and inserts it into the DOM. | |
* | |
* @param {ReactComponent} componentInstance The instance to mount. | |
* @param {string} rootID DOM ID of the root node. | |
* @param {DOMElement} container DOM element to mount into. | |
* @param {ReactReconcileTransaction} transaction | |
* @param {boolean} shouldReuseMarkup If true, do not insert markup | |
*/ | |
function mountComponentIntoNode(componentInstance, rootID, container, transaction, shouldReuseMarkup, context) { | |
if (ReactDOMFeatureFlags.useCreateElement) { | |
context = assign({}, context); | |
if (container.nodeType === DOC_NODE_TYPE) { | |
context[ownerDocumentContextKey] = container; | |
} else { | |
context[ownerDocumentContextKey] = container.ownerDocument; | |
} | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
if (context === emptyObject) { | |
context = {}; | |
} | |
var tag = container.nodeName.toLowerCase(); | |
context[validateDOMNesting.ancestorInfoContextKey] = validateDOMNesting.updatedAncestorInfo(null, tag, null); | |
} | |
var markup = ReactReconciler.mountComponent(componentInstance, rootID, transaction, context); | |
componentInstance._renderedComponent._topLevelWrapper = componentInstance; | |
ReactMount._mountImageIntoNode(markup, container, shouldReuseMarkup, transaction); | |
} | |
/** | |
* Batched mount. | |
* | |
* @param {ReactComponent} componentInstance The instance to mount. | |
* @param {string} rootID DOM ID of the root node. | |
* @param {DOMElement} container DOM element to mount into. | |
* @param {boolean} shouldReuseMarkup If true, do not insert markup | |
*/ | |
function batchedMountComponentIntoNode(componentInstance, rootID, container, shouldReuseMarkup, context) { | |
var transaction = ReactUpdates.ReactReconcileTransaction.getPooled( | |
/* forceHTML */shouldReuseMarkup); | |
transaction.perform(mountComponentIntoNode, null, componentInstance, rootID, container, transaction, shouldReuseMarkup, context); | |
ReactUpdates.ReactReconcileTransaction.release(transaction); | |
} | |
/** | |
* Unmounts a component and removes it from the DOM. | |
* | |
* @param {ReactComponent} instance React component instance. | |
* @param {DOMElement} container DOM element to unmount from. | |
* @final | |
* @internal | |
* @see {ReactMount.unmountComponentAtNode} | |
*/ | |
function unmountComponentFromNode(instance, container) { | |
ReactReconciler.unmountComponent(instance); | |
if (container.nodeType === DOC_NODE_TYPE) { | |
container = container.documentElement; | |
} | |
// http://jsperf.com/emptying-a-node | |
while (container.lastChild) { | |
container.removeChild(container.lastChild); | |
} | |
} | |
/** | |
* True if the supplied DOM node has a direct React-rendered child that is | |
* not a React root element. Useful for warning in `render`, | |
* `unmountComponentAtNode`, etc. | |
* | |
* @param {?DOMElement} node The candidate DOM node. | |
* @return {boolean} True if the DOM element contains a direct child that was | |
* rendered by React but is not a root element. | |
* @internal | |
*/ | |
function hasNonRootReactChild(node) { | |
var reactRootID = getReactRootID(node); | |
return reactRootID ? reactRootID !== ReactInstanceHandles.getReactRootIDFromNodeID(reactRootID) : false; | |
} | |
/** | |
* Returns the first (deepest) ancestor of a node which is rendered by this copy | |
* of React. | |
*/ | |
function findFirstReactDOMImpl(node) { | |
// This node might be from another React instance, so we make sure not to | |
// examine the node cache here | |
for (; node && node.parentNode !== node; node = node.parentNode) { | |
if (node.nodeType !== 1) { | |
// Not a DOMElement, therefore not a React component | |
continue; | |
} | |
var nodeID = internalGetID(node); | |
if (!nodeID) { | |
continue; | |
} | |
var reactRootID = ReactInstanceHandles.getReactRootIDFromNodeID(nodeID); | |
// If containersByReactRootID contains the container we find by crawling up | |
// the tree, we know that this instance of React rendered the node. | |
// nb. isValid's strategy (with containsNode) does not work because render | |
// trees may be nested and we don't want a false positive in that case. | |
var current = node; | |
var lastID; | |
do { | |
lastID = internalGetID(current); | |
current = current.parentNode; | |
if (current == null) { | |
// The passed-in node has been detached from the container it was | |
// originally rendered into. | |
return null; | |
} | |
} while (lastID !== reactRootID); | |
if (current === containersByReactRootID[reactRootID]) { | |
return node; | |
} | |
} | |
return null; | |
} | |
/** | |
* Temporary (?) hack so that we can store all top-level pending updates on | |
* composites instead of having to worry about different types of components | |
* here. | |
*/ | |
var TopLevelWrapper = function () {}; | |
TopLevelWrapper.prototype.isReactComponent = {}; | |
if (process.env.NODE_ENV !== 'production') { | |
TopLevelWrapper.displayName = 'TopLevelWrapper'; | |
} | |
TopLevelWrapper.prototype.render = function () { | |
// this.props is actually a ReactElement | |
return this.props; | |
}; | |
/** | |
* Mounting is the process of initializing a React component by creating its | |
* representative DOM elements and inserting them into a supplied `container`. | |
* Any prior content inside `container` is destroyed in the process. | |
* | |
* ReactMount.render( | |
* component, | |
* document.getElementById('container') | |
* ); | |
* | |
* <div id="container"> <-- Supplied `container`. | |
* <div data-reactid=".3"> <-- Rendered reactRoot of React | |
* // ... component. | |
* </div> | |
* </div> | |
* | |
* Inside of `container`, the first element rendered is the "reactRoot". | |
*/ | |
var ReactMount = { | |
TopLevelWrapper: TopLevelWrapper, | |
/** Exposed for debugging purposes **/ | |
_instancesByReactRootID: instancesByReactRootID, | |
/** | |
* This is a hook provided to support rendering React components while | |
* ensuring that the apparent scroll position of its `container` does not | |
* change. | |
* | |
* @param {DOMElement} container The `container` being rendered into. | |
* @param {function} renderCallback This must be called once to do the render. | |
*/ | |
scrollMonitor: function (container, renderCallback) { | |
renderCallback(); | |
}, | |
/** | |
* Take a component that's already mounted into the DOM and replace its props | |
* @param {ReactComponent} prevComponent component instance already in the DOM | |
* @param {ReactElement} nextElement component instance to render | |
* @param {DOMElement} container container to render into | |
* @param {?function} callback function triggered on completion | |
*/ | |
_updateRootComponent: function (prevComponent, nextElement, container, callback) { | |
ReactMount.scrollMonitor(container, function () { | |
ReactUpdateQueue.enqueueElementInternal(prevComponent, nextElement); | |
if (callback) { | |
ReactUpdateQueue.enqueueCallbackInternal(prevComponent, callback); | |
} | |
}); | |
if (process.env.NODE_ENV !== 'production') { | |
// Record the root element in case it later gets transplanted. | |
rootElementsByReactRootID[getReactRootID(container)] = getReactRootElementInContainer(container); | |
} | |
return prevComponent; | |
}, | |
/** | |
* Register a component into the instance map and starts scroll value | |
* monitoring | |
* @param {ReactComponent} nextComponent component instance to render | |
* @param {DOMElement} container container to render into | |
* @return {string} reactRoot ID prefix | |
*/ | |
_registerComponent: function (nextComponent, container) { | |
!(container && (container.nodeType === ELEMENT_NODE_TYPE || container.nodeType === DOC_NODE_TYPE || container.nodeType === DOCUMENT_FRAGMENT_NODE_TYPE)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '_registerComponent(...): Target container is not a DOM element.') : invariant(false) : undefined; | |
ReactBrowserEventEmitter.ensureScrollValueMonitoring(); | |
var reactRootID = ReactMount.registerContainer(container); | |
instancesByReactRootID[reactRootID] = nextComponent; | |
return reactRootID; | |
}, | |
/** | |
* Render a new component into the DOM. | |
* @param {ReactElement} nextElement element to render | |
* @param {DOMElement} container container to render into | |
* @param {boolean} shouldReuseMarkup if we should skip the markup insertion | |
* @return {ReactComponent} nextComponent | |
*/ | |
_renderNewRootComponent: function (nextElement, container, shouldReuseMarkup, context) { | |
// Various parts of our code (such as ReactCompositeComponent's | |
// _renderValidatedComponent) assume that calls to render aren't nested; | |
// verify that that's the case. | |
process.env.NODE_ENV !== 'production' ? warning(ReactCurrentOwner.current == null, '_renderNewRootComponent(): Render methods should be a pure function ' + 'of props and state; triggering nested component updates from ' + 'render is not allowed. If necessary, trigger nested updates in ' + 'componentDidUpdate. Check the render method of %s.', ReactCurrentOwner.current && ReactCurrentOwner.current.getName() || 'ReactCompositeComponent') : undefined; | |
var componentInstance = instantiateReactComponent(nextElement, null); | |
var reactRootID = ReactMount._registerComponent(componentInstance, container); | |
// The initial render is synchronous but any updates that happen during | |
// rendering, in componentWillMount or componentDidMount, will be batched | |
// according to the current batching strategy. | |
ReactUpdates.batchedUpdates(batchedMountComponentIntoNode, componentInstance, reactRootID, container, shouldReuseMarkup, context); | |
if (process.env.NODE_ENV !== 'production') { | |
// Record the root element in case it later gets transplanted. | |
rootElementsByReactRootID[reactRootID] = getReactRootElementInContainer(container); | |
} | |
return componentInstance; | |
}, | |
/** | |
* Renders a React component into the DOM in the supplied `container`. | |
* | |
* If the React component was previously rendered into `container`, this will | |
* perform an update on it and only mutate the DOM as necessary to reflect the | |
* latest React component. | |
* | |
* @param {ReactComponent} parentComponent The conceptual parent of this render tree. | |
* @param {ReactElement} nextElement Component element to render. | |
* @param {DOMElement} container DOM element to render into. | |
* @param {?function} callback function triggered on completion | |
* @return {ReactComponent} Component instance rendered in `container`. | |
*/ | |
renderSubtreeIntoContainer: function (parentComponent, nextElement, container, callback) { | |
!(parentComponent != null && parentComponent._reactInternalInstance != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'parentComponent must be a valid React Component') : invariant(false) : undefined; | |
return ReactMount._renderSubtreeIntoContainer(parentComponent, nextElement, container, callback); | |
}, | |
_renderSubtreeIntoContainer: function (parentComponent, nextElement, container, callback) { | |
!ReactElement.isValidElement(nextElement) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactDOM.render(): Invalid component element.%s', typeof nextElement === 'string' ? ' Instead of passing an element string, make sure to instantiate ' + 'it by passing it to React.createElement.' : typeof nextElement === 'function' ? ' Instead of passing a component class, make sure to instantiate ' + 'it by passing it to React.createElement.' : | |
// Check if it quacks like an element | |
nextElement != null && nextElement.props !== undefined ? ' This may be caused by unintentionally loading two independent ' + 'copies of React.' : '') : invariant(false) : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!container || !container.tagName || container.tagName.toUpperCase() !== 'BODY', 'render(): Rendering components directly into document.body is ' + 'discouraged, since its children are often manipulated by third-party ' + 'scripts and browser extensions. This may lead to subtle ' + 'reconciliation issues. Try rendering into a container element created ' + 'for your app.') : undefined; | |
var nextWrappedElement = new ReactElement(TopLevelWrapper, null, null, null, null, null, nextElement); | |
var prevComponent = instancesByReactRootID[getReactRootID(container)]; | |
if (prevComponent) { | |
var prevWrappedElement = prevComponent._currentElement; | |
var prevElement = prevWrappedElement.props; | |
if (shouldUpdateReactComponent(prevElement, nextElement)) { | |
var publicInst = prevComponent._renderedComponent.getPublicInstance(); | |
var updatedCallback = callback && function () { | |
callback.call(publicInst); | |
}; | |
ReactMount._updateRootComponent(prevComponent, nextWrappedElement, container, updatedCallback); | |
return publicInst; | |
} else { | |
ReactMount.unmountComponentAtNode(container); | |
} | |
} | |
var reactRootElement = getReactRootElementInContainer(container); | |
var containerHasReactMarkup = reactRootElement && !!internalGetID(reactRootElement); | |
var containerHasNonRootReactChild = hasNonRootReactChild(container); | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(!containerHasNonRootReactChild, 'render(...): Replacing React-rendered children with a new root ' + 'component. If you intended to update the children of this node, ' + 'you should instead have the existing children update their state ' + 'and render the new components instead of calling ReactDOM.render.') : undefined; | |
if (!containerHasReactMarkup || reactRootElement.nextSibling) { | |
var rootElementSibling = reactRootElement; | |
while (rootElementSibling) { | |
if (internalGetID(rootElementSibling)) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'render(): Target node has markup rendered by React, but there ' + 'are unrelated nodes as well. This is most commonly caused by ' + 'white-space inserted around server-rendered markup.') : undefined; | |
break; | |
} | |
rootElementSibling = rootElementSibling.nextSibling; | |
} | |
} | |
} | |
var shouldReuseMarkup = containerHasReactMarkup && !prevComponent && !containerHasNonRootReactChild; | |
var component = ReactMount._renderNewRootComponent(nextWrappedElement, container, shouldReuseMarkup, parentComponent != null ? parentComponent._reactInternalInstance._processChildContext(parentComponent._reactInternalInstance._context) : emptyObject)._renderedComponent.getPublicInstance(); | |
if (callback) { | |
callback.call(component); | |
} | |
return component; | |
}, | |
/** | |
* Renders a React component into the DOM in the supplied `container`. | |
* | |
* If the React component was previously rendered into `container`, this will | |
* perform an update on it and only mutate the DOM as necessary to reflect the | |
* latest React component. | |
* | |
* @param {ReactElement} nextElement Component element to render. | |
* @param {DOMElement} container DOM element to render into. | |
* @param {?function} callback function triggered on completion | |
* @return {ReactComponent} Component instance rendered in `container`. | |
*/ | |
render: function (nextElement, container, callback) { | |
return ReactMount._renderSubtreeIntoContainer(null, nextElement, container, callback); | |
}, | |
/** | |
* Registers a container node into which React components will be rendered. | |
* This also creates the "reactRoot" ID that will be assigned to the element | |
* rendered within. | |
* | |
* @param {DOMElement} container DOM element to register as a container. | |
* @return {string} The "reactRoot" ID of elements rendered within. | |
*/ | |
registerContainer: function (container) { | |
var reactRootID = getReactRootID(container); | |
if (reactRootID) { | |
// If one exists, make sure it is a valid "reactRoot" ID. | |
reactRootID = ReactInstanceHandles.getReactRootIDFromNodeID(reactRootID); | |
} | |
if (!reactRootID) { | |
// No valid "reactRoot" ID found, create one. | |
reactRootID = ReactInstanceHandles.createReactRootID(); | |
} | |
containersByReactRootID[reactRootID] = container; | |
return reactRootID; | |
}, | |
/** | |
* Unmounts and destroys the React component rendered in the `container`. | |
* | |
* @param {DOMElement} container DOM element containing a React component. | |
* @return {boolean} True if a component was found in and unmounted from | |
* `container` | |
*/ | |
unmountComponentAtNode: function (container) { | |
// Various parts of our code (such as ReactCompositeComponent's | |
// _renderValidatedComponent) assume that calls to render aren't nested; | |
// verify that that's the case. (Strictly speaking, unmounting won't cause a | |
// render but we still don't expect to be in a render call here.) | |
process.env.NODE_ENV !== 'production' ? warning(ReactCurrentOwner.current == null, 'unmountComponentAtNode(): Render methods should be a pure function ' + 'of props and state; triggering nested component updates from render ' + 'is not allowed. If necessary, trigger nested updates in ' + 'componentDidUpdate. Check the render method of %s.', ReactCurrentOwner.current && ReactCurrentOwner.current.getName() || 'ReactCompositeComponent') : undefined; | |
!(container && (container.nodeType === ELEMENT_NODE_TYPE || container.nodeType === DOC_NODE_TYPE || container.nodeType === DOCUMENT_FRAGMENT_NODE_TYPE)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'unmountComponentAtNode(...): Target container is not a DOM element.') : invariant(false) : undefined; | |
var reactRootID = getReactRootID(container); | |
var component = instancesByReactRootID[reactRootID]; | |
if (!component) { | |
// Check if the node being unmounted was rendered by React, but isn't a | |
// root node. | |
var containerHasNonRootReactChild = hasNonRootReactChild(container); | |
// Check if the container itself is a React root node. | |
var containerID = internalGetID(container); | |
var isContainerReactRoot = containerID && containerID === ReactInstanceHandles.getReactRootIDFromNodeID(containerID); | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(!containerHasNonRootReactChild, 'unmountComponentAtNode(): The node you\'re attempting to unmount ' + 'was rendered by React and is not a top-level container. %s', isContainerReactRoot ? 'You may have accidentally passed in a React root node instead ' + 'of its container.' : 'Instead, have the parent component update its state and ' + 'rerender in order to remove this component.') : undefined; | |
} | |
return false; | |
} | |
ReactUpdates.batchedUpdates(unmountComponentFromNode, component, container); | |
delete instancesByReactRootID[reactRootID]; | |
delete containersByReactRootID[reactRootID]; | |
if (process.env.NODE_ENV !== 'production') { | |
delete rootElementsByReactRootID[reactRootID]; | |
} | |
return true; | |
}, | |
/** | |
* Finds the container DOM element that contains React component to which the | |
* supplied DOM `id` belongs. | |
* | |
* @param {string} id The ID of an element rendered by a React component. | |
* @return {?DOMElement} DOM element that contains the `id`. | |
*/ | |
findReactContainerForID: function (id) { | |
var reactRootID = ReactInstanceHandles.getReactRootIDFromNodeID(id); | |
var container = containersByReactRootID[reactRootID]; | |
if (process.env.NODE_ENV !== 'production') { | |
var rootElement = rootElementsByReactRootID[reactRootID]; | |
if (rootElement && rootElement.parentNode !== container) { | |
process.env.NODE_ENV !== 'production' ? warning( | |
// Call internalGetID here because getID calls isValid which calls | |
// findReactContainerForID (this function). | |
internalGetID(rootElement) === reactRootID, 'ReactMount: Root element ID differed from reactRootID.') : undefined; | |
var containerChild = container.firstChild; | |
if (containerChild && reactRootID === internalGetID(containerChild)) { | |
// If the container has a new child with the same ID as the old | |
// root element, then rootElementsByReactRootID[reactRootID] is | |
// just stale and needs to be updated. The case that deserves a | |
// warning is when the container is empty. | |
rootElementsByReactRootID[reactRootID] = containerChild; | |
} else { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactMount: Root element has been removed from its original ' + 'container. New container: %s', rootElement.parentNode) : undefined; | |
} | |
} | |
} | |
return container; | |
}, | |
/** | |
* Finds an element rendered by React with the supplied ID. | |
* | |
* @param {string} id ID of a DOM node in the React component. | |
* @return {DOMElement} Root DOM node of the React component. | |
*/ | |
findReactNodeByID: function (id) { | |
var reactRoot = ReactMount.findReactContainerForID(id); | |
return ReactMount.findComponentRoot(reactRoot, id); | |
}, | |
/** | |
* Traverses up the ancestors of the supplied node to find a node that is a | |
* DOM representation of a React component rendered by this copy of React. | |
* | |
* @param {*} node | |
* @return {?DOMEventTarget} | |
* @internal | |
*/ | |
getFirstReactDOM: function (node) { | |
return findFirstReactDOMImpl(node); | |
}, | |
/** | |
* Finds a node with the supplied `targetID` inside of the supplied | |
* `ancestorNode`. Exploits the ID naming scheme to perform the search | |
* quickly. | |
* | |
* @param {DOMEventTarget} ancestorNode Search from this root. | |
* @pararm {string} targetID ID of the DOM representation of the component. | |
* @return {DOMEventTarget} DOM node with the supplied `targetID`. | |
* @internal | |
*/ | |
findComponentRoot: function (ancestorNode, targetID) { | |
var firstChildren = findComponentRootReusableArray; | |
var childIndex = 0; | |
var deepestAncestor = findDeepestCachedAncestor(targetID) || ancestorNode; | |
if (process.env.NODE_ENV !== 'production') { | |
// This will throw on the next line; give an early warning | |
process.env.NODE_ENV !== 'production' ? warning(deepestAncestor != null, 'React can\'t find the root component node for data-reactid value ' + '`%s`. If you\'re seeing this message, it probably means that ' + 'you\'ve loaded two copies of React on the page. At this time, only ' + 'a single copy of React can be loaded at a time.', targetID) : undefined; | |
} | |
firstChildren[0] = deepestAncestor.firstChild; | |
firstChildren.length = 1; | |
while (childIndex < firstChildren.length) { | |
var child = firstChildren[childIndex++]; | |
var targetChild; | |
while (child) { | |
var childID = ReactMount.getID(child); | |
if (childID) { | |
// Even if we find the node we're looking for, we finish looping | |
// through its siblings to ensure they're cached so that we don't have | |
// to revisit this node again. Otherwise, we make n^2 calls to getID | |
// when visiting the many children of a single node in order. | |
if (targetID === childID) { | |
targetChild = child; | |
} else if (ReactInstanceHandles.isAncestorIDOf(childID, targetID)) { | |
// If we find a child whose ID is an ancestor of the given ID, | |
// then we can be sure that we only want to search the subtree | |
// rooted at this child, so we can throw out the rest of the | |
// search state. | |
firstChildren.length = childIndex = 0; | |
firstChildren.push(child.firstChild); | |
} | |
} else { | |
// If this child had no ID, then there's a chance that it was | |
// injected automatically by the browser, as when a `<table>` | |
// element sprouts an extra `<tbody>` child as a side effect of | |
// `.innerHTML` parsing. Optimistically continue down this | |
// branch, but not before examining the other siblings. | |
firstChildren.push(child.firstChild); | |
} | |
child = child.nextSibling; | |
} | |
if (targetChild) { | |
// Emptying firstChildren/findComponentRootReusableArray is | |
// not necessary for correctness, but it helps the GC reclaim | |
// any nodes that were left at the end of the search. | |
firstChildren.length = 0; | |
return targetChild; | |
} | |
} | |
firstChildren.length = 0; | |
true ? process.env.NODE_ENV !== 'production' ? invariant(false, 'findComponentRoot(..., %s): Unable to find element. This probably ' + 'means the DOM was unexpectedly mutated (e.g., by the browser), ' + 'usually due to forgetting a <tbody> when using tables, nesting tags ' + 'like <form>, <p>, or <a>, or using non-SVG elements in an <svg> ' + 'parent. ' + 'Try inspecting the child nodes of the element with React ID `%s`.', targetID, ReactMount.getID(ancestorNode)) : invariant(false) : undefined; | |
}, | |
_mountImageIntoNode: function (markup, container, shouldReuseMarkup, transaction) { | |
!(container && (container.nodeType === ELEMENT_NODE_TYPE || container.nodeType === DOC_NODE_TYPE || container.nodeType === DOCUMENT_FRAGMENT_NODE_TYPE)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'mountComponentIntoNode(...): Target container is not valid.') : invariant(false) : undefined; | |
if (shouldReuseMarkup) { | |
var rootElement = getReactRootElementInContainer(container); | |
if (ReactMarkupChecksum.canReuseMarkup(markup, rootElement)) { | |
return; | |
} else { | |
var checksum = rootElement.getAttribute(ReactMarkupChecksum.CHECKSUM_ATTR_NAME); | |
rootElement.removeAttribute(ReactMarkupChecksum.CHECKSUM_ATTR_NAME); | |
var rootMarkup = rootElement.outerHTML; | |
rootElement.setAttribute(ReactMarkupChecksum.CHECKSUM_ATTR_NAME, checksum); | |
var normalizedMarkup = markup; | |
if (process.env.NODE_ENV !== 'production') { | |
// because rootMarkup is retrieved from the DOM, various normalizations | |
// will have occurred which will not be present in `markup`. Here, | |
// insert markup into a <div> or <iframe> depending on the container | |
// type to perform the same normalizations before comparing. | |
var normalizer; | |
if (container.nodeType === ELEMENT_NODE_TYPE) { | |
normalizer = document.createElement('div'); | |
normalizer.innerHTML = markup; | |
normalizedMarkup = normalizer.innerHTML; | |
} else { | |
normalizer = document.createElement('iframe'); | |
document.body.appendChild(normalizer); | |
normalizer.contentDocument.write(markup); | |
normalizedMarkup = normalizer.contentDocument.documentElement.outerHTML; | |
document.body.removeChild(normalizer); | |
} | |
} | |
var diffIndex = firstDifferenceIndex(normalizedMarkup, rootMarkup); | |
var difference = ' (client) ' + normalizedMarkup.substring(diffIndex - 20, diffIndex + 20) + ' | |
(server) ' + rootMarkup.substring(diffIndex - 20, diffIndex + 20); | |
!(container.nodeType !== DOC_NODE_TYPE) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'You\'re trying to render a component to the document using ' + 'server rendering but the checksum was invalid. This usually ' + 'means you rendered a different component type or props on ' + 'the client from the one on the server, or your render() ' + 'methods are impure. React cannot handle this case due to ' + 'cross-browser quirks by rendering at the document root. You ' + 'should look for environment dependent code in your components ' + 'and ensure the props are the same client and server side: | |
%s', difference) : invariant(false) : undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'React attempted to reuse markup in a container but the ' + 'checksum was invalid. This generally means that you are ' + 'using server rendering and the markup generated on the ' + 'server was not what the client was expecting. React injected ' + 'new markup to compensate which works but you have lost many ' + 'of the benefits of server rendering. Instead, figure out ' + 'why the markup being generated is different on the client ' + 'or server: | |
%s', difference) : undefined; | |
} | |
} | |
} | |
!(container.nodeType !== DOC_NODE_TYPE) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'You\'re trying to render a component to the document but ' + 'you didn\'t use server rendering. We can\'t do this ' + 'without using server rendering due to cross-browser quirks. ' + 'See ReactDOMServer.renderToString() for server rendering.') : invariant(false) : undefined; | |
if (transaction.useCreateElement) { | |
while (container.lastChild) { | |
container.removeChild(container.lastChild); | |
} | |
container.appendChild(markup); | |
} else { | |
setInnerHTML(container, markup); | |
} | |
}, | |
ownerDocumentContextKey: ownerDocumentContextKey, | |
/** | |
* React ID utilities. | |
*/ | |
getReactRootID: getReactRootID, | |
getID: getID, | |
setID: setID, | |
getNode: getNode, | |
getNodeFromInstance: getNodeFromInstance, | |
isValid: isValid, | |
purgeID: purgeID | |
}; | |
ReactPerf.measureMethods(ReactMount, 'ReactMount', { | |
_renderNewRootComponent: '_renderNewRootComponent', | |
_mountImageIntoNode: '_mountImageIntoNode' | |
}); | |
module.exports = ReactMount; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 87 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactBrowserEventEmitter | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPluginHub = __webpack_require__(89); | |
var EventPluginRegistry = __webpack_require__(90); | |
var ReactEventEmitterMixin = __webpack_require__(95); | |
var ReactPerf = __webpack_require__(76); | |
var ViewportMetrics = __webpack_require__(96); | |
var assign = __webpack_require__(29); | |
var isEventSupported = __webpack_require__(97); | |
/** | |
* Summary of `ReactBrowserEventEmitter` event handling: | |
* | |
* - Top-level delegation is used to trap most native browser events. This | |
* may only occur in the main thread and is the responsibility of | |
* ReactEventListener, which is injected and can therefore support pluggable | |
* event sources. This is the only work that occurs in the main thread. | |
* | |
* - We normalize and de-duplicate events to account for browser quirks. This | |
* may be done in the worker thread. | |
* | |
* - Forward these native events (with the associated top-level type used to | |
* trap it) to `EventPluginHub`, which in turn will ask plugins if they want | |
* to extract any synthetic events. | |
* | |
* - The `EventPluginHub` will then process each event by annotating them with | |
* "dispatches", a sequence of listeners and IDs that care about that event. | |
* | |
* - The `EventPluginHub` then dispatches the events. | |
* | |
* Overview of React and the event system: | |
* | |
* +------------+ . | |
* | DOM | . | |
* +------------+ . | |
* | . | |
* v . | |
* +------------+ . | |
* | ReactEvent | . | |
* | Listener | . | |
* +------------+ . +-----------+ | |
* | . +--------+|SimpleEvent| | |
* | . | |Plugin | | |
* +-----|------+ . v +-----------+ | |
* | | | . +--------------+ +------------+ | |
* | +-----------.--->|EventPluginHub| | Event | | |
* | | . | | +-----------+ | Propagators| | |
* | ReactEvent | . | | |TapEvent | |------------| | |
* | Emitter | . | |<---+|Plugin | |other plugin| | |
* | | . | | +-----------+ | utilities | | |
* | +-----------.--->| | +------------+ | |
* | | | . +--------------+ | |
* +-----|------+ . ^ +-----------+ | |
* | . | |Enter/Leave| | |
* + . +-------+|Plugin | | |
* +-------------+ . +-----------+ | |
* | application | . | |
* |-------------| . | |
* | | . | |
* | | . | |
* +-------------+ . | |
* . | |
* React Core . General Purpose Event Plugin System | |
*/ | |
var alreadyListeningTo = {}; | |
var isMonitoringScrollValue = false; | |
var reactTopListenersCounter = 0; | |
// For events like 'submit' which don't consistently bubble (which we trap at a | |
// lower node than `document`), binding at `document` would cause duplicate | |
// events so we don't include them here | |
var topEventMapping = { | |
topAbort: 'abort', | |
topBlur: 'blur', | |
topCanPlay: 'canplay', | |
topCanPlayThrough: 'canplaythrough', | |
topChange: 'change', | |
topClick: 'click', | |
topCompositionEnd: 'compositionend', | |
topCompositionStart: 'compositionstart', | |
topCompositionUpdate: 'compositionupdate', | |
topContextMenu: 'contextmenu', | |
topCopy: 'copy', | |
topCut: 'cut', | |
topDoubleClick: 'dblclick', | |
topDrag: 'drag', | |
topDragEnd: 'dragend', | |
topDragEnter: 'dragenter', | |
topDragExit: 'dragexit', | |
topDragLeave: 'dragleave', | |
topDragOver: 'dragover', | |
topDragStart: 'dragstart', | |
topDrop: 'drop', | |
topDurationChange: 'durationchange', | |
topEmptied: 'emptied', | |
topEncrypted: 'encrypted', | |
topEnded: 'ended', | |
topError: 'error', | |
topFocus: 'focus', | |
topInput: 'input', | |
topKeyDown: 'keydown', | |
topKeyPress: 'keypress', | |
topKeyUp: 'keyup', | |
topLoadedData: 'loadeddata', | |
topLoadedMetadata: 'loadedmetadata', | |
topLoadStart: 'loadstart', | |
topMouseDown: 'mousedown', | |
topMouseMove: 'mousemove', | |
topMouseOut: 'mouseout', | |
topMouseOver: 'mouseover', | |
topMouseUp: 'mouseup', | |
topPaste: 'paste', | |
topPause: 'pause', | |
topPlay: 'play', | |
topPlaying: 'playing', | |
topProgress: 'progress', | |
topRateChange: 'ratechange', | |
topScroll: 'scroll', | |
topSeeked: 'seeked', | |
topSeeking: 'seeking', | |
topSelectionChange: 'selectionchange', | |
topStalled: 'stalled', | |
topSuspend: 'suspend', | |
topTextInput: 'textInput', | |
topTimeUpdate: 'timeupdate', | |
topTouchCancel: 'touchcancel', | |
topTouchEnd: 'touchend', | |
topTouchMove: 'touchmove', | |
topTouchStart: 'touchstart', | |
topVolumeChange: 'volumechange', | |
topWaiting: 'waiting', | |
topWheel: 'wheel' | |
}; | |
/** | |
* To ensure no conflicts with other potential React instances on the page | |
*/ | |
var topListenersIDKey = '_reactListenersID' + String(Math.random()).slice(2); | |
function getListeningForDocument(mountAt) { | |
// In IE8, `mountAt` is a host object and doesn't have `hasOwnProperty` | |
// directly. | |
if (!Object.prototype.hasOwnProperty.call(mountAt, topListenersIDKey)) { | |
mountAt[topListenersIDKey] = reactTopListenersCounter++; | |
alreadyListeningTo[mountAt[topListenersIDKey]] = {}; | |
} | |
return alreadyListeningTo[mountAt[topListenersIDKey]]; | |
} | |
/** | |
* `ReactBrowserEventEmitter` is used to attach top-level event listeners. For | |
* example: | |
* | |
* ReactBrowserEventEmitter.putListener('myID', 'onClick', myFunction); | |
* | |
* This would allocate a "registration" of `('onClick', myFunction)` on 'myID'. | |
* | |
* @internal | |
*/ | |
var ReactBrowserEventEmitter = assign({}, ReactEventEmitterMixin, { | |
/** | |
* Injectable event backend | |
*/ | |
ReactEventListener: null, | |
injection: { | |
/** | |
* @param {object} ReactEventListener | |
*/ | |
injectReactEventListener: function (ReactEventListener) { | |
ReactEventListener.setHandleTopLevel(ReactBrowserEventEmitter.handleTopLevel); | |
ReactBrowserEventEmitter.ReactEventListener = ReactEventListener; | |
} | |
}, | |
/** | |
* Sets whether or not any created callbacks should be enabled. | |
* | |
* @param {boolean} enabled True if callbacks should be enabled. | |
*/ | |
setEnabled: function (enabled) { | |
if (ReactBrowserEventEmitter.ReactEventListener) { | |
ReactBrowserEventEmitter.ReactEventListener.setEnabled(enabled); | |
} | |
}, | |
/** | |
* @return {boolean} True if callbacks are enabled. | |
*/ | |
isEnabled: function () { | |
return !!(ReactBrowserEventEmitter.ReactEventListener && ReactBrowserEventEmitter.ReactEventListener.isEnabled()); | |
}, | |
/** | |
* We listen for bubbled touch events on the document object. | |
* | |
* Firefox v8.01 (and possibly others) exhibited strange behavior when | |
* mounting `onmousemove` events at some node that was not the document | |
* element. The symptoms were that if your mouse is not moving over something | |
* contained within that mount point (for example on the background) the | |
* top-level listeners for `onmousemove` won't be called. However, if you | |
* register the `mousemove` on the document object, then it will of course | |
* catch all `mousemove`s. This along with iOS quirks, justifies restricting | |
* top-level listeners to the document object only, at least for these | |
* movement types of events and possibly all events. | |
* | |
* @see http://www.quirksmode.org/blog/archives/2010/09/click_event_del.html | |
* | |
* Also, `keyup`/`keypress`/`keydown` do not bubble to the window on IE, but | |
* they bubble to document. | |
* | |
* @param {string} registrationName Name of listener (e.g. `onClick`). | |
* @param {object} contentDocumentHandle Document which owns the container | |
*/ | |
listenTo: function (registrationName, contentDocumentHandle) { | |
var mountAt = contentDocumentHandle; | |
var isListening = getListeningForDocument(mountAt); | |
var dependencies = EventPluginRegistry.registrationNameDependencies[registrationName]; | |
var topLevelTypes = EventConstants.topLevelTypes; | |
for (var i = 0; i < dependencies.length; i++) { | |
var dependency = dependencies[i]; | |
if (!(isListening.hasOwnProperty(dependency) && isListening[dependency])) { | |
if (dependency === topLevelTypes.topWheel) { | |
if (isEventSupported('wheel')) { | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'wheel', mountAt); | |
} else if (isEventSupported('mousewheel')) { | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'mousewheel', mountAt); | |
} else { | |
// Firefox needs to capture a different mouse scroll event. | |
// @see http://www.quirksmode.org/dom/events/tests/scroll.html | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topWheel, 'DOMMouseScroll', mountAt); | |
} | |
} else if (dependency === topLevelTypes.topScroll) { | |
if (isEventSupported('scroll', true)) { | |
ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topScroll, 'scroll', mountAt); | |
} else { | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topScroll, 'scroll', ReactBrowserEventEmitter.ReactEventListener.WINDOW_HANDLE); | |
} | |
} else if (dependency === topLevelTypes.topFocus || dependency === topLevelTypes.topBlur) { | |
if (isEventSupported('focus', true)) { | |
ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topFocus, 'focus', mountAt); | |
ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelTypes.topBlur, 'blur', mountAt); | |
} else if (isEventSupported('focusin')) { | |
// IE has `focusin` and `focusout` events which bubble. | |
// @see http://www.quirksmode.org/blog/archives/2008/04/delegating_the.html | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topFocus, 'focusin', mountAt); | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelTypes.topBlur, 'focusout', mountAt); | |
} | |
// to make sure blur and focus event listeners are only attached once | |
isListening[topLevelTypes.topBlur] = true; | |
isListening[topLevelTypes.topFocus] = true; | |
} else if (topEventMapping.hasOwnProperty(dependency)) { | |
ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(dependency, topEventMapping[dependency], mountAt); | |
} | |
isListening[dependency] = true; | |
} | |
} | |
}, | |
trapBubbledEvent: function (topLevelType, handlerBaseName, handle) { | |
return ReactBrowserEventEmitter.ReactEventListener.trapBubbledEvent(topLevelType, handlerBaseName, handle); | |
}, | |
trapCapturedEvent: function (topLevelType, handlerBaseName, handle) { | |
return ReactBrowserEventEmitter.ReactEventListener.trapCapturedEvent(topLevelType, handlerBaseName, handle); | |
}, | |
/** | |
* Listens to window scroll and resize events. We cache scroll values so that | |
* application code can access them without triggering reflows. | |
* | |
* NOTE: Scroll events do not bubble. | |
* | |
* @see http://www.quirksmode.org/dom/events/scroll.html | |
*/ | |
ensureScrollValueMonitoring: function () { | |
if (!isMonitoringScrollValue) { | |
var refresh = ViewportMetrics.refreshScrollValues; | |
ReactBrowserEventEmitter.ReactEventListener.monitorScrollValue(refresh); | |
isMonitoringScrollValue = true; | |
} | |
}, | |
eventNameDispatchConfigs: EventPluginHub.eventNameDispatchConfigs, | |
registrationNameModules: EventPluginHub.registrationNameModules, | |
putListener: EventPluginHub.putListener, | |
getListener: EventPluginHub.getListener, | |
deleteListener: EventPluginHub.deleteListener, | |
deleteAllListeners: EventPluginHub.deleteAllListeners | |
}); | |
ReactPerf.measureMethods(ReactBrowserEventEmitter, 'ReactBrowserEventEmitter', { | |
putListener: 'putListener', | |
deleteListener: 'deleteListener' | |
}); | |
module.exports = ReactBrowserEventEmitter; | |
/***/ }, | |
/* 88 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EventConstants | |
*/ | |
'use strict'; | |
var keyMirror = __webpack_require__(75); | |
var PropagationPhases = keyMirror({ bubbled: null, captured: null }); | |
/** | |
* Types of raw signals from the browser caught at the top level. | |
*/ | |
var topLevelTypes = keyMirror({ | |
topAbort: null, | |
topBlur: null, | |
topCanPlay: null, | |
topCanPlayThrough: null, | |
topChange: null, | |
topClick: null, | |
topCompositionEnd: null, | |
topCompositionStart: null, | |
topCompositionUpdate: null, | |
topContextMenu: null, | |
topCopy: null, | |
topCut: null, | |
topDoubleClick: null, | |
topDrag: null, | |
topDragEnd: null, | |
topDragEnter: null, | |
topDragExit: null, | |
topDragLeave: null, | |
topDragOver: null, | |
topDragStart: null, | |
topDrop: null, | |
topDurationChange: null, | |
topEmptied: null, | |
topEncrypted: null, | |
topEnded: null, | |
topError: null, | |
topFocus: null, | |
topInput: null, | |
topKeyDown: null, | |
topKeyPress: null, | |
topKeyUp: null, | |
topLoad: null, | |
topLoadedData: null, | |
topLoadedMetadata: null, | |
topLoadStart: null, | |
topMouseDown: null, | |
topMouseMove: null, | |
topMouseOut: null, | |
topMouseOver: null, | |
topMouseUp: null, | |
topPaste: null, | |
topPause: null, | |
topPlay: null, | |
topPlaying: null, | |
topProgress: null, | |
topRateChange: null, | |
topReset: null, | |
topScroll: null, | |
topSeeked: null, | |
topSeeking: null, | |
topSelectionChange: null, | |
topStalled: null, | |
topSubmit: null, | |
topSuspend: null, | |
topTextInput: null, | |
topTimeUpdate: null, | |
topTouchCancel: null, | |
topTouchEnd: null, | |
topTouchMove: null, | |
topTouchStart: null, | |
topVolumeChange: null, | |
topWaiting: null, | |
topWheel: null | |
}); | |
var EventConstants = { | |
topLevelTypes: topLevelTypes, | |
PropagationPhases: PropagationPhases | |
}; | |
module.exports = EventConstants; | |
/***/ }, | |
/* 89 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EventPluginHub | |
*/ | |
'use strict'; | |
var EventPluginRegistry = __webpack_require__(90); | |
var EventPluginUtils = __webpack_require__(91); | |
var ReactErrorUtils = __webpack_require__(92); | |
var accumulateInto = __webpack_require__(93); | |
var forEachAccumulated = __webpack_require__(94); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
/** | |
* Internal store for event listeners | |
*/ | |
var listenerBank = {}; | |
/** | |
* Internal queue of events that have accumulated their dispatches and are | |
* waiting to have their dispatches executed. | |
*/ | |
var eventQueue = null; | |
/** | |
* Dispatches an event and releases it back into the pool, unless persistent. | |
* | |
* @param {?object} event Synthetic event to be dispatched. | |
* @param {boolean} simulated If the event is simulated (changes exn behavior) | |
* @private | |
*/ | |
var executeDispatchesAndRelease = function (event, simulated) { | |
if (event) { | |
EventPluginUtils.executeDispatchesInOrder(event, simulated); | |
if (!event.isPersistent()) { | |
event.constructor.release(event); | |
} | |
} | |
}; | |
var executeDispatchesAndReleaseSimulated = function (e) { | |
return executeDispatchesAndRelease(e, true); | |
}; | |
var executeDispatchesAndReleaseTopLevel = function (e) { | |
return executeDispatchesAndRelease(e, false); | |
}; | |
/** | |
* - `InstanceHandle`: [required] Module that performs logical traversals of DOM | |
* hierarchy given ids of the logical DOM elements involved. | |
*/ | |
var InstanceHandle = null; | |
function validateInstanceHandle() { | |
var valid = InstanceHandle && InstanceHandle.traverseTwoPhase && InstanceHandle.traverseEnterLeave; | |
process.env.NODE_ENV !== 'production' ? warning(valid, 'InstanceHandle not injected before use!') : undefined; | |
} | |
/** | |
* This is a unified interface for event plugins to be installed and configured. | |
* | |
* Event plugins can implement the following properties: | |
* | |
* `extractEvents` {function(string, DOMEventTarget, string, object): *} | |
* Required. When a top-level event is fired, this method is expected to | |
* extract synthetic events that will in turn be queued and dispatched. | |
* | |
* `eventTypes` {object} | |
* Optional, plugins that fire events must publish a mapping of registration | |
* names that are used to register listeners. Values of this mapping must | |
* be objects that contain `registrationName` or `phasedRegistrationNames`. | |
* | |
* `executeDispatch` {function(object, function, string)} | |
* Optional, allows plugins to override how an event gets dispatched. By | |
* default, the listener is simply invoked. | |
* | |
* Each plugin that is injected into `EventsPluginHub` is immediately operable. | |
* | |
* @public | |
*/ | |
var EventPluginHub = { | |
/** | |
* Methods for injecting dependencies. | |
*/ | |
injection: { | |
/** | |
* @param {object} InjectedMount | |
* @public | |
*/ | |
injectMount: EventPluginUtils.injection.injectMount, | |
/** | |
* @param {object} InjectedInstanceHandle | |
* @public | |
*/ | |
injectInstanceHandle: function (InjectedInstanceHandle) { | |
InstanceHandle = InjectedInstanceHandle; | |
if (process.env.NODE_ENV !== 'production') { | |
validateInstanceHandle(); | |
} | |
}, | |
getInstanceHandle: function () { | |
if (process.env.NODE_ENV !== 'production') { | |
validateInstanceHandle(); | |
} | |
return InstanceHandle; | |
}, | |
/** | |
* @param {array} InjectedEventPluginOrder | |
* @public | |
*/ | |
injectEventPluginOrder: EventPluginRegistry.injectEventPluginOrder, | |
/** | |
* @param {object} injectedNamesToPlugins Map from names to plugin modules. | |
*/ | |
injectEventPluginsByName: EventPluginRegistry.injectEventPluginsByName | |
}, | |
eventNameDispatchConfigs: EventPluginRegistry.eventNameDispatchConfigs, | |
registrationNameModules: EventPluginRegistry.registrationNameModules, | |
/** | |
* Stores `listener` at `listenerBank[registrationName][id]`. Is idempotent. | |
* | |
* @param {string} id ID of the DOM element. | |
* @param {string} registrationName Name of listener (e.g. `onClick`). | |
* @param {?function} listener The callback to store. | |
*/ | |
putListener: function (id, registrationName, listener) { | |
!(typeof listener === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected %s listener to be a function, instead got type %s', registrationName, typeof listener) : invariant(false) : undefined; | |
var bankForRegistrationName = listenerBank[registrationName] || (listenerBank[registrationName] = {}); | |
bankForRegistrationName[id] = listener; | |
var PluginModule = EventPluginRegistry.registrationNameModules[registrationName]; | |
if (PluginModule && PluginModule.didPutListener) { | |
PluginModule.didPutListener(id, registrationName, listener); | |
} | |
}, | |
/** | |
* @param {string} id ID of the DOM element. | |
* @param {string} registrationName Name of listener (e.g. `onClick`). | |
* @return {?function} The stored callback. | |
*/ | |
getListener: function (id, registrationName) { | |
var bankForRegistrationName = listenerBank[registrationName]; | |
return bankForRegistrationName && bankForRegistrationName[id]; | |
}, | |
/** | |
* Deletes a listener from the registration bank. | |
* | |
* @param {string} id ID of the DOM element. | |
* @param {string} registrationName Name of listener (e.g. `onClick`). | |
*/ | |
deleteListener: function (id, registrationName) { | |
var PluginModule = EventPluginRegistry.registrationNameModules[registrationName]; | |
if (PluginModule && PluginModule.willDeleteListener) { | |
PluginModule.willDeleteListener(id, registrationName); | |
} | |
var bankForRegistrationName = listenerBank[registrationName]; | |
// TODO: This should never be null -- when is it? | |
if (bankForRegistrationName) { | |
delete bankForRegistrationName[id]; | |
} | |
}, | |
/** | |
* Deletes all listeners for the DOM element with the supplied ID. | |
* | |
* @param {string} id ID of the DOM element. | |
*/ | |
deleteAllListeners: function (id) { | |
for (var registrationName in listenerBank) { | |
if (!listenerBank[registrationName][id]) { | |
continue; | |
} | |
var PluginModule = EventPluginRegistry.registrationNameModules[registrationName]; | |
if (PluginModule && PluginModule.willDeleteListener) { | |
PluginModule.willDeleteListener(id, registrationName); | |
} | |
delete listenerBank[registrationName][id]; | |
} | |
}, | |
/** | |
* Allows registered plugins an opportunity to extract events from top-level | |
* native browser events. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @internal | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var events; | |
var plugins = EventPluginRegistry.plugins; | |
for (var i = 0; i < plugins.length; i++) { | |
// Not every plugin in the ordering may be loaded at runtime. | |
var possiblePlugin = plugins[i]; | |
if (possiblePlugin) { | |
var extractedEvents = possiblePlugin.extractEvents(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget); | |
if (extractedEvents) { | |
events = accumulateInto(events, extractedEvents); | |
} | |
} | |
} | |
return events; | |
}, | |
/** | |
* Enqueues a synthetic event that should be dispatched when | |
* `processEventQueue` is invoked. | |
* | |
* @param {*} events An accumulation of synthetic events. | |
* @internal | |
*/ | |
enqueueEvents: function (events) { | |
if (events) { | |
eventQueue = accumulateInto(eventQueue, events); | |
} | |
}, | |
/** | |
* Dispatches all synthetic events on the event queue. | |
* | |
* @internal | |
*/ | |
processEventQueue: function (simulated) { | |
// Set `eventQueue` to null before processing it so that we can tell if more | |
// events get enqueued while processing. | |
var processingEventQueue = eventQueue; | |
eventQueue = null; | |
if (simulated) { | |
forEachAccumulated(processingEventQueue, executeDispatchesAndReleaseSimulated); | |
} else { | |
forEachAccumulated(processingEventQueue, executeDispatchesAndReleaseTopLevel); | |
} | |
!!eventQueue ? process.env.NODE_ENV !== 'production' ? invariant(false, 'processEventQueue(): Additional events were enqueued while processing ' + 'an event queue. Support for this has not yet been implemented.') : invariant(false) : undefined; | |
// This would be a good time to rethrow if any of the event handlers threw. | |
ReactErrorUtils.rethrowCaughtError(); | |
}, | |
/** | |
* These are needed for tests only. Do not use! | |
*/ | |
__purge: function () { | |
listenerBank = {}; | |
}, | |
__getListenerBank: function () { | |
return listenerBank; | |
} | |
}; | |
module.exports = EventPluginHub; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 90 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EventPluginRegistry | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* Injectable ordering of event plugins. | |
*/ | |
var EventPluginOrder = null; | |
/** | |
* Injectable mapping from names to event plugin modules. | |
*/ | |
var namesToPlugins = {}; | |
/** | |
* Recomputes the plugin list using the injected plugins and plugin ordering. | |
* | |
* @private | |
*/ | |
function recomputePluginOrdering() { | |
if (!EventPluginOrder) { | |
// Wait until an `EventPluginOrder` is injected. | |
return; | |
} | |
for (var pluginName in namesToPlugins) { | |
var PluginModule = namesToPlugins[pluginName]; | |
var pluginIndex = EventPluginOrder.indexOf(pluginName); | |
!(pluginIndex > -1) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject event plugins that do not exist in ' + 'the plugin ordering, `%s`.', pluginName) : invariant(false) : undefined; | |
if (EventPluginRegistry.plugins[pluginIndex]) { | |
continue; | |
} | |
!PluginModule.extractEvents ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Event plugins must implement an `extractEvents` ' + 'method, but `%s` does not.', pluginName) : invariant(false) : undefined; | |
EventPluginRegistry.plugins[pluginIndex] = PluginModule; | |
var publishedEvents = PluginModule.eventTypes; | |
for (var eventName in publishedEvents) { | |
!publishEventForPlugin(publishedEvents[eventName], PluginModule, eventName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Failed to publish event `%s` for plugin `%s`.', eventName, pluginName) : invariant(false) : undefined; | |
} | |
} | |
} | |
/** | |
* Publishes an event so that it can be dispatched by the supplied plugin. | |
* | |
* @param {object} dispatchConfig Dispatch configuration for the event. | |
* @param {object} PluginModule Plugin publishing the event. | |
* @return {boolean} True if the event was successfully published. | |
* @private | |
*/ | |
function publishEventForPlugin(dispatchConfig, PluginModule, eventName) { | |
!!EventPluginRegistry.eventNameDispatchConfigs.hasOwnProperty(eventName) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginHub: More than one plugin attempted to publish the same ' + 'event name, `%s`.', eventName) : invariant(false) : undefined; | |
EventPluginRegistry.eventNameDispatchConfigs[eventName] = dispatchConfig; | |
var phasedRegistrationNames = dispatchConfig.phasedRegistrationNames; | |
if (phasedRegistrationNames) { | |
for (var phaseName in phasedRegistrationNames) { | |
if (phasedRegistrationNames.hasOwnProperty(phaseName)) { | |
var phasedRegistrationName = phasedRegistrationNames[phaseName]; | |
publishRegistrationName(phasedRegistrationName, PluginModule, eventName); | |
} | |
} | |
return true; | |
} else if (dispatchConfig.registrationName) { | |
publishRegistrationName(dispatchConfig.registrationName, PluginModule, eventName); | |
return true; | |
} | |
return false; | |
} | |
/** | |
* Publishes a registration name that is used to identify dispatched events and | |
* can be used with `EventPluginHub.putListener` to register listeners. | |
* | |
* @param {string} registrationName Registration name to add. | |
* @param {object} PluginModule Plugin publishing the event. | |
* @private | |
*/ | |
function publishRegistrationName(registrationName, PluginModule, eventName) { | |
!!EventPluginRegistry.registrationNameModules[registrationName] ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginHub: More than one plugin attempted to publish the same ' + 'registration name, `%s`.', registrationName) : invariant(false) : undefined; | |
EventPluginRegistry.registrationNameModules[registrationName] = PluginModule; | |
EventPluginRegistry.registrationNameDependencies[registrationName] = PluginModule.eventTypes[eventName].dependencies; | |
} | |
/** | |
* Registers plugins so that they can extract and dispatch events. | |
* | |
* @see {EventPluginHub} | |
*/ | |
var EventPluginRegistry = { | |
/** | |
* Ordered list of injected plugins. | |
*/ | |
plugins: [], | |
/** | |
* Mapping from event name to dispatch config | |
*/ | |
eventNameDispatchConfigs: {}, | |
/** | |
* Mapping from registration name to plugin module | |
*/ | |
registrationNameModules: {}, | |
/** | |
* Mapping from registration name to event name | |
*/ | |
registrationNameDependencies: {}, | |
/** | |
* Injects an ordering of plugins (by plugin name). This allows the ordering | |
* to be decoupled from injection of the actual plugins so that ordering is | |
* always deterministic regardless of packaging, on-the-fly injection, etc. | |
* | |
* @param {array} InjectedEventPluginOrder | |
* @internal | |
* @see {EventPluginHub.injection.injectEventPluginOrder} | |
*/ | |
injectEventPluginOrder: function (InjectedEventPluginOrder) { | |
!!EventPluginOrder ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject event plugin ordering more than ' + 'once. You are likely trying to load more than one copy of React.') : invariant(false) : undefined; | |
// Clone the ordering so it cannot be dynamically mutated. | |
EventPluginOrder = Array.prototype.slice.call(InjectedEventPluginOrder); | |
recomputePluginOrdering(); | |
}, | |
/** | |
* Injects plugins to be used by `EventPluginHub`. The plugin names must be | |
* in the ordering injected by `injectEventPluginOrder`. | |
* | |
* Plugins can be injected as part of page initialization or on-the-fly. | |
* | |
* @param {object} injectedNamesToPlugins Map from names to plugin modules. | |
* @internal | |
* @see {EventPluginHub.injection.injectEventPluginsByName} | |
*/ | |
injectEventPluginsByName: function (injectedNamesToPlugins) { | |
var isOrderingDirty = false; | |
for (var pluginName in injectedNamesToPlugins) { | |
if (!injectedNamesToPlugins.hasOwnProperty(pluginName)) { | |
continue; | |
} | |
var PluginModule = injectedNamesToPlugins[pluginName]; | |
if (!namesToPlugins.hasOwnProperty(pluginName) || namesToPlugins[pluginName] !== PluginModule) { | |
!!namesToPlugins[pluginName] ? process.env.NODE_ENV !== 'production' ? invariant(false, 'EventPluginRegistry: Cannot inject two different event plugins ' + 'using the same name, `%s`.', pluginName) : invariant(false) : undefined; | |
namesToPlugins[pluginName] = PluginModule; | |
isOrderingDirty = true; | |
} | |
} | |
if (isOrderingDirty) { | |
recomputePluginOrdering(); | |
} | |
}, | |
/** | |
* Looks up the plugin for the supplied event. | |
* | |
* @param {object} event A synthetic event. | |
* @return {?object} The plugin that created the supplied event. | |
* @internal | |
*/ | |
getPluginModuleForEvent: function (event) { | |
var dispatchConfig = event.dispatchConfig; | |
if (dispatchConfig.registrationName) { | |
return EventPluginRegistry.registrationNameModules[dispatchConfig.registrationName] || null; | |
} | |
for (var phase in dispatchConfig.phasedRegistrationNames) { | |
if (!dispatchConfig.phasedRegistrationNames.hasOwnProperty(phase)) { | |
continue; | |
} | |
var PluginModule = EventPluginRegistry.registrationNameModules[dispatchConfig.phasedRegistrationNames[phase]]; | |
if (PluginModule) { | |
return PluginModule; | |
} | |
} | |
return null; | |
}, | |
/** | |
* Exposed for unit testing. | |
* @private | |
*/ | |
_resetEventPlugins: function () { | |
EventPluginOrder = null; | |
for (var pluginName in namesToPlugins) { | |
if (namesToPlugins.hasOwnProperty(pluginName)) { | |
delete namesToPlugins[pluginName]; | |
} | |
} | |
EventPluginRegistry.plugins.length = 0; | |
var eventNameDispatchConfigs = EventPluginRegistry.eventNameDispatchConfigs; | |
for (var eventName in eventNameDispatchConfigs) { | |
if (eventNameDispatchConfigs.hasOwnProperty(eventName)) { | |
delete eventNameDispatchConfigs[eventName]; | |
} | |
} | |
var registrationNameModules = EventPluginRegistry.registrationNameModules; | |
for (var registrationName in registrationNameModules) { | |
if (registrationNameModules.hasOwnProperty(registrationName)) { | |
delete registrationNameModules[registrationName]; | |
} | |
} | |
} | |
}; | |
module.exports = EventPluginRegistry; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 91 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EventPluginUtils | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var ReactErrorUtils = __webpack_require__(92); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
/** | |
* Injected dependencies: | |
*/ | |
/** | |
* - `Mount`: [required] Module that can convert between React dom IDs and | |
* actual node references. | |
*/ | |
var injection = { | |
Mount: null, | |
injectMount: function (InjectedMount) { | |
injection.Mount = InjectedMount; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(InjectedMount && InjectedMount.getNode && InjectedMount.getID, 'EventPluginUtils.injection.injectMount(...): Injected Mount ' + 'module is missing getNode or getID.') : undefined; | |
} | |
} | |
}; | |
var topLevelTypes = EventConstants.topLevelTypes; | |
function isEndish(topLevelType) { | |
return topLevelType === topLevelTypes.topMouseUp || topLevelType === topLevelTypes.topTouchEnd || topLevelType === topLevelTypes.topTouchCancel; | |
} | |
function isMoveish(topLevelType) { | |
return topLevelType === topLevelTypes.topMouseMove || topLevelType === topLevelTypes.topTouchMove; | |
} | |
function isStartish(topLevelType) { | |
return topLevelType === topLevelTypes.topMouseDown || topLevelType === topLevelTypes.topTouchStart; | |
} | |
var validateEventDispatches; | |
if (process.env.NODE_ENV !== 'production') { | |
validateEventDispatches = function (event) { | |
var dispatchListeners = event._dispatchListeners; | |
var dispatchIDs = event._dispatchIDs; | |
var listenersIsArr = Array.isArray(dispatchListeners); | |
var idsIsArr = Array.isArray(dispatchIDs); | |
var IDsLen = idsIsArr ? dispatchIDs.length : dispatchIDs ? 1 : 0; | |
var listenersLen = listenersIsArr ? dispatchListeners.length : dispatchListeners ? 1 : 0; | |
process.env.NODE_ENV !== 'production' ? warning(idsIsArr === listenersIsArr && IDsLen === listenersLen, 'EventPluginUtils: Invalid `event`.') : undefined; | |
}; | |
} | |
/** | |
* Dispatch the event to the listener. | |
* @param {SyntheticEvent} event SyntheticEvent to handle | |
* @param {boolean} simulated If the event is simulated (changes exn behavior) | |
* @param {function} listener Application-level callback | |
* @param {string} domID DOM id to pass to the callback. | |
*/ | |
function executeDispatch(event, simulated, listener, domID) { | |
var type = event.type || 'unknown-event'; | |
event.currentTarget = injection.Mount.getNode(domID); | |
if (simulated) { | |
ReactErrorUtils.invokeGuardedCallbackWithCatch(type, listener, event, domID); | |
} else { | |
ReactErrorUtils.invokeGuardedCallback(type, listener, event, domID); | |
} | |
event.currentTarget = null; | |
} | |
/** | |
* Standard/simple iteration through an event's collected dispatches. | |
*/ | |
function executeDispatchesInOrder(event, simulated) { | |
var dispatchListeners = event._dispatchListeners; | |
var dispatchIDs = event._dispatchIDs; | |
if (process.env.NODE_ENV !== 'production') { | |
validateEventDispatches(event); | |
} | |
if (Array.isArray(dispatchListeners)) { | |
for (var i = 0; i < dispatchListeners.length; i++) { | |
if (event.isPropagationStopped()) { | |
break; | |
} | |
// Listeners and IDs are two parallel arrays that are always in sync. | |
executeDispatch(event, simulated, dispatchListeners[i], dispatchIDs[i]); | |
} | |
} else if (dispatchListeners) { | |
executeDispatch(event, simulated, dispatchListeners, dispatchIDs); | |
} | |
event._dispatchListeners = null; | |
event._dispatchIDs = null; | |
} | |
/** | |
* Standard/simple iteration through an event's collected dispatches, but stops | |
* at the first dispatch execution returning true, and returns that id. | |
* | |
* @return {?string} id of the first dispatch execution who's listener returns | |
* true, or null if no listener returned true. | |
*/ | |
function executeDispatchesInOrderStopAtTrueImpl(event) { | |
var dispatchListeners = event._dispatchListeners; | |
var dispatchIDs = event._dispatchIDs; | |
if (process.env.NODE_ENV !== 'production') { | |
validateEventDispatches(event); | |
} | |
if (Array.isArray(dispatchListeners)) { | |
for (var i = 0; i < dispatchListeners.length; i++) { | |
if (event.isPropagationStopped()) { | |
break; | |
} | |
// Listeners and IDs are two parallel arrays that are always in sync. | |
if (dispatchListeners[i](event, dispatchIDs[i])) { | |
return dispatchIDs[i]; | |
} | |
} | |
} else if (dispatchListeners) { | |
if (dispatchListeners(event, dispatchIDs)) { | |
return dispatchIDs; | |
} | |
} | |
return null; | |
} | |
/** | |
* @see executeDispatchesInOrderStopAtTrueImpl | |
*/ | |
function executeDispatchesInOrderStopAtTrue(event) { | |
var ret = executeDispatchesInOrderStopAtTrueImpl(event); | |
event._dispatchIDs = null; | |
event._dispatchListeners = null; | |
return ret; | |
} | |
/** | |
* Execution of a "direct" dispatch - there must be at most one dispatch | |
* accumulated on the event or it is considered an error. It doesn't really make | |
* sense for an event with multiple dispatches (bubbled) to keep track of the | |
* return values at each dispatch execution, but it does tend to make sense when | |
* dealing with "direct" dispatches. | |
* | |
* @return {*} The return value of executing the single dispatch. | |
*/ | |
function executeDirectDispatch(event) { | |
if (process.env.NODE_ENV !== 'production') { | |
validateEventDispatches(event); | |
} | |
var dispatchListener = event._dispatchListeners; | |
var dispatchID = event._dispatchIDs; | |
!!Array.isArray(dispatchListener) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'executeDirectDispatch(...): Invalid `event`.') : invariant(false) : undefined; | |
var res = dispatchListener ? dispatchListener(event, dispatchID) : null; | |
event._dispatchListeners = null; | |
event._dispatchIDs = null; | |
return res; | |
} | |
/** | |
* @param {SyntheticEvent} event | |
* @return {boolean} True iff number of dispatches accumulated is greater than 0. | |
*/ | |
function hasDispatches(event) { | |
return !!event._dispatchListeners; | |
} | |
/** | |
* General utilities that are useful in creating custom Event Plugins. | |
*/ | |
var EventPluginUtils = { | |
isEndish: isEndish, | |
isMoveish: isMoveish, | |
isStartish: isStartish, | |
executeDirectDispatch: executeDirectDispatch, | |
executeDispatchesInOrder: executeDispatchesInOrder, | |
executeDispatchesInOrderStopAtTrue: executeDispatchesInOrderStopAtTrue, | |
hasDispatches: hasDispatches, | |
getNode: function (id) { | |
return injection.Mount.getNode(id); | |
}, | |
getID: function (node) { | |
return injection.Mount.getID(node); | |
}, | |
injection: injection | |
}; | |
module.exports = EventPluginUtils; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 92 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactErrorUtils | |
* @typechecks | |
*/ | |
'use strict'; | |
var caughtError = null; | |
/** | |
* Call a function while guarding against errors that happens within it. | |
* | |
* @param {?String} name of the guard to use for logging or debugging | |
* @param {Function} func The function to invoke | |
* @param {*} a First argument | |
* @param {*} b Second argument | |
*/ | |
function invokeGuardedCallback(name, func, a, b) { | |
try { | |
return func(a, b); | |
} catch (x) { | |
if (caughtError === null) { | |
caughtError = x; | |
} | |
return undefined; | |
} | |
} | |
var ReactErrorUtils = { | |
invokeGuardedCallback: invokeGuardedCallback, | |
/** | |
* Invoked by ReactTestUtils.Simulate so that any errors thrown by the event | |
* handler are sure to be rethrown by rethrowCaughtError. | |
*/ | |
invokeGuardedCallbackWithCatch: invokeGuardedCallback, | |
/** | |
* During execution of guarded functions we will capture the first error which | |
* we will rethrow to be handled by the top level error handler. | |
*/ | |
rethrowCaughtError: function () { | |
if (caughtError) { | |
var error = caughtError; | |
caughtError = null; | |
throw error; | |
} | |
} | |
}; | |
if (process.env.NODE_ENV !== 'production') { | |
/** | |
* To help development we can get better devtools integration by simulating a | |
* real browser event. | |
*/ | |
if (typeof window !== 'undefined' && typeof window.dispatchEvent === 'function' && typeof document !== 'undefined' && typeof document.createEvent === 'function') { | |
var fakeNode = document.createElement('react'); | |
ReactErrorUtils.invokeGuardedCallback = function (name, func, a, b) { | |
var boundFunc = func.bind(null, a, b); | |
var evtType = 'react-' + name; | |
fakeNode.addEventListener(evtType, boundFunc, false); | |
var evt = document.createEvent('Event'); | |
evt.initEvent(evtType, false, false); | |
fakeNode.dispatchEvent(evt); | |
fakeNode.removeEventListener(evtType, boundFunc, false); | |
}; | |
} | |
} | |
module.exports = ReactErrorUtils; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 93 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule accumulateInto | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* | |
* Accumulates items that must not be null or undefined into the first one. This | |
* is used to conserve memory by avoiding array allocations, and thus sacrifices | |
* API cleanness. Since `current` can be null before being passed in and not | |
* null after this function, make sure to assign it back to `current`: | |
* | |
* `a = accumulateInto(a, b);` | |
* | |
* This API should be sparingly used. Try `accumulate` for something cleaner. | |
* | |
* @return {*|array<*>} An accumulation of items. | |
*/ | |
function accumulateInto(current, next) { | |
!(next != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'accumulateInto(...): Accumulated items must not be null or undefined.') : invariant(false) : undefined; | |
if (current == null) { | |
return next; | |
} | |
// Both are not empty. Warning: Never call x.concat(y) when you are not | |
// certain that x is an Array (x could be a string with concat method). | |
var currentIsArray = Array.isArray(current); | |
var nextIsArray = Array.isArray(next); | |
if (currentIsArray && nextIsArray) { | |
current.push.apply(current, next); | |
return current; | |
} | |
if (currentIsArray) { | |
current.push(next); | |
return current; | |
} | |
if (nextIsArray) { | |
// A bit too dangerous to mutate `next`. | |
return [current].concat(next); | |
} | |
return [current, next]; | |
} | |
module.exports = accumulateInto; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 94 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule forEachAccumulated | |
*/ | |
'use strict'; | |
/** | |
* @param {array} arr an "accumulation" of items which is either an Array or | |
* a single item. Useful when paired with the `accumulate` module. This is a | |
* simple utility that allows us to reason about a collection of items, but | |
* handling the case when there is exactly one item (and we do not need to | |
* allocate an array). | |
*/ | |
var forEachAccumulated = function (arr, cb, scope) { | |
if (Array.isArray(arr)) { | |
arr.forEach(cb, scope); | |
} else if (arr) { | |
cb.call(scope, arr); | |
} | |
}; | |
module.exports = forEachAccumulated; | |
/***/ }, | |
/* 95 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactEventEmitterMixin | |
*/ | |
'use strict'; | |
var EventPluginHub = __webpack_require__(89); | |
function runEventQueueInBatch(events) { | |
EventPluginHub.enqueueEvents(events); | |
EventPluginHub.processEventQueue(false); | |
} | |
var ReactEventEmitterMixin = { | |
/** | |
* Streams a fired top-level event to `EventPluginHub` where plugins have the | |
* opportunity to create `ReactEvent`s to be dispatched. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {object} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native environment event. | |
*/ | |
handleTopLevel: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var events = EventPluginHub.extractEvents(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget); | |
runEventQueueInBatch(events); | |
} | |
}; | |
module.exports = ReactEventEmitterMixin; | |
/***/ }, | |
/* 96 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ViewportMetrics | |
*/ | |
'use strict'; | |
var ViewportMetrics = { | |
currentScrollLeft: 0, | |
currentScrollTop: 0, | |
refreshScrollValues: function (scrollPosition) { | |
ViewportMetrics.currentScrollLeft = scrollPosition.x; | |
ViewportMetrics.currentScrollTop = scrollPosition.y; | |
} | |
}; | |
module.exports = ViewportMetrics; | |
/***/ }, | |
/* 97 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule isEventSupported | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var useHasFeature; | |
if (ExecutionEnvironment.canUseDOM) { | |
useHasFeature = document.implementation && document.implementation.hasFeature && | |
// always returns true in newer browsers as per the standard. | |
// @see http://dom.spec.whatwg.org/#dom-domimplementation-hasfeature | |
document.implementation.hasFeature('', '') !== true; | |
} | |
/** | |
* Checks if an event is supported in the current execution environment. | |
* | |
* NOTE: This will not work correctly for non-generic events such as `change`, | |
* `reset`, `load`, `error`, and `select`. | |
* | |
* Borrows from Modernizr. | |
* | |
* @param {string} eventNameSuffix Event name, e.g. "click". | |
* @param {?boolean} capture Check if the capture phase is supported. | |
* @return {boolean} True if the event is supported. | |
* @internal | |
* @license Modernizr 3.0.0pre (Custom Build) | MIT | |
*/ | |
function isEventSupported(eventNameSuffix, capture) { | |
if (!ExecutionEnvironment.canUseDOM || capture && !('addEventListener' in document)) { | |
return false; | |
} | |
var eventName = 'on' + eventNameSuffix; | |
var isSupported = (eventName in document); | |
if (!isSupported) { | |
var element = document.createElement('div'); | |
element.setAttribute(eventName, 'return;'); | |
isSupported = typeof element[eventName] === 'function'; | |
} | |
if (!isSupported && useHasFeature && eventNameSuffix === 'wheel') { | |
// This is the only way to test support for the `wheel` event in IE9+. | |
isSupported = document.implementation.hasFeature('Events.wheel', '3.0'); | |
} | |
return isSupported; | |
} | |
module.exports = isEventSupported; | |
/***/ }, | |
/* 98 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMFeatureFlags | |
*/ | |
'use strict'; | |
var ReactDOMFeatureFlags = { | |
useCreateElement: false | |
}; | |
module.exports = ReactDOMFeatureFlags; | |
/***/ }, | |
/* 99 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactElement | |
*/ | |
'use strict'; | |
var ReactCurrentOwner = __webpack_require__(64); | |
var assign = __webpack_require__(29); | |
var canDefineProperty = __webpack_require__(100); | |
// The Symbol used to tag the ReactElement type. If there is no native Symbol | |
// nor polyfill, then a plain number is used for performance. | |
var REACT_ELEMENT_TYPE = typeof Symbol === 'function' && Symbol['for'] && Symbol['for']('react.element') || 0xeac7; | |
var RESERVED_PROPS = { | |
key: true, | |
ref: true, | |
__self: true, | |
__source: true | |
}; | |
/** | |
* Base constructor for all React elements. This is only used to make this | |
* work with a dynamic instanceof check. Nothing should live on this prototype. | |
* | |
* @param {*} type | |
* @param {*} key | |
* @param {string|object} ref | |
* @param {*} self A *temporary* helper to detect places where `this` is | |
* different from the `owner` when React.createElement is called, so that we | |
* can warn. We want to get rid of owner and replace string `ref`s with arrow | |
* functions, and as long as `this` and owner are the same, there will be no | |
* change in behavior. | |
* @param {*} source An annotation object (added by a transpiler or otherwise) | |
* indicating filename, line number, and/or other information. | |
* @param {*} owner | |
* @param {*} props | |
* @internal | |
*/ | |
var ReactElement = function (type, key, ref, self, source, owner, props) { | |
var element = { | |
// This tag allow us to uniquely identify this as a React Element | |
$$typeof: REACT_ELEMENT_TYPE, | |
// Built-in properties that belong on the element | |
type: type, | |
key: key, | |
ref: ref, | |
props: props, | |
// Record the component responsible for creating this element. | |
_owner: owner | |
}; | |
if (process.env.NODE_ENV !== 'production') { | |
// The validation flag is currently mutative. We put it on | |
// an external backing store so that we can freeze the whole object. | |
// This can be replaced with a WeakMap once they are implemented in | |
// commonly used development environments. | |
element._store = {}; | |
// To make comparing ReactElements easier for testing purposes, we make | |
// the validation flag non-enumerable (where possible, which should | |
// include every environment we run tests in), so the test framework | |
// ignores it. | |
if (canDefineProperty) { | |
Object.defineProperty(element._store, 'validated', { | |
configurable: false, | |
enumerable: false, | |
writable: true, | |
value: false | |
}); | |
// self and source are DEV only properties. | |
Object.defineProperty(element, '_self', { | |
configurable: false, | |
enumerable: false, | |
writable: false, | |
value: self | |
}); | |
// Two elements created in two different places should be considered | |
// equal for testing purposes and therefore we hide it from enumeration. | |
Object.defineProperty(element, '_source', { | |
configurable: false, | |
enumerable: false, | |
writable: false, | |
value: source | |
}); | |
} else { | |
element._store.validated = false; | |
element._self = self; | |
element._source = source; | |
} | |
Object.freeze(element.props); | |
Object.freeze(element); | |
} | |
return element; | |
}; | |
ReactElement.createElement = function (type, config, children) { | |
var propName; | |
// Reserved names are extracted | |
var props = {}; | |
var key = null; | |
var ref = null; | |
var self = null; | |
var source = null; | |
if (config != null) { | |
ref = config.ref === undefined ? null : config.ref; | |
key = config.key === undefined ? null : '' + config.key; | |
self = config.__self === undefined ? null : config.__self; | |
source = config.__source === undefined ? null : config.__source; | |
// Remaining properties are added to a new props object | |
for (propName in config) { | |
if (config.hasOwnProperty(propName) && !RESERVED_PROPS.hasOwnProperty(propName)) { | |
props[propName] = config[propName]; | |
} | |
} | |
} | |
// Children can be more than one argument, and those are transferred onto | |
// the newly allocated props object. | |
var childrenLength = arguments.length - 2; | |
if (childrenLength === 1) { | |
props.children = children; | |
} else if (childrenLength > 1) { | |
var childArray = Array(childrenLength); | |
for (var i = 0; i < childrenLength; i++) { | |
childArray[i] = arguments[i + 2]; | |
} | |
props.children = childArray; | |
} | |
// Resolve default props | |
if (type && type.defaultProps) { | |
var defaultProps = type.defaultProps; | |
for (propName in defaultProps) { | |
if (typeof props[propName] === 'undefined') { | |
props[propName] = defaultProps[propName]; | |
} | |
} | |
} | |
return ReactElement(type, key, ref, self, source, ReactCurrentOwner.current, props); | |
}; | |
ReactElement.createFactory = function (type) { | |
var factory = ReactElement.createElement.bind(null, type); | |
// Expose the type on the factory and the prototype so that it can be | |
// easily accessed on elements. E.g. `<Foo />.type === Foo`. | |
// This should not be named `constructor` since this may not be the function | |
// that created the element, and it may not even be a constructor. | |
// Legacy hook TODO: Warn if this is accessed | |
factory.type = type; | |
return factory; | |
}; | |
ReactElement.cloneAndReplaceKey = function (oldElement, newKey) { | |
var newElement = ReactElement(oldElement.type, newKey, oldElement.ref, oldElement._self, oldElement._source, oldElement._owner, oldElement.props); | |
return newElement; | |
}; | |
ReactElement.cloneAndReplaceProps = function (oldElement, newProps) { | |
var newElement = ReactElement(oldElement.type, oldElement.key, oldElement.ref, oldElement._self, oldElement._source, oldElement._owner, newProps); | |
if (process.env.NODE_ENV !== 'production') { | |
// If the key on the original is valid, then the clone is valid | |
newElement._store.validated = oldElement._store.validated; | |
} | |
return newElement; | |
}; | |
ReactElement.cloneElement = function (element, config, children) { | |
var propName; | |
// Original props are copied | |
var props = assign({}, element.props); | |
// Reserved names are extracted | |
var key = element.key; | |
var ref = element.ref; | |
// Self is preserved since the owner is preserved. | |
var self = element._self; | |
// Source is preserved since cloneElement is unlikely to be targeted by a | |
// transpiler, and the original source is probably a better indicator of the | |
// true owner. | |
var source = element._source; | |
// Owner will be preserved, unless ref is overridden | |
var owner = element._owner; | |
if (config != null) { | |
if (config.ref !== undefined) { | |
// Silently steal the ref from the parent. | |
ref = config.ref; | |
owner = ReactCurrentOwner.current; | |
} | |
if (config.key !== undefined) { | |
key = '' + config.key; | |
} | |
// Remaining properties override existing props | |
for (propName in config) { | |
if (config.hasOwnProperty(propName) && !RESERVED_PROPS.hasOwnProperty(propName)) { | |
props[propName] = config[propName]; | |
} | |
} | |
} | |
// Children can be more than one argument, and those are transferred onto | |
// the newly allocated props object. | |
var childrenLength = arguments.length - 2; | |
if (childrenLength === 1) { | |
props.children = children; | |
} else if (childrenLength > 1) { | |
var childArray = Array(childrenLength); | |
for (var i = 0; i < childrenLength; i++) { | |
childArray[i] = arguments[i + 2]; | |
} | |
props.children = childArray; | |
} | |
return ReactElement(element.type, key, ref, self, source, owner, props); | |
}; | |
/** | |
* @param {?object} object | |
* @return {boolean} True if `object` is a valid component. | |
* @final | |
*/ | |
ReactElement.isValidElement = function (object) { | |
return typeof object === 'object' && object !== null && object.$$typeof === REACT_ELEMENT_TYPE; | |
}; | |
module.exports = ReactElement; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 100 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule canDefineProperty | |
*/ | |
'use strict'; | |
var canDefineProperty = false; | |
if (process.env.NODE_ENV !== 'production') { | |
try { | |
Object.defineProperty({}, 'x', { get: function () {} }); | |
canDefineProperty = true; | |
} catch (x) { | |
// IE will fail on defineProperty | |
} | |
} | |
module.exports = canDefineProperty; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 101 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactEmptyComponentRegistry | |
*/ | |
'use strict'; | |
// This registry keeps track of the React IDs of the components that rendered to | |
// `null` (in reality a placeholder such as `noscript`) | |
var nullComponentIDsRegistry = {}; | |
/** | |
* @param {string} id Component's `_rootNodeID`. | |
* @return {boolean} True if the component is rendered to null. | |
*/ | |
function isNullComponentID(id) { | |
return !!nullComponentIDsRegistry[id]; | |
} | |
/** | |
* Mark the component as having rendered to null. | |
* @param {string} id Component's `_rootNodeID`. | |
*/ | |
function registerNullComponentID(id) { | |
nullComponentIDsRegistry[id] = true; | |
} | |
/** | |
* Unmark the component as having rendered to null: it renders to something now. | |
* @param {string} id Component's `_rootNodeID`. | |
*/ | |
function deregisterNullComponentID(id) { | |
delete nullComponentIDsRegistry[id]; | |
} | |
var ReactEmptyComponentRegistry = { | |
isNullComponentID: isNullComponentID, | |
registerNullComponentID: registerNullComponentID, | |
deregisterNullComponentID: deregisterNullComponentID | |
}; | |
module.exports = ReactEmptyComponentRegistry; | |
/***/ }, | |
/* 102 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactInstanceHandles | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactRootIndex = __webpack_require__(103); | |
var invariant = __webpack_require__(31); | |
var SEPARATOR = '.'; | |
var SEPARATOR_LENGTH = SEPARATOR.length; | |
/** | |
* Maximum depth of traversals before we consider the possibility of a bad ID. | |
*/ | |
var MAX_TREE_DEPTH = 10000; | |
/** | |
* Creates a DOM ID prefix to use when mounting React components. | |
* | |
* @param {number} index A unique integer | |
* @return {string} React root ID. | |
* @internal | |
*/ | |
function getReactRootIDString(index) { | |
return SEPARATOR + index.toString(36); | |
} | |
/** | |
* Checks if a character in the supplied ID is a separator or the end. | |
* | |
* @param {string} id A React DOM ID. | |
* @param {number} index Index of the character to check. | |
* @return {boolean} True if the character is a separator or end of the ID. | |
* @private | |
*/ | |
function isBoundary(id, index) { | |
return id.charAt(index) === SEPARATOR || index === id.length; | |
} | |
/** | |
* Checks if the supplied string is a valid React DOM ID. | |
* | |
* @param {string} id A React DOM ID, maybe. | |
* @return {boolean} True if the string is a valid React DOM ID. | |
* @private | |
*/ | |
function isValidID(id) { | |
return id === '' || id.charAt(0) === SEPARATOR && id.charAt(id.length - 1) !== SEPARATOR; | |
} | |
/** | |
* Checks if the first ID is an ancestor of or equal to the second ID. | |
* | |
* @param {string} ancestorID | |
* @param {string} descendantID | |
* @return {boolean} True if `ancestorID` is an ancestor of `descendantID`. | |
* @internal | |
*/ | |
function isAncestorIDOf(ancestorID, descendantID) { | |
return descendantID.indexOf(ancestorID) === 0 && isBoundary(descendantID, ancestorID.length); | |
} | |
/** | |
* Gets the parent ID of the supplied React DOM ID, `id`. | |
* | |
* @param {string} id ID of a component. | |
* @return {string} ID of the parent, or an empty string. | |
* @private | |
*/ | |
function getParentID(id) { | |
return id ? id.substr(0, id.lastIndexOf(SEPARATOR)) : ''; | |
} | |
/** | |
* Gets the next DOM ID on the tree path from the supplied `ancestorID` to the | |
* supplied `destinationID`. If they are equal, the ID is returned. | |
* | |
* @param {string} ancestorID ID of an ancestor node of `destinationID`. | |
* @param {string} destinationID ID of the destination node. | |
* @return {string} Next ID on the path from `ancestorID` to `destinationID`. | |
* @private | |
*/ | |
function getNextDescendantID(ancestorID, destinationID) { | |
!(isValidID(ancestorID) && isValidID(destinationID)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'getNextDescendantID(%s, %s): Received an invalid React DOM ID.', ancestorID, destinationID) : invariant(false) : undefined; | |
!isAncestorIDOf(ancestorID, destinationID) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'getNextDescendantID(...): React has made an invalid assumption about ' + 'the DOM hierarchy. Expected `%s` to be an ancestor of `%s`.', ancestorID, destinationID) : invariant(false) : undefined; | |
if (ancestorID === destinationID) { | |
return ancestorID; | |
} | |
// Skip over the ancestor and the immediate separator. Traverse until we hit | |
// another separator or we reach the end of `destinationID`. | |
var start = ancestorID.length + SEPARATOR_LENGTH; | |
var i; | |
for (i = start; i < destinationID.length; i++) { | |
if (isBoundary(destinationID, i)) { | |
break; | |
} | |
} | |
return destinationID.substr(0, i); | |
} | |
/** | |
* Gets the nearest common ancestor ID of two IDs. | |
* | |
* Using this ID scheme, the nearest common ancestor ID is the longest common | |
* prefix of the two IDs that immediately preceded a "marker" in both strings. | |
* | |
* @param {string} oneID | |
* @param {string} twoID | |
* @return {string} Nearest common ancestor ID, or the empty string if none. | |
* @private | |
*/ | |
function getFirstCommonAncestorID(oneID, twoID) { | |
var minLength = Math.min(oneID.length, twoID.length); | |
if (minLength === 0) { | |
return ''; | |
} | |
var lastCommonMarkerIndex = 0; | |
// Use `<=` to traverse until the "EOL" of the shorter string. | |
for (var i = 0; i <= minLength; i++) { | |
if (isBoundary(oneID, i) && isBoundary(twoID, i)) { | |
lastCommonMarkerIndex = i; | |
} else if (oneID.charAt(i) !== twoID.charAt(i)) { | |
break; | |
} | |
} | |
var longestCommonID = oneID.substr(0, lastCommonMarkerIndex); | |
!isValidID(longestCommonID) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'getFirstCommonAncestorID(%s, %s): Expected a valid React DOM ID: %s', oneID, twoID, longestCommonID) : invariant(false) : undefined; | |
return longestCommonID; | |
} | |
/** | |
* Traverses the parent path between two IDs (either up or down). The IDs must | |
* not be the same, and there must exist a parent path between them. If the | |
* callback returns `false`, traversal is stopped. | |
* | |
* @param {?string} start ID at which to start traversal. | |
* @param {?string} stop ID at which to end traversal. | |
* @param {function} cb Callback to invoke each ID with. | |
* @param {*} arg Argument to invoke the callback with. | |
* @param {?boolean} skipFirst Whether or not to skip the first node. | |
* @param {?boolean} skipLast Whether or not to skip the last node. | |
* @private | |
*/ | |
function traverseParentPath(start, stop, cb, arg, skipFirst, skipLast) { | |
start = start || ''; | |
stop = stop || ''; | |
!(start !== stop) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'traverseParentPath(...): Cannot traverse from and to the same ID, `%s`.', start) : invariant(false) : undefined; | |
var traverseUp = isAncestorIDOf(stop, start); | |
!(traverseUp || isAncestorIDOf(start, stop)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'traverseParentPath(%s, %s, ...): Cannot traverse from two IDs that do ' + 'not have a parent path.', start, stop) : invariant(false) : undefined; | |
// Traverse from `start` to `stop` one depth at a time. | |
var depth = 0; | |
var traverse = traverseUp ? getParentID : getNextDescendantID; | |
for (var id = start;; /* until break */id = traverse(id, stop)) { | |
var ret; | |
if ((!skipFirst || id !== start) && (!skipLast || id !== stop)) { | |
ret = cb(id, traverseUp, arg); | |
} | |
if (ret === false || id === stop) { | |
// Only break //after// visiting `stop`. | |
break; | |
} | |
!(depth++ < MAX_TREE_DEPTH) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'traverseParentPath(%s, %s, ...): Detected an infinite loop while ' + 'traversing the React DOM ID tree. This may be due to malformed IDs: %s', start, stop, id) : invariant(false) : undefined; | |
} | |
} | |
/** | |
* Manages the IDs assigned to DOM representations of React components. This | |
* uses a specific scheme in order to traverse the DOM efficiently (e.g. in | |
* order to simulate events). | |
* | |
* @internal | |
*/ | |
var ReactInstanceHandles = { | |
/** | |
* Constructs a React root ID | |
* @return {string} A React root ID. | |
*/ | |
createReactRootID: function () { | |
return getReactRootIDString(ReactRootIndex.createReactRootIndex()); | |
}, | |
/** | |
* Constructs a React ID by joining a root ID with a name. | |
* | |
* @param {string} rootID Root ID of a parent component. | |
* @param {string} name A component's name (as flattened children). | |
* @return {string} A React ID. | |
* @internal | |
*/ | |
createReactID: function (rootID, name) { | |
return rootID + name; | |
}, | |
/** | |
* Gets the DOM ID of the React component that is the root of the tree that | |
* contains the React component with the supplied DOM ID. | |
* | |
* @param {string} id DOM ID of a React component. | |
* @return {?string} DOM ID of the React component that is the root. | |
* @internal | |
*/ | |
getReactRootIDFromNodeID: function (id) { | |
if (id && id.charAt(0) === SEPARATOR && id.length > 1) { | |
var index = id.indexOf(SEPARATOR, 1); | |
return index > -1 ? id.substr(0, index) : id; | |
} | |
return null; | |
}, | |
/** | |
* Traverses the ID hierarchy and invokes the supplied `cb` on any IDs that | |
* should would receive a `mouseEnter` or `mouseLeave` event. | |
* | |
* NOTE: Does not invoke the callback on the nearest common ancestor because | |
* nothing "entered" or "left" that element. | |
* | |
* @param {string} leaveID ID being left. | |
* @param {string} enterID ID being entered. | |
* @param {function} cb Callback to invoke on each entered/left ID. | |
* @param {*} upArg Argument to invoke the callback with on left IDs. | |
* @param {*} downArg Argument to invoke the callback with on entered IDs. | |
* @internal | |
*/ | |
traverseEnterLeave: function (leaveID, enterID, cb, upArg, downArg) { | |
var ancestorID = getFirstCommonAncestorID(leaveID, enterID); | |
if (ancestorID !== leaveID) { | |
traverseParentPath(leaveID, ancestorID, cb, upArg, false, true); | |
} | |
if (ancestorID !== enterID) { | |
traverseParentPath(ancestorID, enterID, cb, downArg, true, false); | |
} | |
}, | |
/** | |
* Simulates the traversal of a two-phase, capture/bubble event dispatch. | |
* | |
* NOTE: This traversal happens on IDs without touching the DOM. | |
* | |
* @param {string} targetID ID of the target node. | |
* @param {function} cb Callback to invoke. | |
* @param {*} arg Argument to invoke the callback with. | |
* @internal | |
*/ | |
traverseTwoPhase: function (targetID, cb, arg) { | |
if (targetID) { | |
traverseParentPath('', targetID, cb, arg, true, false); | |
traverseParentPath(targetID, '', cb, arg, false, true); | |
} | |
}, | |
/** | |
* Same as `traverseTwoPhase` but skips the `targetID`. | |
*/ | |
traverseTwoPhaseSkipTarget: function (targetID, cb, arg) { | |
if (targetID) { | |
traverseParentPath('', targetID, cb, arg, true, true); | |
traverseParentPath(targetID, '', cb, arg, true, true); | |
} | |
}, | |
/** | |
* Traverse a node ID, calling the supplied `cb` for each ancestor ID. For | |
* example, passing `.0.$row-0.1` would result in `cb` getting called | |
* with `.0`, `.0.$row-0`, and `.0.$row-0.1`. | |
* | |
* NOTE: This traversal happens on IDs without touching the DOM. | |
* | |
* @param {string} targetID ID of the target node. | |
* @param {function} cb Callback to invoke. | |
* @param {*} arg Argument to invoke the callback with. | |
* @internal | |
*/ | |
traverseAncestors: function (targetID, cb, arg) { | |
traverseParentPath('', targetID, cb, arg, true, false); | |
}, | |
getFirstCommonAncestorID: getFirstCommonAncestorID, | |
/** | |
* Exposed for unit testing. | |
* @private | |
*/ | |
_getNextDescendantID: getNextDescendantID, | |
isAncestorIDOf: isAncestorIDOf, | |
SEPARATOR: SEPARATOR | |
}; | |
module.exports = ReactInstanceHandles; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 103 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactRootIndex | |
* @typechecks | |
*/ | |
'use strict'; | |
var ReactRootIndexInjection = { | |
/** | |
* @param {function} _createReactRootIndex | |
*/ | |
injectCreateReactRootIndex: function (_createReactRootIndex) { | |
ReactRootIndex.createReactRootIndex = _createReactRootIndex; | |
} | |
}; | |
var ReactRootIndex = { | |
createReactRootIndex: null, | |
injection: ReactRootIndexInjection | |
}; | |
module.exports = ReactRootIndex; | |
/***/ }, | |
/* 104 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactInstanceMap | |
*/ | |
'use strict'; | |
/** | |
* `ReactInstanceMap` maintains a mapping from a public facing stateful | |
* instance (key) and the internal representation (value). This allows public | |
* methods to accept the user facing instance as an argument and map them back | |
* to internal methods. | |
*/ | |
// TODO: Replace this with ES6: var ReactInstanceMap = new Map(); | |
var ReactInstanceMap = { | |
/** | |
* This API should be called `delete` but we'd have to make sure to always | |
* transform these to strings for IE support. When this transform is fully | |
* supported we can rename it. | |
*/ | |
remove: function (key) { | |
key._reactInternalInstance = undefined; | |
}, | |
get: function (key) { | |
return key._reactInternalInstance; | |
}, | |
has: function (key) { | |
return key._reactInternalInstance !== undefined; | |
}, | |
set: function (key, value) { | |
key._reactInternalInstance = value; | |
} | |
}; | |
module.exports = ReactInstanceMap; | |
/***/ }, | |
/* 105 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactMarkupChecksum | |
*/ | |
'use strict'; | |
var adler32 = __webpack_require__(106); | |
var TAG_END = /\/?>/; | |
var ReactMarkupChecksum = { | |
CHECKSUM_ATTR_NAME: 'data-react-checksum', | |
/** | |
* @param {string} markup Markup string | |
* @return {string} Markup string with checksum attribute attached | |
*/ | |
addChecksumToMarkup: function (markup) { | |
var checksum = adler32(markup); | |
// Add checksum (handle both parent tags and self-closing tags) | |
return markup.replace(TAG_END, ' ' + ReactMarkupChecksum.CHECKSUM_ATTR_NAME + '="' + checksum + '"$&'); | |
}, | |
/** | |
* @param {string} markup to use | |
* @param {DOMElement} element root React element | |
* @returns {boolean} whether or not the markup is the same | |
*/ | |
canReuseMarkup: function (markup, element) { | |
var existingChecksum = element.getAttribute(ReactMarkupChecksum.CHECKSUM_ATTR_NAME); | |
existingChecksum = existingChecksum && parseInt(existingChecksum, 10); | |
var markupChecksum = adler32(markup); | |
return markupChecksum === existingChecksum; | |
} | |
}; | |
module.exports = ReactMarkupChecksum; | |
/***/ }, | |
/* 106 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule adler32 | |
*/ | |
'use strict'; | |
var MOD = 65521; | |
// adler32 is not cryptographically strong, and is only used to sanity check that | |
// markup generated on the server matches the markup generated on the client. | |
// This implementation (a modified version of the SheetJS version) has been optimized | |
// for our use case, at the expense of conforming to the adler32 specification | |
// for non-ascii inputs. | |
function adler32(data) { | |
var a = 1; | |
var b = 0; | |
var i = 0; | |
var l = data.length; | |
var m = l & ~0x3; | |
while (i < m) { | |
for (; i < Math.min(i + 4096, m); i += 4) { | |
b += (a += data.charCodeAt(i)) + (a += data.charCodeAt(i + 1)) + (a += data.charCodeAt(i + 2)) + (a += data.charCodeAt(i + 3)); | |
} | |
a %= MOD; | |
b %= MOD; | |
} | |
for (; i < l; i++) { | |
b += a += data.charCodeAt(i); | |
} | |
a %= MOD; | |
b %= MOD; | |
return a | b << 16; | |
} | |
module.exports = adler32; | |
/***/ }, | |
/* 107 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactReconciler | |
*/ | |
'use strict'; | |
var ReactRef = __webpack_require__(108); | |
/** | |
* Helper to call ReactRef.attachRefs with this composite component, split out | |
* to avoid allocations in the transaction mount-ready queue. | |
*/ | |
function attachRefs() { | |
ReactRef.attachRefs(this, this._currentElement); | |
} | |
var ReactReconciler = { | |
/** | |
* Initializes the component, renders markup, and registers event listeners. | |
* | |
* @param {ReactComponent} internalInstance | |
* @param {string} rootID DOM ID of the root node. | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @return {?string} Rendered markup to be inserted into the DOM. | |
* @final | |
* @internal | |
*/ | |
mountComponent: function (internalInstance, rootID, transaction, context) { | |
var markup = internalInstance.mountComponent(rootID, transaction, context); | |
if (internalInstance._currentElement && internalInstance._currentElement.ref != null) { | |
transaction.getReactMountReady().enqueue(attachRefs, internalInstance); | |
} | |
return markup; | |
}, | |
/** | |
* Releases any resources allocated by `mountComponent`. | |
* | |
* @final | |
* @internal | |
*/ | |
unmountComponent: function (internalInstance) { | |
ReactRef.detachRefs(internalInstance, internalInstance._currentElement); | |
internalInstance.unmountComponent(); | |
}, | |
/** | |
* Update a component using a new element. | |
* | |
* @param {ReactComponent} internalInstance | |
* @param {ReactElement} nextElement | |
* @param {ReactReconcileTransaction} transaction | |
* @param {object} context | |
* @internal | |
*/ | |
receiveComponent: function (internalInstance, nextElement, transaction, context) { | |
var prevElement = internalInstance._currentElement; | |
if (nextElement === prevElement && context === internalInstance._context) { | |
// Since elements are immutable after the owner is rendered, | |
// we can do a cheap identity compare here to determine if this is a | |
// superfluous reconcile. It's possible for state to be mutable but such | |
// change should trigger an update of the owner which would recreate | |
// the element. We explicitly check for the existence of an owner since | |
// it's possible for an element created outside a composite to be | |
// deeply mutated and reused. | |
// TODO: Bailing out early is just a perf optimization right? | |
// TODO: Removing the return statement should affect correctness? | |
return; | |
} | |
var refsChanged = ReactRef.shouldUpdateRefs(prevElement, nextElement); | |
if (refsChanged) { | |
ReactRef.detachRefs(internalInstance, prevElement); | |
} | |
internalInstance.receiveComponent(nextElement, transaction, context); | |
if (refsChanged && internalInstance._currentElement && internalInstance._currentElement.ref != null) { | |
transaction.getReactMountReady().enqueue(attachRefs, internalInstance); | |
} | |
}, | |
/** | |
* Flush any dirty changes in a component. | |
* | |
* @param {ReactComponent} internalInstance | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
*/ | |
performUpdateIfNecessary: function (internalInstance, transaction) { | |
internalInstance.performUpdateIfNecessary(transaction); | |
} | |
}; | |
module.exports = ReactReconciler; | |
/***/ }, | |
/* 108 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactRef | |
*/ | |
'use strict'; | |
var ReactOwner = __webpack_require__(109); | |
var ReactRef = {}; | |
function attachRef(ref, component, owner) { | |
if (typeof ref === 'function') { | |
ref(component.getPublicInstance()); | |
} else { | |
// Legacy ref | |
ReactOwner.addComponentAsRefTo(component, ref, owner); | |
} | |
} | |
function detachRef(ref, component, owner) { | |
if (typeof ref === 'function') { | |
ref(null); | |
} else { | |
// Legacy ref | |
ReactOwner.removeComponentAsRefFrom(component, ref, owner); | |
} | |
} | |
ReactRef.attachRefs = function (instance, element) { | |
if (element === null || element === false) { | |
return; | |
} | |
var ref = element.ref; | |
if (ref != null) { | |
attachRef(ref, instance, element._owner); | |
} | |
}; | |
ReactRef.shouldUpdateRefs = function (prevElement, nextElement) { | |
// If either the owner or a `ref` has changed, make sure the newest owner | |
// has stored a reference to `this`, and the previous owner (if different) | |
// has forgotten the reference to `this`. We use the element instead | |
// of the public this.props because the post processing cannot determine | |
// a ref. The ref conceptually lives on the element. | |
// TODO: Should this even be possible? The owner cannot change because | |
// it's forbidden by shouldUpdateReactComponent. The ref can change | |
// if you swap the keys of but not the refs. Reconsider where this check | |
// is made. It probably belongs where the key checking and | |
// instantiateReactComponent is done. | |
var prevEmpty = prevElement === null || prevElement === false; | |
var nextEmpty = nextElement === null || nextElement === false; | |
return( | |
// This has a few false positives w/r/t empty components. | |
prevEmpty || nextEmpty || nextElement._owner !== prevElement._owner || nextElement.ref !== prevElement.ref | |
); | |
}; | |
ReactRef.detachRefs = function (instance, element) { | |
if (element === null || element === false) { | |
return; | |
} | |
var ref = element.ref; | |
if (ref != null) { | |
detachRef(ref, instance, element._owner); | |
} | |
}; | |
module.exports = ReactRef; | |
/***/ }, | |
/* 109 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactOwner | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* ReactOwners are capable of storing references to owned components. | |
* | |
* All components are capable of //being// referenced by owner components, but | |
* only ReactOwner components are capable of //referencing// owned components. | |
* The named reference is known as a "ref". | |
* | |
* Refs are available when mounted and updated during reconciliation. | |
* | |
* var MyComponent = React.createClass({ | |
* render: function() { | |
* return ( | |
* <div onClick={this.handleClick}> | |
* <CustomComponent ref="custom" /> | |
* </div> | |
* ); | |
* }, | |
* handleClick: function() { | |
* this.refs.custom.handleClick(); | |
* }, | |
* componentDidMount: function() { | |
* this.refs.custom.initialize(); | |
* } | |
* }); | |
* | |
* Refs should rarely be used. When refs are used, they should only be done to | |
* control data that is not handled by React's data flow. | |
* | |
* @class ReactOwner | |
*/ | |
var ReactOwner = { | |
/** | |
* @param {?object} object | |
* @return {boolean} True if `object` is a valid owner. | |
* @final | |
*/ | |
isValidOwner: function (object) { | |
return !!(object && typeof object.attachRef === 'function' && typeof object.detachRef === 'function'); | |
}, | |
/** | |
* Adds a component by ref to an owner component. | |
* | |
* @param {ReactComponent} component Component to reference. | |
* @param {string} ref Name by which to refer to the component. | |
* @param {ReactOwner} owner Component on which to record the ref. | |
* @final | |
* @internal | |
*/ | |
addComponentAsRefTo: function (component, ref, owner) { | |
!ReactOwner.isValidOwner(owner) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'addComponentAsRefTo(...): Only a ReactOwner can have refs. You might ' + 'be adding a ref to a component that was not created inside a component\'s ' + '`render` method, or you have multiple copies of React loaded ' + '(details: https://fb.me/react-refs-must-have-owner).') : invariant(false) : undefined; | |
owner.attachRef(ref, component); | |
}, | |
/** | |
* Removes a component by ref from an owner component. | |
* | |
* @param {ReactComponent} component Component to dereference. | |
* @param {string} ref Name of the ref to remove. | |
* @param {ReactOwner} owner Component on which the ref is recorded. | |
* @final | |
* @internal | |
*/ | |
removeComponentAsRefFrom: function (component, ref, owner) { | |
!ReactOwner.isValidOwner(owner) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'removeComponentAsRefFrom(...): Only a ReactOwner can have refs. You might ' + 'be removing a ref to a component that was not created inside a component\'s ' + '`render` method, or you have multiple copies of React loaded ' + '(details: https://fb.me/react-refs-must-have-owner).') : invariant(false) : undefined; | |
// Check that `component` is still the current ref because we do not want to | |
// detach the ref if another component stole it. | |
if (owner.getPublicInstance().refs[ref] === component.getPublicInstance()) { | |
owner.detachRef(ref); | |
} | |
} | |
}; | |
module.exports = ReactOwner; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 110 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactUpdateQueue | |
*/ | |
'use strict'; | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactElement = __webpack_require__(99); | |
var ReactInstanceMap = __webpack_require__(104); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
function enqueueUpdate(internalInstance) { | |
ReactUpdates.enqueueUpdate(internalInstance); | |
} | |
function getInternalInstanceReadyForUpdate(publicInstance, callerName) { | |
var internalInstance = ReactInstanceMap.get(publicInstance); | |
if (!internalInstance) { | |
if (process.env.NODE_ENV !== 'production') { | |
// Only warn when we have a callerName. Otherwise we should be silent. | |
// We're probably calling from enqueueCallback. We don't want to warn | |
// there because we already warned for the corresponding lifecycle method. | |
process.env.NODE_ENV !== 'production' ? warning(!callerName, '%s(...): Can only update a mounted or mounting component. ' + 'This usually means you called %s() on an unmounted component. ' + 'This is a no-op. Please check the code for the %s component.', callerName, callerName, publicInstance.constructor.displayName) : undefined; | |
} | |
return null; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(ReactCurrentOwner.current == null, '%s(...): Cannot update during an existing state transition ' + '(such as within `render`). Render methods should be a pure function ' + 'of props and state.', callerName) : undefined; | |
} | |
return internalInstance; | |
} | |
/** | |
* ReactUpdateQueue allows for state updates to be scheduled into a later | |
* reconciliation step. | |
*/ | |
var ReactUpdateQueue = { | |
/** | |
* Checks whether or not this composite component is mounted. | |
* @param {ReactClass} publicInstance The instance we want to test. | |
* @return {boolean} True if mounted, false otherwise. | |
* @protected | |
* @final | |
*/ | |
isMounted: function (publicInstance) { | |
if (process.env.NODE_ENV !== 'production') { | |
var owner = ReactCurrentOwner.current; | |
if (owner !== null) { | |
process.env.NODE_ENV !== 'production' ? warning(owner._warnedAboutRefsInRender, '%s is accessing isMounted inside its render() function. ' + 'render() should be a pure function of props and state. It should ' + 'never access something that requires stale data from the previous ' + 'render, such as refs. Move this logic to componentDidMount and ' + 'componentDidUpdate instead.', owner.getName() || 'A component') : undefined; | |
owner._warnedAboutRefsInRender = true; | |
} | |
} | |
var internalInstance = ReactInstanceMap.get(publicInstance); | |
if (internalInstance) { | |
// During componentWillMount and render this will still be null but after | |
// that will always render to something. At least for now. So we can use | |
// this hack. | |
return !!internalInstance._renderedComponent; | |
} else { | |
return false; | |
} | |
}, | |
/** | |
* Enqueue a callback that will be executed after all the pending updates | |
* have processed. | |
* | |
* @param {ReactClass} publicInstance The instance to use as `this` context. | |
* @param {?function} callback Called after state is updated. | |
* @internal | |
*/ | |
enqueueCallback: function (publicInstance, callback) { | |
!(typeof callback === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'enqueueCallback(...): You called `setProps`, `replaceProps`, ' + '`setState`, `replaceState`, or `forceUpdate` with a callback that ' + 'isn\'t callable.') : invariant(false) : undefined; | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance); | |
// Previously we would throw an error if we didn't have an internal | |
// instance. Since we want to make it a no-op instead, we mirror the same | |
// behavior we have in other enqueue* methods. | |
// We also need to ignore callbacks in componentWillMount. See | |
// enqueueUpdates. | |
if (!internalInstance) { | |
return null; | |
} | |
if (internalInstance._pendingCallbacks) { | |
internalInstance._pendingCallbacks.push(callback); | |
} else { | |
internalInstance._pendingCallbacks = [callback]; | |
} | |
// TODO: The callback here is ignored when setState is called from | |
// componentWillMount. Either fix it or disallow doing so completely in | |
// favor of getInitialState. Alternatively, we can disallow | |
// componentWillMount during server-side rendering. | |
enqueueUpdate(internalInstance); | |
}, | |
enqueueCallbackInternal: function (internalInstance, callback) { | |
!(typeof callback === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'enqueueCallback(...): You called `setProps`, `replaceProps`, ' + '`setState`, `replaceState`, or `forceUpdate` with a callback that ' + 'isn\'t callable.') : invariant(false) : undefined; | |
if (internalInstance._pendingCallbacks) { | |
internalInstance._pendingCallbacks.push(callback); | |
} else { | |
internalInstance._pendingCallbacks = [callback]; | |
} | |
enqueueUpdate(internalInstance); | |
}, | |
/** | |
* Forces an update. This should only be invoked when it is known with | |
* certainty that we are **not** in a DOM transaction. | |
* | |
* You may want to call this when you know that some deeper aspect of the | |
* component's state has changed but `setState` was not called. | |
* | |
* This will not invoke `shouldComponentUpdate`, but it will invoke | |
* `componentWillUpdate` and `componentDidUpdate`. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @internal | |
*/ | |
enqueueForceUpdate: function (publicInstance) { | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance, 'forceUpdate'); | |
if (!internalInstance) { | |
return; | |
} | |
internalInstance._pendingForceUpdate = true; | |
enqueueUpdate(internalInstance); | |
}, | |
/** | |
* Replaces all of the state. Always use this or `setState` to mutate state. | |
* You should treat `this.state` as immutable. | |
* | |
* There is no guarantee that `this.state` will be immediately updated, so | |
* accessing `this.state` after calling this method may return the old value. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} completeState Next state. | |
* @internal | |
*/ | |
enqueueReplaceState: function (publicInstance, completeState) { | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance, 'replaceState'); | |
if (!internalInstance) { | |
return; | |
} | |
internalInstance._pendingStateQueue = [completeState]; | |
internalInstance._pendingReplaceState = true; | |
enqueueUpdate(internalInstance); | |
}, | |
/** | |
* Sets a subset of the state. This only exists because _pendingState is | |
* internal. This provides a merging strategy that is not available to deep | |
* properties which is confusing. TODO: Expose pendingState or don't use it | |
* during the merge. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} partialState Next partial state to be merged with state. | |
* @internal | |
*/ | |
enqueueSetState: function (publicInstance, partialState) { | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance, 'setState'); | |
if (!internalInstance) { | |
return; | |
} | |
var queue = internalInstance._pendingStateQueue || (internalInstance._pendingStateQueue = []); | |
queue.push(partialState); | |
enqueueUpdate(internalInstance); | |
}, | |
/** | |
* Sets a subset of the props. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} partialProps Subset of the next props. | |
* @internal | |
*/ | |
enqueueSetProps: function (publicInstance, partialProps) { | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance, 'setProps'); | |
if (!internalInstance) { | |
return; | |
} | |
ReactUpdateQueue.enqueueSetPropsInternal(internalInstance, partialProps); | |
}, | |
enqueueSetPropsInternal: function (internalInstance, partialProps) { | |
var topLevelWrapper = internalInstance._topLevelWrapper; | |
!topLevelWrapper ? process.env.NODE_ENV !== 'production' ? invariant(false, 'setProps(...): You called `setProps` on a ' + 'component with a parent. This is an anti-pattern since props will ' + 'get reactively updated when rendered. Instead, change the owner\'s ' + '`render` method to pass the correct value as props to the component ' + 'where it is created.') : invariant(false) : undefined; | |
// Merge with the pending element if it exists, otherwise with existing | |
// element props. | |
var wrapElement = topLevelWrapper._pendingElement || topLevelWrapper._currentElement; | |
var element = wrapElement.props; | |
var props = assign({}, element.props, partialProps); | |
topLevelWrapper._pendingElement = ReactElement.cloneAndReplaceProps(wrapElement, ReactElement.cloneAndReplaceProps(element, props)); | |
enqueueUpdate(topLevelWrapper); | |
}, | |
/** | |
* Replaces all of the props. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} props New props. | |
* @internal | |
*/ | |
enqueueReplaceProps: function (publicInstance, props) { | |
var internalInstance = getInternalInstanceReadyForUpdate(publicInstance, 'replaceProps'); | |
if (!internalInstance) { | |
return; | |
} | |
ReactUpdateQueue.enqueueReplacePropsInternal(internalInstance, props); | |
}, | |
enqueueReplacePropsInternal: function (internalInstance, props) { | |
var topLevelWrapper = internalInstance._topLevelWrapper; | |
!topLevelWrapper ? process.env.NODE_ENV !== 'production' ? invariant(false, 'replaceProps(...): You called `replaceProps` on a ' + 'component with a parent. This is an anti-pattern since props will ' + 'get reactively updated when rendered. Instead, change the owner\'s ' + '`render` method to pass the correct value as props to the component ' + 'where it is created.') : invariant(false) : undefined; | |
// Merge with the pending element if it exists, otherwise with existing | |
// element props. | |
var wrapElement = topLevelWrapper._pendingElement || topLevelWrapper._currentElement; | |
var element = wrapElement.props; | |
topLevelWrapper._pendingElement = ReactElement.cloneAndReplaceProps(wrapElement, ReactElement.cloneAndReplaceProps(element, props)); | |
enqueueUpdate(topLevelWrapper); | |
}, | |
enqueueElementInternal: function (internalInstance, newElement) { | |
internalInstance._pendingElement = newElement; | |
enqueueUpdate(internalInstance); | |
} | |
}; | |
module.exports = ReactUpdateQueue; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 111 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactUpdates | |
*/ | |
'use strict'; | |
var CallbackQueue = __webpack_require__(112); | |
var PooledClass = __webpack_require__(113); | |
var ReactPerf = __webpack_require__(76); | |
var ReactReconciler = __webpack_require__(107); | |
var Transaction = __webpack_require__(114); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var dirtyComponents = []; | |
var asapCallbackQueue = CallbackQueue.getPooled(); | |
var asapEnqueued = false; | |
var batchingStrategy = null; | |
function ensureInjected() { | |
!(ReactUpdates.ReactReconcileTransaction && batchingStrategy) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates: must inject a reconcile transaction class and batching ' + 'strategy') : invariant(false) : undefined; | |
} | |
var NESTED_UPDATES = { | |
initialize: function () { | |
this.dirtyComponentsLength = dirtyComponents.length; | |
}, | |
close: function () { | |
if (this.dirtyComponentsLength !== dirtyComponents.length) { | |
// Additional updates were enqueued by componentDidUpdate handlers or | |
// similar; before our own UPDATE_QUEUEING wrapper closes, we want to run | |
// these new updates so that if A's componentDidUpdate calls setState on | |
// B, B will update before the callback A's updater provided when calling | |
// setState. | |
dirtyComponents.splice(0, this.dirtyComponentsLength); | |
flushBatchedUpdates(); | |
} else { | |
dirtyComponents.length = 0; | |
} | |
} | |
}; | |
var UPDATE_QUEUEING = { | |
initialize: function () { | |
this.callbackQueue.reset(); | |
}, | |
close: function () { | |
this.callbackQueue.notifyAll(); | |
} | |
}; | |
var TRANSACTION_WRAPPERS = [NESTED_UPDATES, UPDATE_QUEUEING]; | |
function ReactUpdatesFlushTransaction() { | |
this.reinitializeTransaction(); | |
this.dirtyComponentsLength = null; | |
this.callbackQueue = CallbackQueue.getPooled(); | |
this.reconcileTransaction = ReactUpdates.ReactReconcileTransaction.getPooled( /* forceHTML */false); | |
} | |
assign(ReactUpdatesFlushTransaction.prototype, Transaction.Mixin, { | |
getTransactionWrappers: function () { | |
return TRANSACTION_WRAPPERS; | |
}, | |
destructor: function () { | |
this.dirtyComponentsLength = null; | |
CallbackQueue.release(this.callbackQueue); | |
this.callbackQueue = null; | |
ReactUpdates.ReactReconcileTransaction.release(this.reconcileTransaction); | |
this.reconcileTransaction = null; | |
}, | |
perform: function (method, scope, a) { | |
// Essentially calls `this.reconcileTransaction.perform(method, scope, a)` | |
// with this transaction's wrappers around it. | |
return Transaction.Mixin.perform.call(this, this.reconcileTransaction.perform, this.reconcileTransaction, method, scope, a); | |
} | |
}); | |
PooledClass.addPoolingTo(ReactUpdatesFlushTransaction); | |
function batchedUpdates(callback, a, b, c, d, e) { | |
ensureInjected(); | |
batchingStrategy.batchedUpdates(callback, a, b, c, d, e); | |
} | |
/** | |
* Array comparator for ReactComponents by mount ordering. | |
* | |
* @param {ReactComponent} c1 first component you're comparing | |
* @param {ReactComponent} c2 second component you're comparing | |
* @return {number} Return value usable by Array.prototype.sort(). | |
*/ | |
function mountOrderComparator(c1, c2) { | |
return c1._mountOrder - c2._mountOrder; | |
} | |
function runBatchedUpdates(transaction) { | |
var len = transaction.dirtyComponentsLength; | |
!(len === dirtyComponents.length) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Expected flush transaction\'s stored dirty-components length (%s) to ' + 'match dirty-components array length (%s).', len, dirtyComponents.length) : invariant(false) : undefined; | |
// Since reconciling a component higher in the owner hierarchy usually (not | |
// always -- see shouldComponentUpdate()) will reconcile children, reconcile | |
// them before their children by sorting the array. | |
dirtyComponents.sort(mountOrderComparator); | |
for (var i = 0; i < len; i++) { | |
// If a component is unmounted before pending changes apply, it will still | |
// be here, but we assume that it has cleared its _pendingCallbacks and | |
// that performUpdateIfNecessary is a noop. | |
var component = dirtyComponents[i]; | |
// If performUpdateIfNecessary happens to enqueue any new updates, we | |
// shouldn't execute the callbacks until the next render happens, so | |
// stash the callbacks first | |
var callbacks = component._pendingCallbacks; | |
component._pendingCallbacks = null; | |
ReactReconciler.performUpdateIfNecessary(component, transaction.reconcileTransaction); | |
if (callbacks) { | |
for (var j = 0; j < callbacks.length; j++) { | |
transaction.callbackQueue.enqueue(callbacks[j], component.getPublicInstance()); | |
} | |
} | |
} | |
} | |
var flushBatchedUpdates = function () { | |
// ReactUpdatesFlushTransaction's wrappers will clear the dirtyComponents | |
// array and perform any updates enqueued by mount-ready handlers (i.e., | |
// componentDidUpdate) but we need to check here too in order to catch | |
// updates enqueued by setState callbacks and asap calls. | |
while (dirtyComponents.length || asapEnqueued) { | |
if (dirtyComponents.length) { | |
var transaction = ReactUpdatesFlushTransaction.getPooled(); | |
transaction.perform(runBatchedUpdates, null, transaction); | |
ReactUpdatesFlushTransaction.release(transaction); | |
} | |
if (asapEnqueued) { | |
asapEnqueued = false; | |
var queue = asapCallbackQueue; | |
asapCallbackQueue = CallbackQueue.getPooled(); | |
queue.notifyAll(); | |
CallbackQueue.release(queue); | |
} | |
} | |
}; | |
flushBatchedUpdates = ReactPerf.measure('ReactUpdates', 'flushBatchedUpdates', flushBatchedUpdates); | |
/** | |
* Mark a component as needing a rerender, adding an optional callback to a | |
* list of functions which will be executed once the rerender occurs. | |
*/ | |
function enqueueUpdate(component) { | |
ensureInjected(); | |
// Various parts of our code (such as ReactCompositeComponent's | |
// _renderValidatedComponent) assume that calls to render aren't nested; | |
// verify that that's the case. (This is called by each top-level update | |
// function, like setProps, setState, forceUpdate, etc.; creation and | |
// destruction of top-level components is guarded in ReactMount.) | |
if (!batchingStrategy.isBatchingUpdates) { | |
batchingStrategy.batchedUpdates(enqueueUpdate, component); | |
return; | |
} | |
dirtyComponents.push(component); | |
} | |
/** | |
* Enqueue a callback to be run at the end of the current batching cycle. Throws | |
* if no updates are currently being performed. | |
*/ | |
function asap(callback, context) { | |
!batchingStrategy.isBatchingUpdates ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates.asap: Can\'t enqueue an asap callback in a context where' + 'updates are not being batched.') : invariant(false) : undefined; | |
asapCallbackQueue.enqueue(callback, context); | |
asapEnqueued = true; | |
} | |
var ReactUpdatesInjection = { | |
injectReconcileTransaction: function (ReconcileTransaction) { | |
!ReconcileTransaction ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates: must provide a reconcile transaction class') : invariant(false) : undefined; | |
ReactUpdates.ReactReconcileTransaction = ReconcileTransaction; | |
}, | |
injectBatchingStrategy: function (_batchingStrategy) { | |
!_batchingStrategy ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates: must provide a batching strategy') : invariant(false) : undefined; | |
!(typeof _batchingStrategy.batchedUpdates === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates: must provide a batchedUpdates() function') : invariant(false) : undefined; | |
!(typeof _batchingStrategy.isBatchingUpdates === 'boolean') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactUpdates: must provide an isBatchingUpdates boolean attribute') : invariant(false) : undefined; | |
batchingStrategy = _batchingStrategy; | |
} | |
}; | |
var ReactUpdates = { | |
/** | |
* React references `ReactReconcileTransaction` using this property in order | |
* to allow dependency injection. | |
* | |
* @internal | |
*/ | |
ReactReconcileTransaction: null, | |
batchedUpdates: batchedUpdates, | |
enqueueUpdate: enqueueUpdate, | |
flushBatchedUpdates: flushBatchedUpdates, | |
injection: ReactUpdatesInjection, | |
asap: asap | |
}; | |
module.exports = ReactUpdates; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 112 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule CallbackQueue | |
*/ | |
'use strict'; | |
var PooledClass = __webpack_require__(113); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
/** | |
* A specialized pseudo-event module to help keep track of components waiting to | |
* be notified when their DOM representations are available for use. | |
* | |
* This implements `PooledClass`, so you should never need to instantiate this. | |
* Instead, use `CallbackQueue.getPooled()`. | |
* | |
* @class ReactMountReady | |
* @implements PooledClass | |
* @internal | |
*/ | |
function CallbackQueue() { | |
this._callbacks = null; | |
this._contexts = null; | |
} | |
assign(CallbackQueue.prototype, { | |
/** | |
* Enqueues a callback to be invoked when `notifyAll` is invoked. | |
* | |
* @param {function} callback Invoked when `notifyAll` is invoked. | |
* @param {?object} context Context to call `callback` with. | |
* @internal | |
*/ | |
enqueue: function (callback, context) { | |
this._callbacks = this._callbacks || []; | |
this._contexts = this._contexts || []; | |
this._callbacks.push(callback); | |
this._contexts.push(context); | |
}, | |
/** | |
* Invokes all enqueued callbacks and clears the queue. This is invoked after | |
* the DOM representation of a component has been created or updated. | |
* | |
* @internal | |
*/ | |
notifyAll: function () { | |
var callbacks = this._callbacks; | |
var contexts = this._contexts; | |
if (callbacks) { | |
!(callbacks.length === contexts.length) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Mismatched list of contexts in callback queue') : invariant(false) : undefined; | |
this._callbacks = null; | |
this._contexts = null; | |
for (var i = 0; i < callbacks.length; i++) { | |
callbacks[i].call(contexts[i]); | |
} | |
callbacks.length = 0; | |
contexts.length = 0; | |
} | |
}, | |
/** | |
* Resets the internal queue. | |
* | |
* @internal | |
*/ | |
reset: function () { | |
this._callbacks = null; | |
this._contexts = null; | |
}, | |
/** | |
* `PooledClass` looks for this. | |
*/ | |
destructor: function () { | |
this.reset(); | |
} | |
}); | |
PooledClass.addPoolingTo(CallbackQueue); | |
module.exports = CallbackQueue; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 113 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule PooledClass | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* Static poolers. Several custom versions for each potential number of | |
* arguments. A completely generic pooler is easy to implement, but would | |
* require accessing the `arguments` object. In each of these, `this` refers to | |
* the Class itself, not an instance. If any others are needed, simply add them | |
* here, or in their own files. | |
*/ | |
var oneArgumentPooler = function (copyFieldsFrom) { | |
var Klass = this; | |
if (Klass.instancePool.length) { | |
var instance = Klass.instancePool.pop(); | |
Klass.call(instance, copyFieldsFrom); | |
return instance; | |
} else { | |
return new Klass(copyFieldsFrom); | |
} | |
}; | |
var twoArgumentPooler = function (a1, a2) { | |
var Klass = this; | |
if (Klass.instancePool.length) { | |
var instance = Klass.instancePool.pop(); | |
Klass.call(instance, a1, a2); | |
return instance; | |
} else { | |
return new Klass(a1, a2); | |
} | |
}; | |
var threeArgumentPooler = function (a1, a2, a3) { | |
var Klass = this; | |
if (Klass.instancePool.length) { | |
var instance = Klass.instancePool.pop(); | |
Klass.call(instance, a1, a2, a3); | |
return instance; | |
} else { | |
return new Klass(a1, a2, a3); | |
} | |
}; | |
var fourArgumentPooler = function (a1, a2, a3, a4) { | |
var Klass = this; | |
if (Klass.instancePool.length) { | |
var instance = Klass.instancePool.pop(); | |
Klass.call(instance, a1, a2, a3, a4); | |
return instance; | |
} else { | |
return new Klass(a1, a2, a3, a4); | |
} | |
}; | |
var fiveArgumentPooler = function (a1, a2, a3, a4, a5) { | |
var Klass = this; | |
if (Klass.instancePool.length) { | |
var instance = Klass.instancePool.pop(); | |
Klass.call(instance, a1, a2, a3, a4, a5); | |
return instance; | |
} else { | |
return new Klass(a1, a2, a3, a4, a5); | |
} | |
}; | |
var standardReleaser = function (instance) { | |
var Klass = this; | |
!(instance instanceof Klass) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Trying to release an instance into a pool of a different type.') : invariant(false) : undefined; | |
instance.destructor(); | |
if (Klass.instancePool.length < Klass.poolSize) { | |
Klass.instancePool.push(instance); | |
} | |
}; | |
var DEFAULT_POOL_SIZE = 10; | |
var DEFAULT_POOLER = oneArgumentPooler; | |
/** | |
* Augments `CopyConstructor` to be a poolable class, augmenting only the class | |
* itself (statically) not adding any prototypical fields. Any CopyConstructor | |
* you give this may have a `poolSize` property, and will look for a | |
* prototypical `destructor` on instances (optional). | |
* | |
* @param {Function} CopyConstructor Constructor that can be used to reset. | |
* @param {Function} pooler Customizable pooler. | |
*/ | |
var addPoolingTo = function (CopyConstructor, pooler) { | |
var NewKlass = CopyConstructor; | |
NewKlass.instancePool = []; | |
NewKlass.getPooled = pooler || DEFAULT_POOLER; | |
if (!NewKlass.poolSize) { | |
NewKlass.poolSize = DEFAULT_POOL_SIZE; | |
} | |
NewKlass.release = standardReleaser; | |
return NewKlass; | |
}; | |
var PooledClass = { | |
addPoolingTo: addPoolingTo, | |
oneArgumentPooler: oneArgumentPooler, | |
twoArgumentPooler: twoArgumentPooler, | |
threeArgumentPooler: threeArgumentPooler, | |
fourArgumentPooler: fourArgumentPooler, | |
fiveArgumentPooler: fiveArgumentPooler | |
}; | |
module.exports = PooledClass; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 114 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule Transaction | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
/** | |
* `Transaction` creates a black box that is able to wrap any method such that | |
* certain invariants are maintained before and after the method is invoked | |
* (Even if an exception is thrown while invoking the wrapped method). Whoever | |
* instantiates a transaction can provide enforcers of the invariants at | |
* creation time. The `Transaction` class itself will supply one additional | |
* automatic invariant for you - the invariant that any transaction instance | |
* should not be run while it is already being run. You would typically create a | |
* single instance of a `Transaction` for reuse multiple times, that potentially | |
* is used to wrap several different methods. Wrappers are extremely simple - | |
* they only require implementing two methods. | |
* | |
* <pre> | |
* wrappers (injected at creation time) | |
* + + | |
* | | | |
* +-----------------|--------|--------------+ | |
* | v | | | |
* | +---------------+ | | | |
* | +--| wrapper1 |---|----+ | | |
* | | +---------------+ v | | | |
* | | +-------------+ | | | |
* | | +----| wrapper2 |--------+ | | |
* | | | +-------------+ | | | | |
* | | | | | | | |
* | v v v v | wrapper | |
* | +---+ +---+ +---------+ +---+ +---+ | invariants | |
* perform(anyMethod) | | | | | | | | | | | | maintained | |
* +----------------->|-|---|-|---|-->|anyMethod|---|---|-|---|-|--------> | |
* | | | | | | | | | | | | | |
* | | | | | | | | | | | | | |
* | | | | | | | | | | | | | |
* | +---+ +---+ +---------+ +---+ +---+ | | |
* | initialize close | | |
* +-----------------------------------------+ | |
* </pre> | |
* | |
* Use cases: | |
* - Preserving the input selection ranges before/after reconciliation. | |
* Restoring selection even in the event of an unexpected error. | |
* - Deactivating events while rearranging the DOM, preventing blurs/focuses, | |
* while guaranteeing that afterwards, the event system is reactivated. | |
* - Flushing a queue of collected DOM mutations to the main UI thread after a | |
* reconciliation takes place in a worker thread. | |
* - Invoking any collected `componentDidUpdate` callbacks after rendering new | |
* content. | |
* - (Future use case): Wrapping particular flushes of the `ReactWorker` queue | |
* to preserve the `scrollTop` (an automatic scroll aware DOM). | |
* - (Future use case): Layout calculations before and after DOM updates. | |
* | |
* Transactional plugin API: | |
* - A module that has an `initialize` method that returns any precomputation. | |
* - and a `close` method that accepts the precomputation. `close` is invoked | |
* when the wrapped process is completed, or has failed. | |
* | |
* @param {Array<TransactionalWrapper>} transactionWrapper Wrapper modules | |
* that implement `initialize` and `close`. | |
* @return {Transaction} Single transaction for reuse in thread. | |
* | |
* @class Transaction | |
*/ | |
var Mixin = { | |
/** | |
* Sets up this instance so that it is prepared for collecting metrics. Does | |
* so such that this setup method may be used on an instance that is already | |
* initialized, in a way that does not consume additional memory upon reuse. | |
* That can be useful if you decide to make your subclass of this mixin a | |
* "PooledClass". | |
*/ | |
reinitializeTransaction: function () { | |
this.transactionWrappers = this.getTransactionWrappers(); | |
if (this.wrapperInitData) { | |
this.wrapperInitData.length = 0; | |
} else { | |
this.wrapperInitData = []; | |
} | |
this._isInTransaction = false; | |
}, | |
_isInTransaction: false, | |
/** | |
* @abstract | |
* @return {Array<TransactionWrapper>} Array of transaction wrappers. | |
*/ | |
getTransactionWrappers: null, | |
isInTransaction: function () { | |
return !!this._isInTransaction; | |
}, | |
/** | |
* Executes the function within a safety window. Use this for the top level | |
* methods that result in large amounts of computation/mutations that would | |
* need to be safety checked. The optional arguments helps prevent the need | |
* to bind in many cases. | |
* | |
* @param {function} method Member of scope to call. | |
* @param {Object} scope Scope to invoke from. | |
* @param {Object?=} a Argument to pass to the method. | |
* @param {Object?=} b Argument to pass to the method. | |
* @param {Object?=} c Argument to pass to the method. | |
* @param {Object?=} d Argument to pass to the method. | |
* @param {Object?=} e Argument to pass to the method. | |
* @param {Object?=} f Argument to pass to the method. | |
* | |
* @return {*} Return value from `method`. | |
*/ | |
perform: function (method, scope, a, b, c, d, e, f) { | |
!!this.isInTransaction() ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Transaction.perform(...): Cannot initialize a transaction when there ' + 'is already an outstanding transaction.') : invariant(false) : undefined; | |
var errorThrown; | |
var ret; | |
try { | |
this._isInTransaction = true; | |
// Catching errors makes debugging more difficult, so we start with | |
// errorThrown set to true before setting it to false after calling | |
// close -- if it's still set to true in the finally block, it means | |
// one of these calls threw. | |
errorThrown = true; | |
this.initializeAll(0); | |
ret = method.call(scope, a, b, c, d, e, f); | |
errorThrown = false; | |
} finally { | |
try { | |
if (errorThrown) { | |
// If `method` throws, prefer to show that stack trace over any thrown | |
// by invoking `closeAll`. | |
try { | |
this.closeAll(0); | |
} catch (err) {} | |
} else { | |
// Since `method` didn't throw, we don't want to silence the exception | |
// here. | |
this.closeAll(0); | |
} | |
} finally { | |
this._isInTransaction = false; | |
} | |
} | |
return ret; | |
}, | |
initializeAll: function (startIndex) { | |
var transactionWrappers = this.transactionWrappers; | |
for (var i = startIndex; i < transactionWrappers.length; i++) { | |
var wrapper = transactionWrappers[i]; | |
try { | |
// Catching errors makes debugging more difficult, so we start with the | |
// OBSERVED_ERROR state before overwriting it with the real return value | |
// of initialize -- if it's still set to OBSERVED_ERROR in the finally | |
// block, it means wrapper.initialize threw. | |
this.wrapperInitData[i] = Transaction.OBSERVED_ERROR; | |
this.wrapperInitData[i] = wrapper.initialize ? wrapper.initialize.call(this) : null; | |
} finally { | |
if (this.wrapperInitData[i] === Transaction.OBSERVED_ERROR) { | |
// The initializer for wrapper i threw an error; initialize the | |
// remaining wrappers but silence any exceptions from them to ensure | |
// that the first error is the one to bubble up. | |
try { | |
this.initializeAll(i + 1); | |
} catch (err) {} | |
} | |
} | |
} | |
}, | |
/** | |
* Invokes each of `this.transactionWrappers.close[i]` functions, passing into | |
* them the respective return values of `this.transactionWrappers.init[i]` | |
* (`close`rs that correspond to initializers that failed will not be | |
* invoked). | |
*/ | |
closeAll: function (startIndex) { | |
!this.isInTransaction() ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Transaction.closeAll(): Cannot close transaction when none are open.') : invariant(false) : undefined; | |
var transactionWrappers = this.transactionWrappers; | |
for (var i = startIndex; i < transactionWrappers.length; i++) { | |
var wrapper = transactionWrappers[i]; | |
var initData = this.wrapperInitData[i]; | |
var errorThrown; | |
try { | |
// Catching errors makes debugging more difficult, so we start with | |
// errorThrown set to true before setting it to false after calling | |
// close -- if it's still set to true in the finally block, it means | |
// wrapper.close threw. | |
errorThrown = true; | |
if (initData !== Transaction.OBSERVED_ERROR && wrapper.close) { | |
wrapper.close.call(this, initData); | |
} | |
errorThrown = false; | |
} finally { | |
if (errorThrown) { | |
// The closer for wrapper i threw an error; close the remaining | |
// wrappers but silence any exceptions from them to ensure that the | |
// first error is the one to bubble up. | |
try { | |
this.closeAll(i + 1); | |
} catch (e) {} | |
} | |
} | |
} | |
this.wrapperInitData.length = 0; | |
} | |
}; | |
var Transaction = { | |
Mixin: Mixin, | |
/** | |
* Token to look for to determine if an error occurred. | |
*/ | |
OBSERVED_ERROR: {} | |
}; | |
module.exports = Transaction; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 115 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule emptyObject | |
*/ | |
'use strict'; | |
var emptyObject = {}; | |
if (process.env.NODE_ENV !== 'production') { | |
Object.freeze(emptyObject); | |
} | |
module.exports = emptyObject; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 116 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule containsNode | |
* @typechecks | |
*/ | |
'use strict'; | |
var isTextNode = __webpack_require__(117); | |
/*eslint-disable no-bitwise */ | |
/** | |
* Checks if a given DOM node contains or is another DOM node. | |
* | |
* @param {?DOMNode} outerNode Outer DOM node. | |
* @param {?DOMNode} innerNode Inner DOM node. | |
* @return {boolean} True if `outerNode` contains or is `innerNode`. | |
*/ | |
function containsNode(_x, _x2) { | |
var _again = true; | |
_function: while (_again) { | |
var outerNode = _x, | |
innerNode = _x2; | |
_again = false; | |
if (!outerNode || !innerNode) { | |
return false; | |
} else if (outerNode === innerNode) { | |
return true; | |
} else if (isTextNode(outerNode)) { | |
return false; | |
} else if (isTextNode(innerNode)) { | |
_x = outerNode; | |
_x2 = innerNode.parentNode; | |
_again = true; | |
continue _function; | |
} else if (outerNode.contains) { | |
return outerNode.contains(innerNode); | |
} else if (outerNode.compareDocumentPosition) { | |
return !!(outerNode.compareDocumentPosition(innerNode) & 16); | |
} else { | |
return false; | |
} | |
} | |
} | |
module.exports = containsNode; | |
/***/ }, | |
/* 117 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule isTextNode | |
* @typechecks | |
*/ | |
'use strict'; | |
var isNode = __webpack_require__(118); | |
/** | |
* @param {*} object The object to check. | |
* @return {boolean} Whether or not the object is a DOM text node. | |
*/ | |
function isTextNode(object) { | |
return isNode(object) && object.nodeType == 3; | |
} | |
module.exports = isTextNode; | |
/***/ }, | |
/* 118 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule isNode | |
* @typechecks | |
*/ | |
/** | |
* @param {*} object The object to check. | |
* @return {boolean} Whether or not the object is a DOM node. | |
*/ | |
'use strict'; | |
function isNode(object) { | |
return !!(object && (typeof Node === 'function' ? object instanceof Node : typeof object === 'object' && typeof object.nodeType === 'number' && typeof object.nodeName === 'string')); | |
} | |
module.exports = isNode; | |
/***/ }, | |
/* 119 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule instantiateReactComponent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactCompositeComponent = __webpack_require__(120); | |
var ReactEmptyComponent = __webpack_require__(125); | |
var ReactNativeComponent = __webpack_require__(126); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
// To avoid a cyclic dependency, we create the final class in this module | |
var ReactCompositeComponentWrapper = function () {}; | |
assign(ReactCompositeComponentWrapper.prototype, ReactCompositeComponent.Mixin, { | |
_instantiateReactComponent: instantiateReactComponent | |
}); | |
function getDeclarationErrorAddendum(owner) { | |
if (owner) { | |
var name = owner.getName(); | |
if (name) { | |
return ' Check the render method of `' + name + '`.'; | |
} | |
} | |
return ''; | |
} | |
/** | |
* Check if the type reference is a known internal type. I.e. not a user | |
* provided composite type. | |
* | |
* @param {function} type | |
* @return {boolean} Returns true if this is a valid internal type. | |
*/ | |
function isInternalComponentType(type) { | |
return typeof type === 'function' && typeof type.prototype !== 'undefined' && typeof type.prototype.mountComponent === 'function' && typeof type.prototype.receiveComponent === 'function'; | |
} | |
/** | |
* Given a ReactNode, create an instance that will actually be mounted. | |
* | |
* @param {ReactNode} node | |
* @return {object} A new instance of the element's constructor. | |
* @protected | |
*/ | |
function instantiateReactComponent(node) { | |
var instance; | |
if (node === null || node === false) { | |
instance = new ReactEmptyComponent(instantiateReactComponent); | |
} else if (typeof node === 'object') { | |
var element = node; | |
!(element && (typeof element.type === 'function' || typeof element.type === 'string')) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Element type is invalid: expected a string (for built-in components) ' + 'or a class/function (for composite components) but got: %s.%s', element.type == null ? element.type : typeof element.type, getDeclarationErrorAddendum(element._owner)) : invariant(false) : undefined; | |
// Special case string values | |
if (typeof element.type === 'string') { | |
instance = ReactNativeComponent.createInternalComponent(element); | |
} else if (isInternalComponentType(element.type)) { | |
// This is temporarily available for custom components that are not string | |
// representations. I.e. ART. Once those are updated to use the string | |
// representation, we can drop this code path. | |
instance = new element.type(element); | |
} else { | |
instance = new ReactCompositeComponentWrapper(); | |
} | |
} else if (typeof node === 'string' || typeof node === 'number') { | |
instance = ReactNativeComponent.createInstanceForText(node); | |
} else { | |
true ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Encountered invalid React node of type %s', typeof node) : invariant(false) : undefined; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(typeof instance.construct === 'function' && typeof instance.mountComponent === 'function' && typeof instance.receiveComponent === 'function' && typeof instance.unmountComponent === 'function', 'Only React Components can be mounted.') : undefined; | |
} | |
// Sets up the instance. This can probably just move into the constructor now. | |
instance.construct(node); | |
// These two fields are used by the DOM and ART diffing algorithms | |
// respectively. Instead of using expandos on components, we should be | |
// storing the state needed by the diffing algorithms elsewhere. | |
instance._mountIndex = 0; | |
instance._mountImage = null; | |
if (process.env.NODE_ENV !== 'production') { | |
instance._isOwnerNecessary = false; | |
instance._warnedAboutRefsInRender = false; | |
} | |
// Internal instances should fully constructed at this point, so they should | |
// not get any new fields added to them at this point. | |
if (process.env.NODE_ENV !== 'production') { | |
if (Object.preventExtensions) { | |
Object.preventExtensions(instance); | |
} | |
} | |
return instance; | |
} | |
module.exports = instantiateReactComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 120 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactCompositeComponent | |
*/ | |
'use strict'; | |
var ReactComponentEnvironment = __webpack_require__(121); | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactElement = __webpack_require__(99); | |
var ReactInstanceMap = __webpack_require__(104); | |
var ReactPerf = __webpack_require__(76); | |
var ReactPropTypeLocations = __webpack_require__(122); | |
var ReactPropTypeLocationNames = __webpack_require__(123); | |
var ReactReconciler = __webpack_require__(107); | |
var ReactUpdateQueue = __webpack_require__(110); | |
var assign = __webpack_require__(29); | |
var emptyObject = __webpack_require__(115); | |
var invariant = __webpack_require__(31); | |
var shouldUpdateReactComponent = __webpack_require__(124); | |
var warning = __webpack_require__(83); | |
function getDeclarationErrorAddendum(component) { | |
var owner = component._currentElement._owner || null; | |
if (owner) { | |
var name = owner.getName(); | |
if (name) { | |
return ' Check the render method of `' + name + '`.'; | |
} | |
} | |
return ''; | |
} | |
function StatelessComponent(Component) {} | |
StatelessComponent.prototype.render = function () { | |
var Component = ReactInstanceMap.get(this)._currentElement.type; | |
return Component(this.props, this.context, this.updater); | |
}; | |
/** | |
* ------------------ The Life-Cycle of a Composite Component ------------------ | |
* | |
* - constructor: Initialization of state. The instance is now retained. | |
* - componentWillMount | |
* - render | |
* - [children's constructors] | |
* - [children's componentWillMount and render] | |
* - [children's componentDidMount] | |
* - componentDidMount | |
* | |
* Update Phases: | |
* - componentWillReceiveProps (only called if parent updated) | |
* - shouldComponentUpdate | |
* - componentWillUpdate | |
* - render | |
* - [children's constructors or receive props phases] | |
* - componentDidUpdate | |
* | |
* - componentWillUnmount | |
* - [children's componentWillUnmount] | |
* - [children destroyed] | |
* - (destroyed): The instance is now blank, released by React and ready for GC. | |
* | |
* ----------------------------------------------------------------------------- | |
*/ | |
/** | |
* An incrementing ID assigned to each component when it is mounted. This is | |
* used to enforce the order in which `ReactUpdates` updates dirty components. | |
* | |
* @private | |
*/ | |
var nextMountID = 1; | |
/** | |
* @lends {ReactCompositeComponent.prototype} | |
*/ | |
var ReactCompositeComponentMixin = { | |
/** | |
* Base constructor for all composite component. | |
* | |
* @param {ReactElement} element | |
* @final | |
* @internal | |
*/ | |
construct: function (element) { | |
this._currentElement = element; | |
this._rootNodeID = null; | |
this._instance = null; | |
// See ReactUpdateQueue | |
this._pendingElement = null; | |
this._pendingStateQueue = null; | |
this._pendingReplaceState = false; | |
this._pendingForceUpdate = false; | |
this._renderedComponent = null; | |
this._context = null; | |
this._mountOrder = 0; | |
this._topLevelWrapper = null; | |
// See ReactUpdates and ReactUpdateQueue. | |
this._pendingCallbacks = null; | |
}, | |
/** | |
* Initializes the component, renders markup, and registers event listeners. | |
* | |
* @param {string} rootID DOM ID of the root node. | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @return {?string} Rendered markup to be inserted into the DOM. | |
* @final | |
* @internal | |
*/ | |
mountComponent: function (rootID, transaction, context) { | |
this._context = context; | |
this._mountOrder = nextMountID++; | |
this._rootNodeID = rootID; | |
var publicProps = this._processProps(this._currentElement.props); | |
var publicContext = this._processContext(context); | |
var Component = this._currentElement.type; | |
// Initialize the public class | |
var inst; | |
var renderedElement; | |
// This is a way to detect if Component is a stateless arrow function | |
// component, which is not newable. It might not be 100% reliable but is | |
// something we can do until we start detecting that Component extends | |
// React.Component. We already assume that typeof Component === 'function'. | |
var canInstantiate = ('prototype' in Component); | |
if (canInstantiate) { | |
if (process.env.NODE_ENV !== 'production') { | |
ReactCurrentOwner.current = this; | |
try { | |
inst = new Component(publicProps, publicContext, ReactUpdateQueue); | |
} finally { | |
ReactCurrentOwner.current = null; | |
} | |
} else { | |
inst = new Component(publicProps, publicContext, ReactUpdateQueue); | |
} | |
} | |
if (!canInstantiate || inst === null || inst === false || ReactElement.isValidElement(inst)) { | |
renderedElement = inst; | |
inst = new StatelessComponent(Component); | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
// This will throw later in _renderValidatedComponent, but add an early | |
// warning now to help debugging | |
if (inst.render == null) { | |
process.env.NODE_ENV !== 'production' ? warning(false, '%s(...): No `render` method found on the returned component ' + 'instance: you may have forgotten to define `render`, returned ' + 'null/false from a stateless component, or tried to render an ' + 'element whose type is a function that isn\'t a React component.', Component.displayName || Component.name || 'Component') : undefined; | |
} else { | |
// We support ES6 inheriting from React.Component, the module pattern, | |
// and stateless components, but not ES6 classes that don't extend | |
process.env.NODE_ENV !== 'production' ? warning(Component.prototype && Component.prototype.isReactComponent || !canInstantiate || !(inst instanceof Component), '%s(...): React component classes must extend React.Component.', Component.displayName || Component.name || 'Component') : undefined; | |
} | |
} | |
// These should be set up in the constructor, but as a convenience for | |
// simpler class abstractions, we set them up after the fact. | |
inst.props = publicProps; | |
inst.context = publicContext; | |
inst.refs = emptyObject; | |
inst.updater = ReactUpdateQueue; | |
this._instance = inst; | |
// Store a reference from the instance back to the internal representation | |
ReactInstanceMap.set(inst, this); | |
if (process.env.NODE_ENV !== 'production') { | |
// Since plain JS classes are defined without any special initialization | |
// logic, we can not catch common errors early. Therefore, we have to | |
// catch them here, at initialization time, instead. | |
process.env.NODE_ENV !== 'production' ? warning(!inst.getInitialState || inst.getInitialState.isReactClassApproved, 'getInitialState was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Did you mean to define a state property instead?', this.getName() || 'a component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!inst.getDefaultProps || inst.getDefaultProps.isReactClassApproved, 'getDefaultProps was defined on %s, a plain JavaScript class. ' + 'This is only supported for classes created using React.createClass. ' + 'Use a static property to define defaultProps instead.', this.getName() || 'a component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!inst.propTypes, 'propTypes was defined as an instance property on %s. Use a static ' + 'property to define propTypes instead.', this.getName() || 'a component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!inst.contextTypes, 'contextTypes was defined as an instance property on %s. Use a ' + 'static property to define contextTypes instead.', this.getName() || 'a component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentShouldUpdate !== 'function', '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', this.getName() || 'A component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentDidUnmount !== 'function', '%s has a method called ' + 'componentDidUnmount(). But there is no such lifecycle method. ' + 'Did you mean componentWillUnmount()?', this.getName() || 'A component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(typeof inst.componentWillRecieveProps !== 'function', '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', this.getName() || 'A component') : undefined; | |
} | |
var initialState = inst.state; | |
if (initialState === undefined) { | |
inst.state = initialState = null; | |
} | |
!(typeof initialState === 'object' && !Array.isArray(initialState)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.state: must be set to an object or null', this.getName() || 'ReactCompositeComponent') : invariant(false) : undefined; | |
this._pendingStateQueue = null; | |
this._pendingReplaceState = false; | |
this._pendingForceUpdate = false; | |
if (inst.componentWillMount) { | |
inst.componentWillMount(); | |
// When mounting, calls to `setState` by `componentWillMount` will set | |
// `this._pendingStateQueue` without triggering a re-render. | |
if (this._pendingStateQueue) { | |
inst.state = this._processPendingState(inst.props, inst.context); | |
} | |
} | |
// If not a stateless component, we now render | |
if (renderedElement === undefined) { | |
renderedElement = this._renderValidatedComponent(); | |
} | |
this._renderedComponent = this._instantiateReactComponent(renderedElement); | |
var markup = ReactReconciler.mountComponent(this._renderedComponent, rootID, transaction, this._processChildContext(context)); | |
if (inst.componentDidMount) { | |
transaction.getReactMountReady().enqueue(inst.componentDidMount, inst); | |
} | |
return markup; | |
}, | |
/** | |
* Releases any resources allocated by `mountComponent`. | |
* | |
* @final | |
* @internal | |
*/ | |
unmountComponent: function () { | |
var inst = this._instance; | |
if (inst.componentWillUnmount) { | |
inst.componentWillUnmount(); | |
} | |
ReactReconciler.unmountComponent(this._renderedComponent); | |
this._renderedComponent = null; | |
this._instance = null; | |
// Reset pending fields | |
// Even if this component is scheduled for another update in ReactUpdates, | |
// it would still be ignored because these fields are reset. | |
this._pendingStateQueue = null; | |
this._pendingReplaceState = false; | |
this._pendingForceUpdate = false; | |
this._pendingCallbacks = null; | |
this._pendingElement = null; | |
// These fields do not really need to be reset since this object is no | |
// longer accessible. | |
this._context = null; | |
this._rootNodeID = null; | |
this._topLevelWrapper = null; | |
// Delete the reference from the instance to this internal representation | |
// which allow the internals to be properly cleaned up even if the user | |
// leaks a reference to the public instance. | |
ReactInstanceMap.remove(inst); | |
// Some existing components rely on inst.props even after they've been | |
// destroyed (in event handlers). | |
// TODO: inst.props = null; | |
// TODO: inst.state = null; | |
// TODO: inst.context = null; | |
}, | |
/** | |
* Filters the context object to only contain keys specified in | |
* `contextTypes` | |
* | |
* @param {object} context | |
* @return {?object} | |
* @private | |
*/ | |
_maskContext: function (context) { | |
var maskedContext = null; | |
var Component = this._currentElement.type; | |
var contextTypes = Component.contextTypes; | |
if (!contextTypes) { | |
return emptyObject; | |
} | |
maskedContext = {}; | |
for (var contextName in contextTypes) { | |
maskedContext[contextName] = context[contextName]; | |
} | |
return maskedContext; | |
}, | |
/** | |
* Filters the context object to only contain keys specified in | |
* `contextTypes`, and asserts that they are valid. | |
* | |
* @param {object} context | |
* @return {?object} | |
* @private | |
*/ | |
_processContext: function (context) { | |
var maskedContext = this._maskContext(context); | |
if (process.env.NODE_ENV !== 'production') { | |
var Component = this._currentElement.type; | |
if (Component.contextTypes) { | |
this._checkPropTypes(Component.contextTypes, maskedContext, ReactPropTypeLocations.context); | |
} | |
} | |
return maskedContext; | |
}, | |
/** | |
* @param {object} currentContext | |
* @return {object} | |
* @private | |
*/ | |
_processChildContext: function (currentContext) { | |
var Component = this._currentElement.type; | |
var inst = this._instance; | |
var childContext = inst.getChildContext && inst.getChildContext(); | |
if (childContext) { | |
!(typeof Component.childContextTypes === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): childContextTypes must be defined in order to ' + 'use getChildContext().', this.getName() || 'ReactCompositeComponent') : invariant(false) : undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
this._checkPropTypes(Component.childContextTypes, childContext, ReactPropTypeLocations.childContext); | |
} | |
for (var name in childContext) { | |
!(name in Component.childContextTypes) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getChildContext(): key "%s" is not defined in childContextTypes.', this.getName() || 'ReactCompositeComponent', name) : invariant(false) : undefined; | |
} | |
return assign({}, currentContext, childContext); | |
} | |
return currentContext; | |
}, | |
/** | |
* Processes props by setting default values for unspecified props and | |
* asserting that the props are valid. Does not mutate its argument; returns | |
* a new props object with defaults merged in. | |
* | |
* @param {object} newProps | |
* @return {object} | |
* @private | |
*/ | |
_processProps: function (newProps) { | |
if (process.env.NODE_ENV !== 'production') { | |
var Component = this._currentElement.type; | |
if (Component.propTypes) { | |
this._checkPropTypes(Component.propTypes, newProps, ReactPropTypeLocations.prop); | |
} | |
} | |
return newProps; | |
}, | |
/** | |
* Assert that the props are valid | |
* | |
* @param {object} propTypes Map of prop name to a ReactPropType | |
* @param {object} props | |
* @param {string} location e.g. "prop", "context", "child context" | |
* @private | |
*/ | |
_checkPropTypes: function (propTypes, props, location) { | |
// TODO: Stop validating prop types here and only use the element | |
// validation. | |
var componentName = this.getName(); | |
for (var propName in propTypes) { | |
if (propTypes.hasOwnProperty(propName)) { | |
var error; | |
try { | |
// This is intentionally an invariant that gets caught. It's the same | |
// behavior as without this statement except with a better message. | |
!(typeof propTypes[propName] === 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s: %s type `%s` is invalid; it must be a function, usually ' + 'from React.PropTypes.', componentName || 'React class', ReactPropTypeLocationNames[location], propName) : invariant(false) : undefined; | |
error = propTypes[propName](props, propName, componentName, location); | |
} catch (ex) { | |
error = ex; | |
} | |
if (error instanceof Error) { | |
// We may want to extend this logic for similar errors in | |
// top-level render calls, so I'm abstracting it away into | |
// a function to minimize refactoring in the future | |
var addendum = getDeclarationErrorAddendum(this); | |
if (location === ReactPropTypeLocations.prop) { | |
// Preface gives us something to blacklist in warning module | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Failed Composite propType: %s%s', error.message, addendum) : undefined; | |
} else { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Failed Context Types: %s%s', error.message, addendum) : undefined; | |
} | |
} | |
} | |
} | |
}, | |
receiveComponent: function (nextElement, transaction, nextContext) { | |
var prevElement = this._currentElement; | |
var prevContext = this._context; | |
this._pendingElement = null; | |
this.updateComponent(transaction, prevElement, nextElement, prevContext, nextContext); | |
}, | |
/** | |
* If any of `_pendingElement`, `_pendingStateQueue`, or `_pendingForceUpdate` | |
* is set, update the component. | |
* | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
*/ | |
performUpdateIfNecessary: function (transaction) { | |
if (this._pendingElement != null) { | |
ReactReconciler.receiveComponent(this, this._pendingElement || this._currentElement, transaction, this._context); | |
} | |
if (this._pendingStateQueue !== null || this._pendingForceUpdate) { | |
this.updateComponent(transaction, this._currentElement, this._currentElement, this._context, this._context); | |
} | |
}, | |
/** | |
* Perform an update to a mounted component. The componentWillReceiveProps and | |
* shouldComponentUpdate methods are called, then (assuming the update isn't | |
* skipped) the remaining update lifecycle methods are called and the DOM | |
* representation is updated. | |
* | |
* By default, this implements React's rendering and reconciliation algorithm. | |
* Sophisticated clients may wish to override this. | |
* | |
* @param {ReactReconcileTransaction} transaction | |
* @param {ReactElement} prevParentElement | |
* @param {ReactElement} nextParentElement | |
* @internal | |
* @overridable | |
*/ | |
updateComponent: function (transaction, prevParentElement, nextParentElement, prevUnmaskedContext, nextUnmaskedContext) { | |
var inst = this._instance; | |
var nextContext = this._context === nextUnmaskedContext ? inst.context : this._processContext(nextUnmaskedContext); | |
var nextProps; | |
// Distinguish between a props update versus a simple state update | |
if (prevParentElement === nextParentElement) { | |
// Skip checking prop types again -- we don't read inst.props to avoid | |
// warning for DOM component props in this upgrade | |
nextProps = nextParentElement.props; | |
} else { | |
nextProps = this._processProps(nextParentElement.props); | |
// An update here will schedule an update but immediately set | |
// _pendingStateQueue which will ensure that any state updates gets | |
// immediately reconciled instead of waiting for the next batch. | |
if (inst.componentWillReceiveProps) { | |
inst.componentWillReceiveProps(nextProps, nextContext); | |
} | |
} | |
var nextState = this._processPendingState(nextProps, nextContext); | |
var shouldUpdate = this._pendingForceUpdate || !inst.shouldComponentUpdate || inst.shouldComponentUpdate(nextProps, nextState, nextContext); | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(typeof shouldUpdate !== 'undefined', '%s.shouldComponentUpdate(): Returned undefined instead of a ' + 'boolean value. Make sure to return true or false.', this.getName() || 'ReactCompositeComponent') : undefined; | |
} | |
if (shouldUpdate) { | |
this._pendingForceUpdate = false; | |
// Will set `this.props`, `this.state` and `this.context`. | |
this._performComponentUpdate(nextParentElement, nextProps, nextState, nextContext, transaction, nextUnmaskedContext); | |
} else { | |
// If it's determined that a component should not update, we still want | |
// to set props and state but we shortcut the rest of the update. | |
this._currentElement = nextParentElement; | |
this._context = nextUnmaskedContext; | |
inst.props = nextProps; | |
inst.state = nextState; | |
inst.context = nextContext; | |
} | |
}, | |
_processPendingState: function (props, context) { | |
var inst = this._instance; | |
var queue = this._pendingStateQueue; | |
var replace = this._pendingReplaceState; | |
this._pendingReplaceState = false; | |
this._pendingStateQueue = null; | |
if (!queue) { | |
return inst.state; | |
} | |
if (replace && queue.length === 1) { | |
return queue[0]; | |
} | |
var nextState = assign({}, replace ? queue[0] : inst.state); | |
for (var i = replace ? 1 : 0; i < queue.length; i++) { | |
var partial = queue[i]; | |
assign(nextState, typeof partial === 'function' ? partial.call(inst, nextState, props, context) : partial); | |
} | |
return nextState; | |
}, | |
/** | |
* Merges new props and state, notifies delegate methods of update and | |
* performs update. | |
* | |
* @param {ReactElement} nextElement Next element | |
* @param {object} nextProps Next public object to set as properties. | |
* @param {?object} nextState Next object to set as state. | |
* @param {?object} nextContext Next public object to set as context. | |
* @param {ReactReconcileTransaction} transaction | |
* @param {?object} unmaskedContext | |
* @private | |
*/ | |
_performComponentUpdate: function (nextElement, nextProps, nextState, nextContext, transaction, unmaskedContext) { | |
var inst = this._instance; | |
var hasComponentDidUpdate = Boolean(inst.componentDidUpdate); | |
var prevProps; | |
var prevState; | |
var prevContext; | |
if (hasComponentDidUpdate) { | |
prevProps = inst.props; | |
prevState = inst.state; | |
prevContext = inst.context; | |
} | |
if (inst.componentWillUpdate) { | |
inst.componentWillUpdate(nextProps, nextState, nextContext); | |
} | |
this._currentElement = nextElement; | |
this._context = unmaskedContext; | |
inst.props = nextProps; | |
inst.state = nextState; | |
inst.context = nextContext; | |
this._updateRenderedComponent(transaction, unmaskedContext); | |
if (hasComponentDidUpdate) { | |
transaction.getReactMountReady().enqueue(inst.componentDidUpdate.bind(inst, prevProps, prevState, prevContext), inst); | |
} | |
}, | |
/** | |
* Call the component's `render` method and update the DOM accordingly. | |
* | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
*/ | |
_updateRenderedComponent: function (transaction, context) { | |
var prevComponentInstance = this._renderedComponent; | |
var prevRenderedElement = prevComponentInstance._currentElement; | |
var nextRenderedElement = this._renderValidatedComponent(); | |
if (shouldUpdateReactComponent(prevRenderedElement, nextRenderedElement)) { | |
ReactReconciler.receiveComponent(prevComponentInstance, nextRenderedElement, transaction, this._processChildContext(context)); | |
} else { | |
// These two IDs are actually the same! But nothing should rely on that. | |
var thisID = this._rootNodeID; | |
var prevComponentID = prevComponentInstance._rootNodeID; | |
ReactReconciler.unmountComponent(prevComponentInstance); | |
this._renderedComponent = this._instantiateReactComponent(nextRenderedElement); | |
var nextMarkup = ReactReconciler.mountComponent(this._renderedComponent, thisID, transaction, this._processChildContext(context)); | |
this._replaceNodeWithMarkupByID(prevComponentID, nextMarkup); | |
} | |
}, | |
/** | |
* @protected | |
*/ | |
_replaceNodeWithMarkupByID: function (prevComponentID, nextMarkup) { | |
ReactComponentEnvironment.replaceNodeWithMarkupByID(prevComponentID, nextMarkup); | |
}, | |
/** | |
* @protected | |
*/ | |
_renderValidatedComponentWithoutOwnerOrContext: function () { | |
var inst = this._instance; | |
var renderedComponent = inst.render(); | |
if (process.env.NODE_ENV !== 'production') { | |
// We allow auto-mocks to proceed as if they're returning null. | |
if (typeof renderedComponent === 'undefined' && inst.render._isMockFunction) { | |
// This is probably bad practice. Consider warning here and | |
// deprecating this convenience. | |
renderedComponent = null; | |
} | |
} | |
return renderedComponent; | |
}, | |
/** | |
* @private | |
*/ | |
_renderValidatedComponent: function () { | |
var renderedComponent; | |
ReactCurrentOwner.current = this; | |
try { | |
renderedComponent = this._renderValidatedComponentWithoutOwnerOrContext(); | |
} finally { | |
ReactCurrentOwner.current = null; | |
} | |
!( | |
// TODO: An `isValidNode` function would probably be more appropriate | |
renderedComponent === null || renderedComponent === false || ReactElement.isValidElement(renderedComponent)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.render(): A valid ReactComponent must be returned. You may have ' + 'returned undefined, an array or some other invalid object.', this.getName() || 'ReactCompositeComponent') : invariant(false) : undefined; | |
return renderedComponent; | |
}, | |
/** | |
* Lazily allocates the refs object and stores `component` as `ref`. | |
* | |
* @param {string} ref Reference name. | |
* @param {component} component Component to store as `ref`. | |
* @final | |
* @private | |
*/ | |
attachRef: function (ref, component) { | |
var inst = this.getPublicInstance(); | |
!(inst != null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Stateless function components cannot have refs.') : invariant(false) : undefined; | |
var publicComponentInstance = component.getPublicInstance(); | |
if (process.env.NODE_ENV !== 'production') { | |
var componentName = component && component.getName ? component.getName() : 'a component'; | |
process.env.NODE_ENV !== 'production' ? warning(publicComponentInstance != null, 'Stateless function components cannot be given refs ' + '(See ref "%s" in %s created by %s). ' + 'Attempts to access this ref will fail.', ref, componentName, this.getName()) : undefined; | |
} | |
var refs = inst.refs === emptyObject ? inst.refs = {} : inst.refs; | |
refs[ref] = publicComponentInstance; | |
}, | |
/** | |
* Detaches a reference name. | |
* | |
* @param {string} ref Name to dereference. | |
* @final | |
* @private | |
*/ | |
detachRef: function (ref) { | |
var refs = this.getPublicInstance().refs; | |
delete refs[ref]; | |
}, | |
/** | |
* Get a text description of the component that can be used to identify it | |
* in error messages. | |
* @return {string} The name or null. | |
* @internal | |
*/ | |
getName: function () { | |
var type = this._currentElement.type; | |
var constructor = this._instance && this._instance.constructor; | |
return type.displayName || constructor && constructor.displayName || type.name || constructor && constructor.name || null; | |
}, | |
/** | |
* Get the publicly accessible representation of this component - i.e. what | |
* is exposed by refs and returned by render. Can be null for stateless | |
* components. | |
* | |
* @return {ReactComponent} the public component instance. | |
* @internal | |
*/ | |
getPublicInstance: function () { | |
var inst = this._instance; | |
if (inst instanceof StatelessComponent) { | |
return null; | |
} | |
return inst; | |
}, | |
// Stub | |
_instantiateReactComponent: null | |
}; | |
ReactPerf.measureMethods(ReactCompositeComponentMixin, 'ReactCompositeComponent', { | |
mountComponent: 'mountComponent', | |
updateComponent: 'updateComponent', | |
_renderValidatedComponent: '_renderValidatedComponent' | |
}); | |
var ReactCompositeComponent = { | |
Mixin: ReactCompositeComponentMixin | |
}; | |
module.exports = ReactCompositeComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 121 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactComponentEnvironment | |
*/ | |
'use strict'; | |
var invariant = __webpack_require__(31); | |
var injected = false; | |
var ReactComponentEnvironment = { | |
/** | |
* Optionally injectable environment dependent cleanup hook. (server vs. | |
* browser etc). Example: A browser system caches DOM nodes based on component | |
* ID and must remove that cache entry when this instance is unmounted. | |
*/ | |
unmountIDFromEnvironment: null, | |
/** | |
* Optionally injectable hook for swapping out mount images in the middle of | |
* the tree. | |
*/ | |
replaceNodeWithMarkupByID: null, | |
/** | |
* Optionally injectable hook for processing a queue of child updates. Will | |
* later move into MultiChildComponents. | |
*/ | |
processChildrenUpdates: null, | |
injection: { | |
injectEnvironment: function (environment) { | |
!!injected ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactCompositeComponent: injectEnvironment() can only be called once.') : invariant(false) : undefined; | |
ReactComponentEnvironment.unmountIDFromEnvironment = environment.unmountIDFromEnvironment; | |
ReactComponentEnvironment.replaceNodeWithMarkupByID = environment.replaceNodeWithMarkupByID; | |
ReactComponentEnvironment.processChildrenUpdates = environment.processChildrenUpdates; | |
injected = true; | |
} | |
} | |
}; | |
module.exports = ReactComponentEnvironment; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 122 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactPropTypeLocations | |
*/ | |
'use strict'; | |
var keyMirror = __webpack_require__(75); | |
var ReactPropTypeLocations = keyMirror({ | |
prop: null, | |
context: null, | |
childContext: null | |
}); | |
module.exports = ReactPropTypeLocations; | |
/***/ }, | |
/* 123 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactPropTypeLocationNames | |
*/ | |
'use strict'; | |
var ReactPropTypeLocationNames = {}; | |
if (process.env.NODE_ENV !== 'production') { | |
ReactPropTypeLocationNames = { | |
prop: 'prop', | |
context: 'context', | |
childContext: 'child context' | |
}; | |
} | |
module.exports = ReactPropTypeLocationNames; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 124 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule shouldUpdateReactComponent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* Given a `prevElement` and `nextElement`, determines if the existing | |
* instance should be updated as opposed to being destroyed or replaced by a new | |
* instance. Both arguments are elements. This ensures that this logic can | |
* operate on stateless trees without any backing instance. | |
* | |
* @param {?object} prevElement | |
* @param {?object} nextElement | |
* @return {boolean} True if the existing instance should be updated. | |
* @protected | |
*/ | |
function shouldUpdateReactComponent(prevElement, nextElement) { | |
var prevEmpty = prevElement === null || prevElement === false; | |
var nextEmpty = nextElement === null || nextElement === false; | |
if (prevEmpty || nextEmpty) { | |
return prevEmpty === nextEmpty; | |
} | |
var prevType = typeof prevElement; | |
var nextType = typeof nextElement; | |
if (prevType === 'string' || prevType === 'number') { | |
return nextType === 'string' || nextType === 'number'; | |
} else { | |
return nextType === 'object' && prevElement.type === nextElement.type && prevElement.key === nextElement.key; | |
} | |
return false; | |
} | |
module.exports = shouldUpdateReactComponent; | |
/***/ }, | |
/* 125 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactEmptyComponent | |
*/ | |
'use strict'; | |
var ReactElement = __webpack_require__(99); | |
var ReactEmptyComponentRegistry = __webpack_require__(101); | |
var ReactReconciler = __webpack_require__(107); | |
var assign = __webpack_require__(29); | |
var placeholderElement; | |
var ReactEmptyComponentInjection = { | |
injectEmptyComponent: function (component) { | |
placeholderElement = ReactElement.createElement(component); | |
} | |
}; | |
var ReactEmptyComponent = function (instantiate) { | |
this._currentElement = null; | |
this._rootNodeID = null; | |
this._renderedComponent = instantiate(placeholderElement); | |
}; | |
assign(ReactEmptyComponent.prototype, { | |
construct: function (element) {}, | |
mountComponent: function (rootID, transaction, context) { | |
ReactEmptyComponentRegistry.registerNullComponentID(rootID); | |
this._rootNodeID = rootID; | |
return ReactReconciler.mountComponent(this._renderedComponent, rootID, transaction, context); | |
}, | |
receiveComponent: function () {}, | |
unmountComponent: function (rootID, transaction, context) { | |
ReactReconciler.unmountComponent(this._renderedComponent); | |
ReactEmptyComponentRegistry.deregisterNullComponentID(this._rootNodeID); | |
this._rootNodeID = null; | |
this._renderedComponent = null; | |
} | |
}); | |
ReactEmptyComponent.injection = ReactEmptyComponentInjection; | |
module.exports = ReactEmptyComponent; | |
/***/ }, | |
/* 126 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactNativeComponent | |
*/ | |
'use strict'; | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var autoGenerateWrapperClass = null; | |
var genericComponentClass = null; | |
// This registry keeps track of wrapper classes around native tags. | |
var tagToComponentClass = {}; | |
var textComponentClass = null; | |
var ReactNativeComponentInjection = { | |
// This accepts a class that receives the tag string. This is a catch all | |
// that can render any kind of tag. | |
injectGenericComponentClass: function (componentClass) { | |
genericComponentClass = componentClass; | |
}, | |
// This accepts a text component class that takes the text string to be | |
// rendered as props. | |
injectTextComponentClass: function (componentClass) { | |
textComponentClass = componentClass; | |
}, | |
// This accepts a keyed object with classes as values. Each key represents a | |
// tag. That particular tag will use this class instead of the generic one. | |
injectComponentClasses: function (componentClasses) { | |
assign(tagToComponentClass, componentClasses); | |
} | |
}; | |
/** | |
* Get a composite component wrapper class for a specific tag. | |
* | |
* @param {ReactElement} element The tag for which to get the class. | |
* @return {function} The React class constructor function. | |
*/ | |
function getComponentClassForElement(element) { | |
if (typeof element.type === 'function') { | |
return element.type; | |
} | |
var tag = element.type; | |
var componentClass = tagToComponentClass[tag]; | |
if (componentClass == null) { | |
tagToComponentClass[tag] = componentClass = autoGenerateWrapperClass(tag); | |
} | |
return componentClass; | |
} | |
/** | |
* Get a native internal component class for a specific tag. | |
* | |
* @param {ReactElement} element The element to create. | |
* @return {function} The internal class constructor function. | |
*/ | |
function createInternalComponent(element) { | |
!genericComponentClass ? process.env.NODE_ENV !== 'production' ? invariant(false, 'There is no registered component for the tag %s', element.type) : invariant(false) : undefined; | |
return new genericComponentClass(element.type, element.props); | |
} | |
/** | |
* @param {ReactText} text | |
* @return {ReactComponent} | |
*/ | |
function createInstanceForText(text) { | |
return new textComponentClass(text); | |
} | |
/** | |
* @param {ReactComponent} component | |
* @return {boolean} | |
*/ | |
function isTextComponent(component) { | |
return component instanceof textComponentClass; | |
} | |
var ReactNativeComponent = { | |
getComponentClassForElement: getComponentClassForElement, | |
createInternalComponent: createInternalComponent, | |
createInstanceForText: createInstanceForText, | |
isTextComponent: isTextComponent, | |
injection: ReactNativeComponentInjection | |
}; | |
module.exports = ReactNativeComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 127 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule validateDOMNesting | |
*/ | |
'use strict'; | |
var assign = __webpack_require__(29); | |
var emptyFunction = __webpack_require__(73); | |
var warning = __webpack_require__(83); | |
var validateDOMNesting = emptyFunction; | |
if (process.env.NODE_ENV !== 'production') { | |
// This validation code was written based on the HTML5 parsing spec: | |
// https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-scope | |
// | |
// Note: this does not catch all invalid nesting, nor does it try to (as it's | |
// not clear what practical benefit doing so provides); instead, we warn only | |
// for cases where the parser will give a parse tree differing from what React | |
// intended. For example, <b><div></div></b> is invalid but we don't warn | |
// because it still parses correctly; we do warn for other cases like nested | |
// <p> tags where the beginning of the second element implicitly closes the | |
// first, causing a confusing mess. | |
// https://html.spec.whatwg.org/multipage/syntax.html#special | |
var specialTags = ['address', 'applet', 'area', 'article', 'aside', 'base', 'basefont', 'bgsound', 'blockquote', 'body', 'br', 'button', 'caption', 'center', 'col', 'colgroup', 'dd', 'details', 'dir', 'div', 'dl', 'dt', 'embed', 'fieldset', 'figcaption', 'figure', 'footer', 'form', 'frame', 'frameset', 'h1', 'h2', 'h3', 'h4', 'h5', 'h6', 'head', 'header', 'hgroup', 'hr', 'html', 'iframe', 'img', 'input', 'isindex', 'li', 'link', 'listing', 'main', 'marquee', 'menu', 'menuitem', 'meta', 'nav', 'noembed', 'noframes', 'noscript', 'object', 'ol', 'p', 'param', 'plaintext', 'pre', 'script', 'section', 'select', 'source', 'style', 'summary', 'table', 'tbody', 'td', 'template', 'textarea', 'tfoot', 'th', 'thead', 'title', 'tr', 'track', 'ul', 'wbr', 'xmp']; | |
// https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-scope | |
var inScopeTags = ['applet', 'caption', 'html', 'table', 'td', 'th', 'marquee', 'object', 'template', | |
// https://html.spec.whatwg.org/multipage/syntax.html#html-integration-point | |
// TODO: Distinguish by namespace here -- for <title>, including it here | |
// errs on the side of fewer warnings | |
'foreignObject', 'desc', 'title']; | |
// https://html.spec.whatwg.org/multipage/syntax.html#has-an-element-in-button-scope | |
var buttonScopeTags = inScopeTags.concat(['button']); | |
// https://html.spec.whatwg.org/multipage/syntax.html#generate-implied-end-tags | |
var impliedEndTags = ['dd', 'dt', 'li', 'option', 'optgroup', 'p', 'rp', 'rt']; | |
var emptyAncestorInfo = { | |
parentTag: null, | |
formTag: null, | |
aTagInScope: null, | |
buttonTagInScope: null, | |
nobrTagInScope: null, | |
pTagInButtonScope: null, | |
listItemTagAutoclosing: null, | |
dlItemTagAutoclosing: null | |
}; | |
var updatedAncestorInfo = function (oldInfo, tag, instance) { | |
var ancestorInfo = assign({}, oldInfo || emptyAncestorInfo); | |
var info = { tag: tag, instance: instance }; | |
if (inScopeTags.indexOf(tag) !== -1) { | |
ancestorInfo.aTagInScope = null; | |
ancestorInfo.buttonTagInScope = null; | |
ancestorInfo.nobrTagInScope = null; | |
} | |
if (buttonScopeTags.indexOf(tag) !== -1) { | |
ancestorInfo.pTagInButtonScope = null; | |
} | |
// See rules for 'li', 'dd', 'dt' start tags in | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inbody | |
if (specialTags.indexOf(tag) !== -1 && tag !== 'address' && tag !== 'div' && tag !== 'p') { | |
ancestorInfo.listItemTagAutoclosing = null; | |
ancestorInfo.dlItemTagAutoclosing = null; | |
} | |
ancestorInfo.parentTag = info; | |
if (tag === 'form') { | |
ancestorInfo.formTag = info; | |
} | |
if (tag === 'a') { | |
ancestorInfo.aTagInScope = info; | |
} | |
if (tag === 'button') { | |
ancestorInfo.buttonTagInScope = info; | |
} | |
if (tag === 'nobr') { | |
ancestorInfo.nobrTagInScope = info; | |
} | |
if (tag === 'p') { | |
ancestorInfo.pTagInButtonScope = info; | |
} | |
if (tag === 'li') { | |
ancestorInfo.listItemTagAutoclosing = info; | |
} | |
if (tag === 'dd' || tag === 'dt') { | |
ancestorInfo.dlItemTagAutoclosing = info; | |
} | |
return ancestorInfo; | |
}; | |
/** | |
* Returns whether | |
*/ | |
var isTagValidWithParent = function (tag, parentTag) { | |
// First, let's check if we're in an unusual parsing mode... | |
switch (parentTag) { | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inselect | |
case 'select': | |
return tag === 'option' || tag === 'optgroup' || tag === '#text'; | |
case 'optgroup': | |
return tag === 'option' || tag === '#text'; | |
// Strictly speaking, seeing an <option> doesn't mean we're in a <select> | |
// but | |
case 'option': | |
return tag === '#text'; | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intd | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-incaption | |
// No special behavior since these rules fall back to "in body" mode for | |
// all except special table nodes which cause bad parsing behavior anyway. | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intr | |
case 'tr': | |
return tag === 'th' || tag === 'td' || tag === 'style' || tag === 'script' || tag === 'template'; | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intbody | |
case 'tbody': | |
case 'thead': | |
case 'tfoot': | |
return tag === 'tr' || tag === 'style' || tag === 'script' || tag === 'template'; | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-incolgroup | |
case 'colgroup': | |
return tag === 'col' || tag === 'template'; | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-intable | |
case 'table': | |
return tag === 'caption' || tag === 'colgroup' || tag === 'tbody' || tag === 'tfoot' || tag === 'thead' || tag === 'style' || tag === 'script' || tag === 'template'; | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inhead | |
case 'head': | |
return tag === 'base' || tag === 'basefont' || tag === 'bgsound' || tag === 'link' || tag === 'meta' || tag === 'title' || tag === 'noscript' || tag === 'noframes' || tag === 'style' || tag === 'script' || tag === 'template'; | |
// https://html.spec.whatwg.org/multipage/semantics.html#the-html-element | |
case 'html': | |
return tag === 'head' || tag === 'body'; | |
} | |
// Probably in the "in body" parsing mode, so we outlaw only tag combos | |
// where the parsing rules cause implicit opens or closes to be added. | |
// https://html.spec.whatwg.org/multipage/syntax.html#parsing-main-inbody | |
switch (tag) { | |
case 'h1': | |
case 'h2': | |
case 'h3': | |
case 'h4': | |
case 'h5': | |
case 'h6': | |
return parentTag !== 'h1' && parentTag !== 'h2' && parentTag !== 'h3' && parentTag !== 'h4' && parentTag !== 'h5' && parentTag !== 'h6'; | |
case 'rp': | |
case 'rt': | |
return impliedEndTags.indexOf(parentTag) === -1; | |
case 'caption': | |
case 'col': | |
case 'colgroup': | |
case 'frame': | |
case 'head': | |
case 'tbody': | |
case 'td': | |
case 'tfoot': | |
case 'th': | |
case 'thead': | |
case 'tr': | |
// These tags are only valid with a few parents that have special child | |
// parsing rules -- if we're down here, then none of those matched and | |
// so we allow it only if we don't know what the parent is, as all other | |
// cases are invalid. | |
return parentTag == null; | |
} | |
return true; | |
}; | |
/** | |
* Returns whether | |
*/ | |
var findInvalidAncestorForTag = function (tag, ancestorInfo) { | |
switch (tag) { | |
case 'address': | |
case 'article': | |
case 'aside': | |
case 'blockquote': | |
case 'center': | |
case 'details': | |
case 'dialog': | |
case 'dir': | |
case 'div': | |
case 'dl': | |
case 'fieldset': | |
case 'figcaption': | |
case 'figure': | |
case 'footer': | |
case 'header': | |
case 'hgroup': | |
case 'main': | |
case 'menu': | |
case 'nav': | |
case 'ol': | |
case 'p': | |
case 'section': | |
case 'summary': | |
case 'ul': | |
case 'pre': | |
case 'listing': | |
case 'table': | |
case 'hr': | |
case 'xmp': | |
case 'h1': | |
case 'h2': | |
case 'h3': | |
case 'h4': | |
case 'h5': | |
case 'h6': | |
return ancestorInfo.pTagInButtonScope; | |
case 'form': | |
return ancestorInfo.formTag || ancestorInfo.pTagInButtonScope; | |
case 'li': | |
return ancestorInfo.listItemTagAutoclosing; | |
case 'dd': | |
case 'dt': | |
return ancestorInfo.dlItemTagAutoclosing; | |
case 'button': | |
return ancestorInfo.buttonTagInScope; | |
case 'a': | |
// Spec says something about storing a list of markers, but it sounds | |
// equivalent to this check. | |
return ancestorInfo.aTagInScope; | |
case 'nobr': | |
return ancestorInfo.nobrTagInScope; | |
} | |
return null; | |
}; | |
/** | |
* Given a ReactCompositeComponent instance, return a list of its recursive | |
* owners, starting at the root and ending with the instance itself. | |
*/ | |
var findOwnerStack = function (instance) { | |
if (!instance) { | |
return []; | |
} | |
var stack = []; | |
/*eslint-disable space-after-keywords */ | |
do { | |
/*eslint-enable space-after-keywords */ | |
stack.push(instance); | |
} while (instance = instance._currentElement._owner); | |
stack.reverse(); | |
return stack; | |
}; | |
var didWarn = {}; | |
validateDOMNesting = function (childTag, childInstance, ancestorInfo) { | |
ancestorInfo = ancestorInfo || emptyAncestorInfo; | |
var parentInfo = ancestorInfo.parentTag; | |
var parentTag = parentInfo && parentInfo.tag; | |
var invalidParent = isTagValidWithParent(childTag, parentTag) ? null : parentInfo; | |
var invalidAncestor = invalidParent ? null : findInvalidAncestorForTag(childTag, ancestorInfo); | |
var problematic = invalidParent || invalidAncestor; | |
if (problematic) { | |
var ancestorTag = problematic.tag; | |
var ancestorInstance = problematic.instance; | |
var childOwner = childInstance && childInstance._currentElement._owner; | |
var ancestorOwner = ancestorInstance && ancestorInstance._currentElement._owner; | |
var childOwners = findOwnerStack(childOwner); | |
var ancestorOwners = findOwnerStack(ancestorOwner); | |
var minStackLen = Math.min(childOwners.length, ancestorOwners.length); | |
var i; | |
var deepestCommon = -1; | |
for (i = 0; i < minStackLen; i++) { | |
if (childOwners[i] === ancestorOwners[i]) { | |
deepestCommon = i; | |
} else { | |
break; | |
} | |
} | |
var UNKNOWN = '(unknown)'; | |
var childOwnerNames = childOwners.slice(deepestCommon + 1).map(function (inst) { | |
return inst.getName() || UNKNOWN; | |
}); | |
var ancestorOwnerNames = ancestorOwners.slice(deepestCommon + 1).map(function (inst) { | |
return inst.getName() || UNKNOWN; | |
}); | |
var ownerInfo = [].concat( | |
// If the parent and child instances have a common owner ancestor, start | |
// with that -- otherwise we just start with the parent's owners. | |
deepestCommon !== -1 ? childOwners[deepestCommon].getName() || UNKNOWN : [], ancestorOwnerNames, ancestorTag, | |
// If we're warning about an invalid (non-parent) ancestry, add '...' | |
invalidAncestor ? ['...'] : [], childOwnerNames, childTag).join(' > '); | |
var warnKey = !!invalidParent + '|' + childTag + '|' + ancestorTag + '|' + ownerInfo; | |
if (didWarn[warnKey]) { | |
return; | |
} | |
didWarn[warnKey] = true; | |
if (invalidParent) { | |
var info = ''; | |
if (ancestorTag === 'table' && childTag === 'tr') { | |
info += ' Add a <tbody> to your code to match the DOM tree generated by ' + 'the browser.'; | |
} | |
process.env.NODE_ENV !== 'production' ? warning(false, 'validateDOMNesting(...): <%s> cannot appear as a child of <%s>. ' + 'See %s.%s', childTag, ancestorTag, ownerInfo, info) : undefined; | |
} else { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'validateDOMNesting(...): <%s> cannot appear as a descendant of ' + '<%s>. See %s.', childTag, ancestorTag, ownerInfo) : undefined; | |
} | |
} | |
}; | |
validateDOMNesting.ancestorInfoContextKey = '__validateDOMNesting_ancestorInfo$' + Math.random().toString(36).slice(2); | |
validateDOMNesting.updatedAncestorInfo = updatedAncestorInfo; | |
// For testing | |
validateDOMNesting.isTagValidInContext = function (tag, ancestorInfo) { | |
ancestorInfo = ancestorInfo || emptyAncestorInfo; | |
var parentInfo = ancestorInfo.parentTag; | |
var parentTag = parentInfo && parentInfo.tag; | |
return isTagValidWithParent(tag, parentTag) && !findInvalidAncestorForTag(tag, ancestorInfo); | |
}; | |
} | |
module.exports = validateDOMNesting; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 128 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDefaultInjection | |
*/ | |
'use strict'; | |
var BeforeInputEventPlugin = __webpack_require__(129); | |
var ChangeEventPlugin = __webpack_require__(136); | |
var ClientReactRootIndex = __webpack_require__(139); | |
var DefaultEventPluginOrder = __webpack_require__(140); | |
var EnterLeaveEventPlugin = __webpack_require__(141); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var HTMLDOMPropertyConfig = __webpack_require__(145); | |
var ReactBrowserComponentMixin = __webpack_require__(146); | |
var ReactComponentBrowserEnvironment = __webpack_require__(84); | |
var ReactDefaultBatchingStrategy = __webpack_require__(148); | |
var ReactDOMComponent = __webpack_require__(149); | |
var ReactDOMTextComponent = __webpack_require__(65); | |
var ReactEventListener = __webpack_require__(174); | |
var ReactInjection = __webpack_require__(177); | |
var ReactInstanceHandles = __webpack_require__(102); | |
var ReactMount = __webpack_require__(86); | |
var ReactReconcileTransaction = __webpack_require__(181); | |
var SelectEventPlugin = __webpack_require__(186); | |
var ServerReactRootIndex = __webpack_require__(187); | |
var SimpleEventPlugin = __webpack_require__(188); | |
var SVGDOMPropertyConfig = __webpack_require__(197); | |
var alreadyInjected = false; | |
function inject() { | |
if (alreadyInjected) { | |
// TODO: This is currently true because these injections are shared between | |
// the client and the server package. They should be built independently | |
// and not share any injection state. Then this problem will be solved. | |
return; | |
} | |
alreadyInjected = true; | |
ReactInjection.EventEmitter.injectReactEventListener(ReactEventListener); | |
/** | |
* Inject modules for resolving DOM hierarchy and plugin ordering. | |
*/ | |
ReactInjection.EventPluginHub.injectEventPluginOrder(DefaultEventPluginOrder); | |
ReactInjection.EventPluginHub.injectInstanceHandle(ReactInstanceHandles); | |
ReactInjection.EventPluginHub.injectMount(ReactMount); | |
/** | |
* Some important event plugins included by default (without having to require | |
* them). | |
*/ | |
ReactInjection.EventPluginHub.injectEventPluginsByName({ | |
SimpleEventPlugin: SimpleEventPlugin, | |
EnterLeaveEventPlugin: EnterLeaveEventPlugin, | |
ChangeEventPlugin: ChangeEventPlugin, | |
SelectEventPlugin: SelectEventPlugin, | |
BeforeInputEventPlugin: BeforeInputEventPlugin | |
}); | |
ReactInjection.NativeComponent.injectGenericComponentClass(ReactDOMComponent); | |
ReactInjection.NativeComponent.injectTextComponentClass(ReactDOMTextComponent); | |
ReactInjection.Class.injectMixin(ReactBrowserComponentMixin); | |
ReactInjection.DOMProperty.injectDOMPropertyConfig(HTMLDOMPropertyConfig); | |
ReactInjection.DOMProperty.injectDOMPropertyConfig(SVGDOMPropertyConfig); | |
ReactInjection.EmptyComponent.injectEmptyComponent('noscript'); | |
ReactInjection.Updates.injectReconcileTransaction(ReactReconcileTransaction); | |
ReactInjection.Updates.injectBatchingStrategy(ReactDefaultBatchingStrategy); | |
ReactInjection.RootIndex.injectCreateReactRootIndex(ExecutionEnvironment.canUseDOM ? ClientReactRootIndex.createReactRootIndex : ServerReactRootIndex.createReactRootIndex); | |
ReactInjection.Component.injectEnvironment(ReactComponentBrowserEnvironment); | |
if (process.env.NODE_ENV !== 'production') { | |
var url = ExecutionEnvironment.canUseDOM && window.location.href || ''; | |
if (/[?&]react_perf/.test(url)) { | |
var ReactDefaultPerf = __webpack_require__(198); | |
ReactDefaultPerf.start(); | |
} | |
} | |
} | |
module.exports = { | |
inject: inject | |
}; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 129 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015 Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule BeforeInputEventPlugin | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPropagators = __webpack_require__(130); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var FallbackCompositionState = __webpack_require__(131); | |
var SyntheticCompositionEvent = __webpack_require__(133); | |
var SyntheticInputEvent = __webpack_require__(135); | |
var keyOf = __webpack_require__(30); | |
var END_KEYCODES = [9, 13, 27, 32]; // Tab, Return, Esc, Space | |
var START_KEYCODE = 229; | |
var canUseCompositionEvent = ExecutionEnvironment.canUseDOM && 'CompositionEvent' in window; | |
var documentMode = null; | |
if (ExecutionEnvironment.canUseDOM && 'documentMode' in document) { | |
documentMode = document.documentMode; | |
} | |
// Webkit offers a very useful `textInput` event that can be used to | |
// directly represent `beforeInput`. The IE `textinput` event is not as | |
// useful, so we don't use it. | |
var canUseTextInputEvent = ExecutionEnvironment.canUseDOM && 'TextEvent' in window && !documentMode && !isPresto(); | |
// In IE9+, we have access to composition events, but the data supplied | |
// by the native compositionend event may be incorrect. Japanese ideographic | |
// spaces, for instance ( ) are not recorded correctly. | |
var useFallbackCompositionData = ExecutionEnvironment.canUseDOM && (!canUseCompositionEvent || documentMode && documentMode > 8 && documentMode <= 11); | |
/** | |
* Opera <= 12 includes TextEvent in window, but does not fire | |
* text input events. Rely on keypress instead. | |
*/ | |
function isPresto() { | |
var opera = window.opera; | |
return typeof opera === 'object' && typeof opera.version === 'function' && parseInt(opera.version(), 10) <= 12; | |
} | |
var SPACEBAR_CODE = 32; | |
var SPACEBAR_CHAR = String.fromCharCode(SPACEBAR_CODE); | |
var topLevelTypes = EventConstants.topLevelTypes; | |
// Events and their corresponding property names. | |
var eventTypes = { | |
beforeInput: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onBeforeInput: null }), | |
captured: keyOf({ onBeforeInputCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topCompositionEnd, topLevelTypes.topKeyPress, topLevelTypes.topTextInput, topLevelTypes.topPaste] | |
}, | |
compositionEnd: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCompositionEnd: null }), | |
captured: keyOf({ onCompositionEndCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionEnd, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] | |
}, | |
compositionStart: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCompositionStart: null }), | |
captured: keyOf({ onCompositionStartCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionStart, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] | |
}, | |
compositionUpdate: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCompositionUpdate: null }), | |
captured: keyOf({ onCompositionUpdateCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topBlur, topLevelTypes.topCompositionUpdate, topLevelTypes.topKeyDown, topLevelTypes.topKeyPress, topLevelTypes.topKeyUp, topLevelTypes.topMouseDown] | |
} | |
}; | |
// Track whether we've ever handled a keypress on the space key. | |
var hasSpaceKeypress = false; | |
/** | |
* Return whether a native keypress event is assumed to be a command. | |
* This is required because Firefox fires `keypress` events for key commands | |
* (cut, copy, select-all, etc.) even though no character is inserted. | |
*/ | |
function isKeypressCommand(nativeEvent) { | |
return (nativeEvent.ctrlKey || nativeEvent.altKey || nativeEvent.metaKey) && | |
// ctrlKey && altKey is equivalent to AltGr, and is not a command. | |
!(nativeEvent.ctrlKey && nativeEvent.altKey); | |
} | |
/** | |
* Translate native top level events into event types. | |
* | |
* @param {string} topLevelType | |
* @return {object} | |
*/ | |
function getCompositionEventType(topLevelType) { | |
switch (topLevelType) { | |
case topLevelTypes.topCompositionStart: | |
return eventTypes.compositionStart; | |
case topLevelTypes.topCompositionEnd: | |
return eventTypes.compositionEnd; | |
case topLevelTypes.topCompositionUpdate: | |
return eventTypes.compositionUpdate; | |
} | |
} | |
/** | |
* Does our fallback best-guess model think this event signifies that | |
* composition has begun? | |
* | |
* @param {string} topLevelType | |
* @param {object} nativeEvent | |
* @return {boolean} | |
*/ | |
function isFallbackCompositionStart(topLevelType, nativeEvent) { | |
return topLevelType === topLevelTypes.topKeyDown && nativeEvent.keyCode === START_KEYCODE; | |
} | |
/** | |
* Does our fallback mode think that this event is the end of composition? | |
* | |
* @param {string} topLevelType | |
* @param {object} nativeEvent | |
* @return {boolean} | |
*/ | |
function isFallbackCompositionEnd(topLevelType, nativeEvent) { | |
switch (topLevelType) { | |
case topLevelTypes.topKeyUp: | |
// Command keys insert or clear IME input. | |
return END_KEYCODES.indexOf(nativeEvent.keyCode) !== -1; | |
case topLevelTypes.topKeyDown: | |
// Expect IME keyCode on each keydown. If we get any other | |
// code we must have exited earlier. | |
return nativeEvent.keyCode !== START_KEYCODE; | |
case topLevelTypes.topKeyPress: | |
case topLevelTypes.topMouseDown: | |
case topLevelTypes.topBlur: | |
// Events are not possible without cancelling IME. | |
return true; | |
default: | |
return false; | |
} | |
} | |
/** | |
* Google Input Tools provides composition data via a CustomEvent, | |
* with the `data` property populated in the `detail` object. If this | |
* is available on the event object, use it. If not, this is a plain | |
* composition event and we have nothing special to extract. | |
* | |
* @param {object} nativeEvent | |
* @return {?string} | |
*/ | |
function getDataFromCustomEvent(nativeEvent) { | |
var detail = nativeEvent.detail; | |
if (typeof detail === 'object' && 'data' in detail) { | |
return detail.data; | |
} | |
return null; | |
} | |
// Track the current IME composition fallback object, if any. | |
var currentComposition = null; | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {?object} A SyntheticCompositionEvent. | |
*/ | |
function extractCompositionEvent(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var eventType; | |
var fallbackData; | |
if (canUseCompositionEvent) { | |
eventType = getCompositionEventType(topLevelType); | |
} else if (!currentComposition) { | |
if (isFallbackCompositionStart(topLevelType, nativeEvent)) { | |
eventType = eventTypes.compositionStart; | |
} | |
} else if (isFallbackCompositionEnd(topLevelType, nativeEvent)) { | |
eventType = eventTypes.compositionEnd; | |
} | |
if (!eventType) { | |
return null; | |
} | |
if (useFallbackCompositionData) { | |
// The current composition is stored statically and must not be | |
// overwritten while composition continues. | |
if (!currentComposition && eventType === eventTypes.compositionStart) { | |
currentComposition = FallbackCompositionState.getPooled(topLevelTarget); | |
} else if (eventType === eventTypes.compositionEnd) { | |
if (currentComposition) { | |
fallbackData = currentComposition.getData(); | |
} | |
} | |
} | |
var event = SyntheticCompositionEvent.getPooled(eventType, topLevelTargetID, nativeEvent, nativeEventTarget); | |
if (fallbackData) { | |
// Inject data generated from fallback path into the synthetic event. | |
// This matches the property of native CompositionEventInterface. | |
event.data = fallbackData; | |
} else { | |
var customData = getDataFromCustomEvent(nativeEvent); | |
if (customData !== null) { | |
event.data = customData; | |
} | |
} | |
EventPropagators.accumulateTwoPhaseDispatches(event); | |
return event; | |
} | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {?string} The string corresponding to this `beforeInput` event. | |
*/ | |
function getNativeBeforeInputChars(topLevelType, nativeEvent) { | |
switch (topLevelType) { | |
case topLevelTypes.topCompositionEnd: | |
return getDataFromCustomEvent(nativeEvent); | |
case topLevelTypes.topKeyPress: | |
/** | |
* If native `textInput` events are available, our goal is to make | |
* use of them. However, there is a special case: the spacebar key. | |
* In Webkit, preventing default on a spacebar `textInput` event | |
* cancels character insertion, but it *also* causes the browser | |
* to fall back to its default spacebar behavior of scrolling the | |
* page. | |
* | |
* Tracking at: | |
* https://code.google.com/p/chromium/issues/detail?id=355103 | |
* | |
* To avoid this issue, use the keypress event as if no `textInput` | |
* event is available. | |
*/ | |
var which = nativeEvent.which; | |
if (which !== SPACEBAR_CODE) { | |
return null; | |
} | |
hasSpaceKeypress = true; | |
return SPACEBAR_CHAR; | |
case topLevelTypes.topTextInput: | |
// Record the characters to be added to the DOM. | |
var chars = nativeEvent.data; | |
// If it's a spacebar character, assume that we have already handled | |
// it at the keypress level and bail immediately. Android Chrome | |
// doesn't give us keycodes, so we need to blacklist it. | |
if (chars === SPACEBAR_CHAR && hasSpaceKeypress) { | |
return null; | |
} | |
return chars; | |
default: | |
// For other native event types, do nothing. | |
return null; | |
} | |
} | |
/** | |
* For browsers that do not provide the `textInput` event, extract the | |
* appropriate string to use for SyntheticInputEvent. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {?string} The fallback string for this `beforeInput` event. | |
*/ | |
function getFallbackBeforeInputChars(topLevelType, nativeEvent) { | |
// If we are currently composing (IME) and using a fallback to do so, | |
// try to extract the composed characters from the fallback object. | |
if (currentComposition) { | |
if (topLevelType === topLevelTypes.topCompositionEnd || isFallbackCompositionEnd(topLevelType, nativeEvent)) { | |
var chars = currentComposition.getData(); | |
FallbackCompositionState.release(currentComposition); | |
currentComposition = null; | |
return chars; | |
} | |
return null; | |
} | |
switch (topLevelType) { | |
case topLevelTypes.topPaste: | |
// If a paste event occurs after a keypress, throw out the input | |
// chars. Paste events should not lead to BeforeInput events. | |
return null; | |
case topLevelTypes.topKeyPress: | |
/** | |
* As of v27, Firefox may fire keypress events even when no character | |
* will be inserted. A few possibilities: | |
* | |
* - `which` is `0`. Arrow keys, Esc key, etc. | |
* | |
* - `which` is the pressed key code, but no char is available. | |
* Ex: 'AltGr + d` in Polish. There is no modified character for | |
* this key combination and no character is inserted into the | |
* document, but FF fires the keypress for char code `100` anyway. | |
* No `input` event will occur. | |
* | |
* - `which` is the pressed key code, but a command combination is | |
* being used. Ex: `Cmd+C`. No character is inserted, and no | |
* `input` event will occur. | |
*/ | |
if (nativeEvent.which && !isKeypressCommand(nativeEvent)) { | |
return String.fromCharCode(nativeEvent.which); | |
} | |
return null; | |
case topLevelTypes.topCompositionEnd: | |
return useFallbackCompositionData ? null : nativeEvent.data; | |
default: | |
return null; | |
} | |
} | |
/** | |
* Extract a SyntheticInputEvent for `beforeInput`, based on either native | |
* `textInput` or fallback behavior. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {?object} A SyntheticInputEvent. | |
*/ | |
function extractBeforeInputEvent(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var chars; | |
if (canUseTextInputEvent) { | |
chars = getNativeBeforeInputChars(topLevelType, nativeEvent); | |
} else { | |
chars = getFallbackBeforeInputChars(topLevelType, nativeEvent); | |
} | |
// If no characters are being inserted, no BeforeInput event should | |
// be fired. | |
if (!chars) { | |
return null; | |
} | |
var event = SyntheticInputEvent.getPooled(eventTypes.beforeInput, topLevelTargetID, nativeEvent, nativeEventTarget); | |
event.data = chars; | |
EventPropagators.accumulateTwoPhaseDispatches(event); | |
return event; | |
} | |
/** | |
* Create an `onBeforeInput` event to match | |
* http://www.w3.org/TR/2013/WD-DOM-Level-3-Events-20131105/#events-inputevents. | |
* | |
* This event plugin is based on the native `textInput` event | |
* available in Chrome, Safari, Opera, and IE. This event fires after | |
* `onKeyPress` and `onCompositionEnd`, but before `onInput`. | |
* | |
* `beforeInput` is spec'd but not implemented in any browsers, and | |
* the `input` event does not provide any useful information about what has | |
* actually been added, contrary to the spec. Thus, `textInput` is the best | |
* available event to identify the characters that have actually been inserted | |
* into the target node. | |
* | |
* This plugin is also responsible for emitting `composition` events, thus | |
* allowing us to share composition fallback code for both `beforeInput` and | |
* `composition` event types. | |
*/ | |
var BeforeInputEventPlugin = { | |
eventTypes: eventTypes, | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @see {EventPluginHub.extractEvents} | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
return [extractCompositionEvent(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget), extractBeforeInputEvent(topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget)]; | |
} | |
}; | |
module.exports = BeforeInputEventPlugin; | |
/***/ }, | |
/* 130 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EventPropagators | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPluginHub = __webpack_require__(89); | |
var warning = __webpack_require__(83); | |
var accumulateInto = __webpack_require__(93); | |
var forEachAccumulated = __webpack_require__(94); | |
var PropagationPhases = EventConstants.PropagationPhases; | |
var getListener = EventPluginHub.getListener; | |
/** | |
* Some event types have a notion of different registration names for different | |
* "phases" of propagation. This finds listeners by a given phase. | |
*/ | |
function listenerAtPhase(id, event, propagationPhase) { | |
var registrationName = event.dispatchConfig.phasedRegistrationNames[propagationPhase]; | |
return getListener(id, registrationName); | |
} | |
/** | |
* Tags a `SyntheticEvent` with dispatched listeners. Creating this function | |
* here, allows us to not have to bind or create functions for each event. | |
* Mutating the event's members allows us to not have to create a wrapping | |
* "dispatch" object that pairs the event with the listener. | |
*/ | |
function accumulateDirectionalDispatches(domID, upwards, event) { | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(domID, 'Dispatching id must not be null') : undefined; | |
} | |
var phase = upwards ? PropagationPhases.bubbled : PropagationPhases.captured; | |
var listener = listenerAtPhase(domID, event, phase); | |
if (listener) { | |
event._dispatchListeners = accumulateInto(event._dispatchListeners, listener); | |
event._dispatchIDs = accumulateInto(event._dispatchIDs, domID); | |
} | |
} | |
/** | |
* Collect dispatches (must be entirely collected before dispatching - see unit | |
* tests). Lazily allocate the array to conserve memory. We must loop through | |
* each event and perform the traversal for each one. We cannot perform a | |
* single traversal for the entire collection of events because each event may | |
* have a different target. | |
*/ | |
function accumulateTwoPhaseDispatchesSingle(event) { | |
if (event && event.dispatchConfig.phasedRegistrationNames) { | |
EventPluginHub.injection.getInstanceHandle().traverseTwoPhase(event.dispatchMarker, accumulateDirectionalDispatches, event); | |
} | |
} | |
/** | |
* Same as `accumulateTwoPhaseDispatchesSingle`, but skips over the targetID. | |
*/ | |
function accumulateTwoPhaseDispatchesSingleSkipTarget(event) { | |
if (event && event.dispatchConfig.phasedRegistrationNames) { | |
EventPluginHub.injection.getInstanceHandle().traverseTwoPhaseSkipTarget(event.dispatchMarker, accumulateDirectionalDispatches, event); | |
} | |
} | |
/** | |
* Accumulates without regard to direction, does not look for phased | |
* registration names. Same as `accumulateDirectDispatchesSingle` but without | |
* requiring that the `dispatchMarker` be the same as the dispatched ID. | |
*/ | |
function accumulateDispatches(id, ignoredDirection, event) { | |
if (event && event.dispatchConfig.registrationName) { | |
var registrationName = event.dispatchConfig.registrationName; | |
var listener = getListener(id, registrationName); | |
if (listener) { | |
event._dispatchListeners = accumulateInto(event._dispatchListeners, listener); | |
event._dispatchIDs = accumulateInto(event._dispatchIDs, id); | |
} | |
} | |
} | |
/** | |
* Accumulates dispatches on an `SyntheticEvent`, but only for the | |
* `dispatchMarker`. | |
* @param {SyntheticEvent} event | |
*/ | |
function accumulateDirectDispatchesSingle(event) { | |
if (event && event.dispatchConfig.registrationName) { | |
accumulateDispatches(event.dispatchMarker, null, event); | |
} | |
} | |
function accumulateTwoPhaseDispatches(events) { | |
forEachAccumulated(events, accumulateTwoPhaseDispatchesSingle); | |
} | |
function accumulateTwoPhaseDispatchesSkipTarget(events) { | |
forEachAccumulated(events, accumulateTwoPhaseDispatchesSingleSkipTarget); | |
} | |
function accumulateEnterLeaveDispatches(leave, enter, fromID, toID) { | |
EventPluginHub.injection.getInstanceHandle().traverseEnterLeave(fromID, toID, accumulateDispatches, leave, enter); | |
} | |
function accumulateDirectDispatches(events) { | |
forEachAccumulated(events, accumulateDirectDispatchesSingle); | |
} | |
/** | |
* A small set of propagation patterns, each of which will accept a small amount | |
* of information, and generate a set of "dispatch ready event objects" - which | |
* are sets of events that have already been annotated with a set of dispatched | |
* listener functions/ids. The API is designed this way to discourage these | |
* propagation strategies from actually executing the dispatches, since we | |
* always want to collect the entire set of dispatches before executing event a | |
* single one. | |
* | |
* @constructor EventPropagators | |
*/ | |
var EventPropagators = { | |
accumulateTwoPhaseDispatches: accumulateTwoPhaseDispatches, | |
accumulateTwoPhaseDispatchesSkipTarget: accumulateTwoPhaseDispatchesSkipTarget, | |
accumulateDirectDispatches: accumulateDirectDispatches, | |
accumulateEnterLeaveDispatches: accumulateEnterLeaveDispatches | |
}; | |
module.exports = EventPropagators; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 131 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule FallbackCompositionState | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var PooledClass = __webpack_require__(113); | |
var assign = __webpack_require__(29); | |
var getTextContentAccessor = __webpack_require__(132); | |
/** | |
* This helper class stores information about text content of a target node, | |
* allowing comparison of content before and after a given event. | |
* | |
* Identify the node where selection currently begins, then observe | |
* both its text content and its current position in the DOM. Since the | |
* browser may natively replace the target node during composition, we can | |
* use its position to find its replacement. | |
* | |
* @param {DOMEventTarget} root | |
*/ | |
function FallbackCompositionState(root) { | |
this._root = root; | |
this._startText = this.getText(); | |
this._fallbackText = null; | |
} | |
assign(FallbackCompositionState.prototype, { | |
destructor: function () { | |
this._root = null; | |
this._startText = null; | |
this._fallbackText = null; | |
}, | |
/** | |
* Get current text of input. | |
* | |
* @return {string} | |
*/ | |
getText: function () { | |
if ('value' in this._root) { | |
return this._root.value; | |
} | |
return this._root[getTextContentAccessor()]; | |
}, | |
/** | |
* Determine the differing substring between the initially stored | |
* text content and the current content. | |
* | |
* @return {string} | |
*/ | |
getData: function () { | |
if (this._fallbackText) { | |
return this._fallbackText; | |
} | |
var start; | |
var startValue = this._startText; | |
var startLength = startValue.length; | |
var end; | |
var endValue = this.getText(); | |
var endLength = endValue.length; | |
for (start = 0; start < startLength; start++) { | |
if (startValue[start] !== endValue[start]) { | |
break; | |
} | |
} | |
var minEnd = startLength - start; | |
for (end = 1; end <= minEnd; end++) { | |
if (startValue[startLength - end] !== endValue[endLength - end]) { | |
break; | |
} | |
} | |
var sliceTail = end > 1 ? 1 - end : undefined; | |
this._fallbackText = endValue.slice(start, sliceTail); | |
return this._fallbackText; | |
} | |
}); | |
PooledClass.addPoolingTo(FallbackCompositionState); | |
module.exports = FallbackCompositionState; | |
/***/ }, | |
/* 132 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getTextContentAccessor | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var contentKey = null; | |
/** | |
* Gets the key used to access text content on a DOM node. | |
* | |
* @return {?string} Key used to access text content. | |
* @internal | |
*/ | |
function getTextContentAccessor() { | |
if (!contentKey && ExecutionEnvironment.canUseDOM) { | |
// Prefer textContent to innerText because many browsers support both but | |
// SVG <text> elements don't support innerText even when <div> does. | |
contentKey = 'textContent' in document.documentElement ? 'textContent' : 'innerText'; | |
} | |
return contentKey; | |
} | |
module.exports = getTextContentAccessor; | |
/***/ }, | |
/* 133 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticCompositionEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticEvent = __webpack_require__(134); | |
/** | |
* @interface Event | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/#events-compositionevents | |
*/ | |
var CompositionEventInterface = { | |
data: null | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticCompositionEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticEvent.augmentClass(SyntheticCompositionEvent, CompositionEventInterface); | |
module.exports = SyntheticCompositionEvent; | |
/***/ }, | |
/* 134 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var PooledClass = __webpack_require__(113); | |
var assign = __webpack_require__(29); | |
var emptyFunction = __webpack_require__(73); | |
var warning = __webpack_require__(83); | |
/** | |
* @interface Event | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var EventInterface = { | |
type: null, | |
target: null, | |
// currentTarget is set when dispatching; no use in copying it here | |
currentTarget: emptyFunction.thatReturnsNull, | |
eventPhase: null, | |
bubbles: null, | |
cancelable: null, | |
timeStamp: function (event) { | |
return event.timeStamp || Date.now(); | |
}, | |
defaultPrevented: null, | |
isTrusted: null | |
}; | |
/** | |
* Synthetic events are dispatched by event plugins, typically in response to a | |
* top-level event delegation handler. | |
* | |
* These systems should generally use pooling to reduce the frequency of garbage | |
* collection. The system should check `isPersistent` to determine whether the | |
* event should be released into the pool after being dispatched. Users that | |
* need a persisted event should invoke `persist`. | |
* | |
* Synthetic events (and subclasses) implement the DOM Level 3 Events API by | |
* normalizing browser quirks. Subclasses do not necessarily have to implement a | |
* DOM interface; custom application-specific events can also subclass this. | |
* | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
*/ | |
function SyntheticEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
this.dispatchConfig = dispatchConfig; | |
this.dispatchMarker = dispatchMarker; | |
this.nativeEvent = nativeEvent; | |
var Interface = this.constructor.Interface; | |
for (var propName in Interface) { | |
if (!Interface.hasOwnProperty(propName)) { | |
continue; | |
} | |
var normalize = Interface[propName]; | |
if (normalize) { | |
this[propName] = normalize(nativeEvent); | |
} else { | |
if (propName === 'target') { | |
this.target = nativeEventTarget; | |
} else { | |
this[propName] = nativeEvent[propName]; | |
} | |
} | |
} | |
var defaultPrevented = nativeEvent.defaultPrevented != null ? nativeEvent.defaultPrevented : nativeEvent.returnValue === false; | |
if (defaultPrevented) { | |
this.isDefaultPrevented = emptyFunction.thatReturnsTrue; | |
} else { | |
this.isDefaultPrevented = emptyFunction.thatReturnsFalse; | |
} | |
this.isPropagationStopped = emptyFunction.thatReturnsFalse; | |
} | |
assign(SyntheticEvent.prototype, { | |
preventDefault: function () { | |
this.defaultPrevented = true; | |
var event = this.nativeEvent; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(event, 'This synthetic event is reused for performance reasons. If you\'re ' + 'seeing this, you\'re calling `preventDefault` on a ' + 'released/nullified synthetic event. This is a no-op. See ' + 'https://fb.me/react-event-pooling for more information.') : undefined; | |
} | |
if (!event) { | |
return; | |
} | |
if (event.preventDefault) { | |
event.preventDefault(); | |
} else { | |
event.returnValue = false; | |
} | |
this.isDefaultPrevented = emptyFunction.thatReturnsTrue; | |
}, | |
stopPropagation: function () { | |
var event = this.nativeEvent; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(event, 'This synthetic event is reused for performance reasons. If you\'re ' + 'seeing this, you\'re calling `stopPropagation` on a ' + 'released/nullified synthetic event. This is a no-op. See ' + 'https://fb.me/react-event-pooling for more information.') : undefined; | |
} | |
if (!event) { | |
return; | |
} | |
if (event.stopPropagation) { | |
event.stopPropagation(); | |
} else { | |
event.cancelBubble = true; | |
} | |
this.isPropagationStopped = emptyFunction.thatReturnsTrue; | |
}, | |
/** | |
* We release all dispatched `SyntheticEvent`s after each event loop, adding | |
* them back into the pool. This allows a way to hold onto a reference that | |
* won't be added back into the pool. | |
*/ | |
persist: function () { | |
this.isPersistent = emptyFunction.thatReturnsTrue; | |
}, | |
/** | |
* Checks if this event should be released back into the pool. | |
* | |
* @return {boolean} True if this should not be released, false otherwise. | |
*/ | |
isPersistent: emptyFunction.thatReturnsFalse, | |
/** | |
* `PooledClass` looks for `destructor` on each instance it releases. | |
*/ | |
destructor: function () { | |
var Interface = this.constructor.Interface; | |
for (var propName in Interface) { | |
this[propName] = null; | |
} | |
this.dispatchConfig = null; | |
this.dispatchMarker = null; | |
this.nativeEvent = null; | |
} | |
}); | |
SyntheticEvent.Interface = EventInterface; | |
/** | |
* Helper to reduce boilerplate when creating subclasses. | |
* | |
* @param {function} Class | |
* @param {?object} Interface | |
*/ | |
SyntheticEvent.augmentClass = function (Class, Interface) { | |
var Super = this; | |
var prototype = Object.create(Super.prototype); | |
assign(prototype, Class.prototype); | |
Class.prototype = prototype; | |
Class.prototype.constructor = Class; | |
Class.Interface = assign({}, Super.Interface, Interface); | |
Class.augmentClass = Super.augmentClass; | |
PooledClass.addPoolingTo(Class, PooledClass.fourArgumentPooler); | |
}; | |
PooledClass.addPoolingTo(SyntheticEvent, PooledClass.fourArgumentPooler); | |
module.exports = SyntheticEvent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 135 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticInputEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticEvent = __webpack_require__(134); | |
/** | |
* @interface Event | |
* @see http://www.w3.org/TR/2013/WD-DOM-Level-3-Events-20131105 | |
* /#events-inputevents | |
*/ | |
var InputEventInterface = { | |
data: null | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticInputEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticEvent.augmentClass(SyntheticInputEvent, InputEventInterface); | |
module.exports = SyntheticInputEvent; | |
/***/ }, | |
/* 136 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ChangeEventPlugin | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPluginHub = __webpack_require__(89); | |
var EventPropagators = __webpack_require__(130); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var ReactUpdates = __webpack_require__(111); | |
var SyntheticEvent = __webpack_require__(134); | |
var getEventTarget = __webpack_require__(137); | |
var isEventSupported = __webpack_require__(97); | |
var isTextInputElement = __webpack_require__(138); | |
var keyOf = __webpack_require__(30); | |
var topLevelTypes = EventConstants.topLevelTypes; | |
var eventTypes = { | |
change: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onChange: null }), | |
captured: keyOf({ onChangeCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topBlur, topLevelTypes.topChange, topLevelTypes.topClick, topLevelTypes.topFocus, topLevelTypes.topInput, topLevelTypes.topKeyDown, topLevelTypes.topKeyUp, topLevelTypes.topSelectionChange] | |
} | |
}; | |
/** | |
* For IE shims | |
*/ | |
var activeElement = null; | |
var activeElementID = null; | |
var activeElementValue = null; | |
var activeElementValueProp = null; | |
/** | |
* SECTION: handle `change` event | |
*/ | |
function shouldUseChangeEvent(elem) { | |
var nodeName = elem.nodeName && elem.nodeName.toLowerCase(); | |
return nodeName === 'select' || nodeName === 'input' && elem.type === 'file'; | |
} | |
var doesChangeEventBubble = false; | |
if (ExecutionEnvironment.canUseDOM) { | |
// See `handleChange` comment below | |
doesChangeEventBubble = isEventSupported('change') && (!('documentMode' in document) || document.documentMode > 8); | |
} | |
function manualDispatchChangeEvent(nativeEvent) { | |
var event = SyntheticEvent.getPooled(eventTypes.change, activeElementID, nativeEvent, getEventTarget(nativeEvent)); | |
EventPropagators.accumulateTwoPhaseDispatches(event); | |
// If change and propertychange bubbled, we'd just bind to it like all the | |
// other events and have it go through ReactBrowserEventEmitter. Since it | |
// doesn't, we manually listen for the events and so we have to enqueue and | |
// process the abstract event manually. | |
// | |
// Batching is necessary here in order to ensure that all event handlers run | |
// before the next rerender (including event handlers attached to ancestor | |
// elements instead of directly on the input). Without this, controlled | |
// components don't work properly in conjunction with event bubbling because | |
// the component is rerendered and the value reverted before all the event | |
// handlers can run. See https://github.com/facebook/react/issues/708. | |
ReactUpdates.batchedUpdates(runEventInBatch, event); | |
} | |
function runEventInBatch(event) { | |
EventPluginHub.enqueueEvents(event); | |
EventPluginHub.processEventQueue(false); | |
} | |
function startWatchingForChangeEventIE8(target, targetID) { | |
activeElement = target; | |
activeElementID = targetID; | |
activeElement.attachEvent('onchange', manualDispatchChangeEvent); | |
} | |
function stopWatchingForChangeEventIE8() { | |
if (!activeElement) { | |
return; | |
} | |
activeElement.detachEvent('onchange', manualDispatchChangeEvent); | |
activeElement = null; | |
activeElementID = null; | |
} | |
function getTargetIDForChangeEvent(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topChange) { | |
return topLevelTargetID; | |
} | |
} | |
function handleEventsForChangeEventIE8(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topFocus) { | |
// stopWatching() should be a noop here but we call it just in case we | |
// missed a blur event somehow. | |
stopWatchingForChangeEventIE8(); | |
startWatchingForChangeEventIE8(topLevelTarget, topLevelTargetID); | |
} else if (topLevelType === topLevelTypes.topBlur) { | |
stopWatchingForChangeEventIE8(); | |
} | |
} | |
/** | |
* SECTION: handle `input` event | |
*/ | |
var isInputEventSupported = false; | |
if (ExecutionEnvironment.canUseDOM) { | |
// IE9 claims to support the input event but fails to trigger it when | |
// deleting text, so we ignore its input events | |
isInputEventSupported = isEventSupported('input') && (!('documentMode' in document) || document.documentMode > 9); | |
} | |
/** | |
* (For old IE.) Replacement getter/setter for the `value` property that gets | |
* set on the active element. | |
*/ | |
var newValueProp = { | |
get: function () { | |
return activeElementValueProp.get.call(this); | |
}, | |
set: function (val) { | |
// Cast to a string so we can do equality checks. | |
activeElementValue = '' + val; | |
activeElementValueProp.set.call(this, val); | |
} | |
}; | |
/** | |
* (For old IE.) Starts tracking propertychange events on the passed-in element | |
* and override the value property so that we can distinguish user events from | |
* value changes in JS. | |
*/ | |
function startWatchingForValueChange(target, targetID) { | |
activeElement = target; | |
activeElementID = targetID; | |
activeElementValue = target.value; | |
activeElementValueProp = Object.getOwnPropertyDescriptor(target.constructor.prototype, 'value'); | |
// Not guarded in a canDefineProperty check: IE8 supports defineProperty only | |
// on DOM elements | |
Object.defineProperty(activeElement, 'value', newValueProp); | |
activeElement.attachEvent('onpropertychange', handlePropertyChange); | |
} | |
/** | |
* (For old IE.) Removes the event listeners from the currently-tracked element, | |
* if any exists. | |
*/ | |
function stopWatchingForValueChange() { | |
if (!activeElement) { | |
return; | |
} | |
// delete restores the original property definition | |
delete activeElement.value; | |
activeElement.detachEvent('onpropertychange', handlePropertyChange); | |
activeElement = null; | |
activeElementID = null; | |
activeElementValue = null; | |
activeElementValueProp = null; | |
} | |
/** | |
* (For old IE.) Handles a propertychange event, sending a `change` event if | |
* the value of the active element has changed. | |
*/ | |
function handlePropertyChange(nativeEvent) { | |
if (nativeEvent.propertyName !== 'value') { | |
return; | |
} | |
var value = nativeEvent.srcElement.value; | |
if (value === activeElementValue) { | |
return; | |
} | |
activeElementValue = value; | |
manualDispatchChangeEvent(nativeEvent); | |
} | |
/** | |
* If a `change` event should be fired, returns the target's ID. | |
*/ | |
function getTargetIDForInputEvent(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topInput) { | |
// In modern browsers (i.e., not IE8 or IE9), the input event is exactly | |
// what we want so fall through here and trigger an abstract event | |
return topLevelTargetID; | |
} | |
} | |
// For IE8 and IE9. | |
function handleEventsForInputEventIE(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topFocus) { | |
// In IE8, we can capture almost all .value changes by adding a | |
// propertychange handler and looking for events with propertyName | |
// equal to 'value' | |
// In IE9, propertychange fires for most input events but is buggy and | |
// doesn't fire when text is deleted, but conveniently, selectionchange | |
// appears to fire in all of the remaining cases so we catch those and | |
// forward the event if the value has changed | |
// In either case, we don't want to call the event handler if the value | |
// is changed from JS so we redefine a setter for `.value` that updates | |
// our activeElementValue variable, allowing us to ignore those changes | |
// | |
// stopWatching() should be a noop here but we call it just in case we | |
// missed a blur event somehow. | |
stopWatchingForValueChange(); | |
startWatchingForValueChange(topLevelTarget, topLevelTargetID); | |
} else if (topLevelType === topLevelTypes.topBlur) { | |
stopWatchingForValueChange(); | |
} | |
} | |
// For IE8 and IE9. | |
function getTargetIDForInputEventIE(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topSelectionChange || topLevelType === topLevelTypes.topKeyUp || topLevelType === topLevelTypes.topKeyDown) { | |
// On the selectionchange event, the target is just document which isn't | |
// helpful for us so just check activeElement instead. | |
// | |
// 99% of the time, keydown and keyup aren't necessary. IE8 fails to fire | |
// propertychange on the first input event after setting `value` from a | |
// script and fires only keydown, keypress, keyup. Catching keyup usually | |
// gets it and catching keydown lets us fire an event for the first | |
// keystroke if user does a key repeat (it'll be a little delayed: right | |
// before the second keystroke). Other input methods (e.g., paste) seem to | |
// fire selectionchange normally. | |
if (activeElement && activeElement.value !== activeElementValue) { | |
activeElementValue = activeElement.value; | |
return activeElementID; | |
} | |
} | |
} | |
/** | |
* SECTION: handle `click` event | |
*/ | |
function shouldUseClickEvent(elem) { | |
// Use the `click` event to detect changes to checkbox and radio inputs. | |
// This approach works across all browsers, whereas `change` does not fire | |
// until `blur` in IE8. | |
return elem.nodeName && elem.nodeName.toLowerCase() === 'input' && (elem.type === 'checkbox' || elem.type === 'radio'); | |
} | |
function getTargetIDForClickEvent(topLevelType, topLevelTarget, topLevelTargetID) { | |
if (topLevelType === topLevelTypes.topClick) { | |
return topLevelTargetID; | |
} | |
} | |
/** | |
* This plugin creates an `onChange` event that normalizes change events | |
* across form elements. This event fires at a time when it's possible to | |
* change the element's value without seeing a flicker. | |
* | |
* Supported elements are: | |
* - input (see `isTextInputElement`) | |
* - textarea | |
* - select | |
*/ | |
var ChangeEventPlugin = { | |
eventTypes: eventTypes, | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @see {EventPluginHub.extractEvents} | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var getTargetIDFunc, handleEventFunc; | |
if (shouldUseChangeEvent(topLevelTarget)) { | |
if (doesChangeEventBubble) { | |
getTargetIDFunc = getTargetIDForChangeEvent; | |
} else { | |
handleEventFunc = handleEventsForChangeEventIE8; | |
} | |
} else if (isTextInputElement(topLevelTarget)) { | |
if (isInputEventSupported) { | |
getTargetIDFunc = getTargetIDForInputEvent; | |
} else { | |
getTargetIDFunc = getTargetIDForInputEventIE; | |
handleEventFunc = handleEventsForInputEventIE; | |
} | |
} else if (shouldUseClickEvent(topLevelTarget)) { | |
getTargetIDFunc = getTargetIDForClickEvent; | |
} | |
if (getTargetIDFunc) { | |
var targetID = getTargetIDFunc(topLevelType, topLevelTarget, topLevelTargetID); | |
if (targetID) { | |
var event = SyntheticEvent.getPooled(eventTypes.change, targetID, nativeEvent, nativeEventTarget); | |
event.type = 'change'; | |
EventPropagators.accumulateTwoPhaseDispatches(event); | |
return event; | |
} | |
} | |
if (handleEventFunc) { | |
handleEventFunc(topLevelType, topLevelTarget, topLevelTargetID); | |
} | |
} | |
}; | |
module.exports = ChangeEventPlugin; | |
/***/ }, | |
/* 137 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getEventTarget | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* Gets the target node from a native browser event by accounting for | |
* inconsistencies in browser DOM APIs. | |
* | |
* @param {object} nativeEvent Native browser event. | |
* @return {DOMEventTarget} Target node. | |
*/ | |
function getEventTarget(nativeEvent) { | |
var target = nativeEvent.target || nativeEvent.srcElement || window; | |
// Safari may fire events on text nodes (Node.TEXT_NODE is 3). | |
// @see http://www.quirksmode.org/js/events_properties.html | |
return target.nodeType === 3 ? target.parentNode : target; | |
} | |
module.exports = getEventTarget; | |
/***/ }, | |
/* 138 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule isTextInputElement | |
*/ | |
'use strict'; | |
/** | |
* @see http://www.whatwg.org/specs/web-apps/current-work/multipage/the-input-element.html#input-type-attr-summary | |
*/ | |
var supportedInputTypes = { | |
'color': true, | |
'date': true, | |
'datetime': true, | |
'datetime-local': true, | |
'email': true, | |
'month': true, | |
'number': true, | |
'password': true, | |
'range': true, | |
'search': true, | |
'tel': true, | |
'text': true, | |
'time': true, | |
'url': true, | |
'week': true | |
}; | |
function isTextInputElement(elem) { | |
var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase(); | |
return nodeName && (nodeName === 'input' && supportedInputTypes[elem.type] || nodeName === 'textarea'); | |
} | |
module.exports = isTextInputElement; | |
/***/ }, | |
/* 139 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ClientReactRootIndex | |
* @typechecks | |
*/ | |
'use strict'; | |
var nextReactRootIndex = 0; | |
var ClientReactRootIndex = { | |
createReactRootIndex: function () { | |
return nextReactRootIndex++; | |
} | |
}; | |
module.exports = ClientReactRootIndex; | |
/***/ }, | |
/* 140 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule DefaultEventPluginOrder | |
*/ | |
'use strict'; | |
var keyOf = __webpack_require__(30); | |
/** | |
* Module that is injectable into `EventPluginHub`, that specifies a | |
* deterministic ordering of `EventPlugin`s. A convenient way to reason about | |
* plugins, without having to package every one of them. This is better than | |
* having plugins be ordered in the same order that they are injected because | |
* that ordering would be influenced by the packaging order. | |
* `ResponderEventPlugin` must occur before `SimpleEventPlugin` so that | |
* preventing default on events is convenient in `SimpleEventPlugin` handlers. | |
*/ | |
var DefaultEventPluginOrder = [keyOf({ ResponderEventPlugin: null }), keyOf({ SimpleEventPlugin: null }), keyOf({ TapEventPlugin: null }), keyOf({ EnterLeaveEventPlugin: null }), keyOf({ ChangeEventPlugin: null }), keyOf({ SelectEventPlugin: null }), keyOf({ BeforeInputEventPlugin: null })]; | |
module.exports = DefaultEventPluginOrder; | |
/***/ }, | |
/* 141 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule EnterLeaveEventPlugin | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPropagators = __webpack_require__(130); | |
var SyntheticMouseEvent = __webpack_require__(142); | |
var ReactMount = __webpack_require__(86); | |
var keyOf = __webpack_require__(30); | |
var topLevelTypes = EventConstants.topLevelTypes; | |
var getFirstReactDOM = ReactMount.getFirstReactDOM; | |
var eventTypes = { | |
mouseEnter: { | |
registrationName: keyOf({ onMouseEnter: null }), | |
dependencies: [topLevelTypes.topMouseOut, topLevelTypes.topMouseOver] | |
}, | |
mouseLeave: { | |
registrationName: keyOf({ onMouseLeave: null }), | |
dependencies: [topLevelTypes.topMouseOut, topLevelTypes.topMouseOver] | |
} | |
}; | |
var extractedEvents = [null, null]; | |
var EnterLeaveEventPlugin = { | |
eventTypes: eventTypes, | |
/** | |
* For almost every interaction we care about, there will be both a top-level | |
* `mouseover` and `mouseout` event that occurs. Only use `mouseout` so that | |
* we do not extract duplicate events. However, moving the mouse into the | |
* browser from outside will not fire a `mouseout` event. In this case, we use | |
* the `mouseover` top-level event. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @see {EventPluginHub.extractEvents} | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
if (topLevelType === topLevelTypes.topMouseOver && (nativeEvent.relatedTarget || nativeEvent.fromElement)) { | |
return null; | |
} | |
if (topLevelType !== topLevelTypes.topMouseOut && topLevelType !== topLevelTypes.topMouseOver) { | |
// Must not be a mouse in or mouse out - ignoring. | |
return null; | |
} | |
var win; | |
if (topLevelTarget.window === topLevelTarget) { | |
// `topLevelTarget` is probably a window object. | |
win = topLevelTarget; | |
} else { | |
// TODO: Figure out why `ownerDocument` is sometimes undefined in IE8. | |
var doc = topLevelTarget.ownerDocument; | |
if (doc) { | |
win = doc.defaultView || doc.parentWindow; | |
} else { | |
win = window; | |
} | |
} | |
var from; | |
var to; | |
var fromID = ''; | |
var toID = ''; | |
if (topLevelType === topLevelTypes.topMouseOut) { | |
from = topLevelTarget; | |
fromID = topLevelTargetID; | |
to = getFirstReactDOM(nativeEvent.relatedTarget || nativeEvent.toElement); | |
if (to) { | |
toID = ReactMount.getID(to); | |
} else { | |
to = win; | |
} | |
to = to || win; | |
} else { | |
from = win; | |
to = topLevelTarget; | |
toID = topLevelTargetID; | |
} | |
if (from === to) { | |
// Nothing pertains to our managed components. | |
return null; | |
} | |
var leave = SyntheticMouseEvent.getPooled(eventTypes.mouseLeave, fromID, nativeEvent, nativeEventTarget); | |
leave.type = 'mouseleave'; | |
leave.target = from; | |
leave.relatedTarget = to; | |
var enter = SyntheticMouseEvent.getPooled(eventTypes.mouseEnter, toID, nativeEvent, nativeEventTarget); | |
enter.type = 'mouseenter'; | |
enter.target = to; | |
enter.relatedTarget = from; | |
EventPropagators.accumulateEnterLeaveDispatches(leave, enter, fromID, toID); | |
extractedEvents[0] = leave; | |
extractedEvents[1] = enter; | |
return extractedEvents; | |
} | |
}; | |
module.exports = EnterLeaveEventPlugin; | |
/***/ }, | |
/* 142 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticMouseEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticUIEvent = __webpack_require__(143); | |
var ViewportMetrics = __webpack_require__(96); | |
var getEventModifierState = __webpack_require__(144); | |
/** | |
* @interface MouseEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var MouseEventInterface = { | |
screenX: null, | |
screenY: null, | |
clientX: null, | |
clientY: null, | |
ctrlKey: null, | |
shiftKey: null, | |
altKey: null, | |
metaKey: null, | |
getModifierState: getEventModifierState, | |
button: function (event) { | |
// Webkit, Firefox, IE9+ | |
// which: 1 2 3 | |
// button: 0 1 2 (standard) | |
var button = event.button; | |
if ('which' in event) { | |
return button; | |
} | |
// IE<9 | |
// which: undefined | |
// button: 0 0 0 | |
// button: 1 4 2 (onmouseup) | |
return button === 2 ? 2 : button === 4 ? 1 : 0; | |
}, | |
buttons: null, | |
relatedTarget: function (event) { | |
return event.relatedTarget || (event.fromElement === event.srcElement ? event.toElement : event.fromElement); | |
}, | |
// "Proprietary" Interface. | |
pageX: function (event) { | |
return 'pageX' in event ? event.pageX : event.clientX + ViewportMetrics.currentScrollLeft; | |
}, | |
pageY: function (event) { | |
return 'pageY' in event ? event.pageY : event.clientY + ViewportMetrics.currentScrollTop; | |
} | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticMouseEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticUIEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticUIEvent.augmentClass(SyntheticMouseEvent, MouseEventInterface); | |
module.exports = SyntheticMouseEvent; | |
/***/ }, | |
/* 143 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticUIEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticEvent = __webpack_require__(134); | |
var getEventTarget = __webpack_require__(137); | |
/** | |
* @interface UIEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var UIEventInterface = { | |
view: function (event) { | |
if (event.view) { | |
return event.view; | |
} | |
var target = getEventTarget(event); | |
if (target != null && target.window === target) { | |
// target is a window object | |
return target; | |
} | |
var doc = target.ownerDocument; | |
// TODO: Figure out why `ownerDocument` is sometimes undefined in IE8. | |
if (doc) { | |
return doc.defaultView || doc.parentWindow; | |
} else { | |
return window; | |
} | |
}, | |
detail: function (event) { | |
return event.detail || 0; | |
} | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticEvent} | |
*/ | |
function SyntheticUIEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticEvent.augmentClass(SyntheticUIEvent, UIEventInterface); | |
module.exports = SyntheticUIEvent; | |
/***/ }, | |
/* 144 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getEventModifierState | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* Translation from modifier key to the associated property in the event. | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/#keys-Modifiers | |
*/ | |
var modifierKeyToProp = { | |
'Alt': 'altKey', | |
'Control': 'ctrlKey', | |
'Meta': 'metaKey', | |
'Shift': 'shiftKey' | |
}; | |
// IE8 does not implement getModifierState so we simply map it to the only | |
// modifier keys exposed by the event itself, does not support Lock-keys. | |
// Currently, all major browsers except Chrome seems to support Lock-keys. | |
function modifierStateGetter(keyArg) { | |
var syntheticEvent = this; | |
var nativeEvent = syntheticEvent.nativeEvent; | |
if (nativeEvent.getModifierState) { | |
return nativeEvent.getModifierState(keyArg); | |
} | |
var keyProp = modifierKeyToProp[keyArg]; | |
return keyProp ? !!nativeEvent[keyProp] : false; | |
} | |
function getEventModifierState(nativeEvent) { | |
return modifierStateGetter; | |
} | |
module.exports = getEventModifierState; | |
/***/ }, | |
/* 145 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule HTMLDOMPropertyConfig | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var MUST_USE_ATTRIBUTE = DOMProperty.injection.MUST_USE_ATTRIBUTE; | |
var MUST_USE_PROPERTY = DOMProperty.injection.MUST_USE_PROPERTY; | |
var HAS_BOOLEAN_VALUE = DOMProperty.injection.HAS_BOOLEAN_VALUE; | |
var HAS_SIDE_EFFECTS = DOMProperty.injection.HAS_SIDE_EFFECTS; | |
var HAS_NUMERIC_VALUE = DOMProperty.injection.HAS_NUMERIC_VALUE; | |
var HAS_POSITIVE_NUMERIC_VALUE = DOMProperty.injection.HAS_POSITIVE_NUMERIC_VALUE; | |
var HAS_OVERLOADED_BOOLEAN_VALUE = DOMProperty.injection.HAS_OVERLOADED_BOOLEAN_VALUE; | |
var hasSVG; | |
if (ExecutionEnvironment.canUseDOM) { | |
var implementation = document.implementation; | |
hasSVG = implementation && implementation.hasFeature && implementation.hasFeature('http://www.w3.org/TR/SVG11/feature#BasicStructure', '1.1'); | |
} | |
var HTMLDOMPropertyConfig = { | |
isCustomAttribute: RegExp.prototype.test.bind(/^(data|aria)-[a-z_][a-z\d_.\-]*$/), | |
Properties: { | |
/** | |
* Standard Properties | |
*/ | |
accept: null, | |
acceptCharset: null, | |
accessKey: null, | |
action: null, | |
allowFullScreen: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
allowTransparency: MUST_USE_ATTRIBUTE, | |
alt: null, | |
async: HAS_BOOLEAN_VALUE, | |
autoComplete: null, | |
// autoFocus is polyfilled/normalized by AutoFocusUtils | |
// autoFocus: HAS_BOOLEAN_VALUE, | |
autoPlay: HAS_BOOLEAN_VALUE, | |
capture: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
cellPadding: null, | |
cellSpacing: null, | |
charSet: MUST_USE_ATTRIBUTE, | |
challenge: MUST_USE_ATTRIBUTE, | |
checked: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
classID: MUST_USE_ATTRIBUTE, | |
// To set className on SVG elements, it's necessary to use .setAttribute; | |
// this works on HTML elements too in all browsers except IE8. Conveniently, | |
// IE8 doesn't support SVG and so we can simply use the attribute in | |
// browsers that support SVG and the property in browsers that don't, | |
// regardless of whether the element is HTML or SVG. | |
className: hasSVG ? MUST_USE_ATTRIBUTE : MUST_USE_PROPERTY, | |
cols: MUST_USE_ATTRIBUTE | HAS_POSITIVE_NUMERIC_VALUE, | |
colSpan: null, | |
content: null, | |
contentEditable: null, | |
contextMenu: MUST_USE_ATTRIBUTE, | |
controls: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
coords: null, | |
crossOrigin: null, | |
data: null, // For `<object />` acts as `src`. | |
dateTime: MUST_USE_ATTRIBUTE, | |
'default': HAS_BOOLEAN_VALUE, | |
defer: HAS_BOOLEAN_VALUE, | |
dir: null, | |
disabled: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
download: HAS_OVERLOADED_BOOLEAN_VALUE, | |
draggable: null, | |
encType: null, | |
form: MUST_USE_ATTRIBUTE, | |
formAction: MUST_USE_ATTRIBUTE, | |
formEncType: MUST_USE_ATTRIBUTE, | |
formMethod: MUST_USE_ATTRIBUTE, | |
formNoValidate: HAS_BOOLEAN_VALUE, | |
formTarget: MUST_USE_ATTRIBUTE, | |
frameBorder: MUST_USE_ATTRIBUTE, | |
headers: null, | |
height: MUST_USE_ATTRIBUTE, | |
hidden: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
high: null, | |
href: null, | |
hrefLang: null, | |
htmlFor: null, | |
httpEquiv: null, | |
icon: null, | |
id: MUST_USE_PROPERTY, | |
inputMode: MUST_USE_ATTRIBUTE, | |
integrity: null, | |
is: MUST_USE_ATTRIBUTE, | |
keyParams: MUST_USE_ATTRIBUTE, | |
keyType: MUST_USE_ATTRIBUTE, | |
kind: null, | |
label: null, | |
lang: null, | |
list: MUST_USE_ATTRIBUTE, | |
loop: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
low: null, | |
manifest: MUST_USE_ATTRIBUTE, | |
marginHeight: null, | |
marginWidth: null, | |
max: null, | |
maxLength: MUST_USE_ATTRIBUTE, | |
media: MUST_USE_ATTRIBUTE, | |
mediaGroup: null, | |
method: null, | |
min: null, | |
minLength: MUST_USE_ATTRIBUTE, | |
multiple: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
muted: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
name: null, | |
nonce: MUST_USE_ATTRIBUTE, | |
noValidate: HAS_BOOLEAN_VALUE, | |
open: HAS_BOOLEAN_VALUE, | |
optimum: null, | |
pattern: null, | |
placeholder: null, | |
poster: null, | |
preload: null, | |
radioGroup: null, | |
readOnly: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
rel: null, | |
required: HAS_BOOLEAN_VALUE, | |
reversed: HAS_BOOLEAN_VALUE, | |
role: MUST_USE_ATTRIBUTE, | |
rows: MUST_USE_ATTRIBUTE | HAS_POSITIVE_NUMERIC_VALUE, | |
rowSpan: null, | |
sandbox: null, | |
scope: null, | |
scoped: HAS_BOOLEAN_VALUE, | |
scrolling: null, | |
seamless: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
selected: MUST_USE_PROPERTY | HAS_BOOLEAN_VALUE, | |
shape: null, | |
size: MUST_USE_ATTRIBUTE | HAS_POSITIVE_NUMERIC_VALUE, | |
sizes: MUST_USE_ATTRIBUTE, | |
span: HAS_POSITIVE_NUMERIC_VALUE, | |
spellCheck: null, | |
src: null, | |
srcDoc: MUST_USE_PROPERTY, | |
srcLang: null, | |
srcSet: MUST_USE_ATTRIBUTE, | |
start: HAS_NUMERIC_VALUE, | |
step: null, | |
style: null, | |
summary: null, | |
tabIndex: null, | |
target: null, | |
title: null, | |
type: null, | |
useMap: null, | |
value: MUST_USE_PROPERTY | HAS_SIDE_EFFECTS, | |
width: MUST_USE_ATTRIBUTE, | |
wmode: MUST_USE_ATTRIBUTE, | |
wrap: null, | |
/** | |
* RDFa Properties | |
*/ | |
about: MUST_USE_ATTRIBUTE, | |
datatype: MUST_USE_ATTRIBUTE, | |
inlist: MUST_USE_ATTRIBUTE, | |
prefix: MUST_USE_ATTRIBUTE, | |
// property is also supported for OpenGraph in meta tags. | |
property: MUST_USE_ATTRIBUTE, | |
resource: MUST_USE_ATTRIBUTE, | |
'typeof': MUST_USE_ATTRIBUTE, | |
vocab: MUST_USE_ATTRIBUTE, | |
/** | |
* Non-standard Properties | |
*/ | |
// autoCapitalize and autoCorrect are supported in Mobile Safari for | |
// keyboard hints. | |
autoCapitalize: MUST_USE_ATTRIBUTE, | |
autoCorrect: MUST_USE_ATTRIBUTE, | |
// autoSave allows WebKit/Blink to persist values of input fields on page reloads | |
autoSave: null, | |
// color is for Safari mask-icon link | |
color: null, | |
// itemProp, itemScope, itemType are for | |
// Microdata support. See http://schema.org/docs/gs.html | |
itemProp: MUST_USE_ATTRIBUTE, | |
itemScope: MUST_USE_ATTRIBUTE | HAS_BOOLEAN_VALUE, | |
itemType: MUST_USE_ATTRIBUTE, | |
// itemID and itemRef are for Microdata support as well but | |
// only specified in the the WHATWG spec document. See | |
// https://html.spec.whatwg.org/multipage/microdata.html#microdata-dom-api | |
itemID: MUST_USE_ATTRIBUTE, | |
itemRef: MUST_USE_ATTRIBUTE, | |
// results show looking glass icon and recent searches on input | |
// search fields in WebKit/Blink | |
results: null, | |
// IE-only attribute that specifies security restrictions on an iframe | |
// as an alternative to the sandbox attribute on IE<10 | |
security: MUST_USE_ATTRIBUTE, | |
// IE-only attribute that controls focus behavior | |
unselectable: MUST_USE_ATTRIBUTE | |
}, | |
DOMAttributeNames: { | |
acceptCharset: 'accept-charset', | |
className: 'class', | |
htmlFor: 'for', | |
httpEquiv: 'http-equiv' | |
}, | |
DOMPropertyNames: { | |
autoComplete: 'autocomplete', | |
autoFocus: 'autofocus', | |
autoPlay: 'autoplay', | |
autoSave: 'autosave', | |
// `encoding` is equivalent to `enctype`, IE8 lacks an `enctype` setter. | |
// http://www.w3.org/TR/html5/forms.html#dom-fs-encoding | |
encType: 'encoding', | |
hrefLang: 'hreflang', | |
radioGroup: 'radiogroup', | |
spellCheck: 'spellcheck', | |
srcDoc: 'srcdoc', | |
srcSet: 'srcset' | |
} | |
}; | |
module.exports = HTMLDOMPropertyConfig; | |
/***/ }, | |
/* 146 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactBrowserComponentMixin | |
*/ | |
'use strict'; | |
var ReactInstanceMap = __webpack_require__(104); | |
var findDOMNode = __webpack_require__(147); | |
var warning = __webpack_require__(83); | |
var didWarnKey = '_getDOMNodeDidWarn'; | |
var ReactBrowserComponentMixin = { | |
/** | |
* Returns the DOM node rendered by this component. | |
* | |
* @return {DOMElement} The root node of this component. | |
* @final | |
* @protected | |
*/ | |
getDOMNode: function () { | |
process.env.NODE_ENV !== 'production' ? warning(this.constructor[didWarnKey], '%s.getDOMNode(...) is deprecated. Please use ' + 'ReactDOM.findDOMNode(instance) instead.', ReactInstanceMap.get(this).getName() || this.tagName || 'Unknown') : undefined; | |
this.constructor[didWarnKey] = true; | |
return findDOMNode(this); | |
} | |
}; | |
module.exports = ReactBrowserComponentMixin; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 147 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule findDOMNode | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactInstanceMap = __webpack_require__(104); | |
var ReactMount = __webpack_require__(86); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
/** | |
* Returns the DOM node rendered by this element. | |
* | |
* @param {ReactComponent|DOMElement} componentOrElement | |
* @return {?DOMElement} The root node of this element. | |
*/ | |
function findDOMNode(componentOrElement) { | |
if (process.env.NODE_ENV !== 'production') { | |
var owner = ReactCurrentOwner.current; | |
if (owner !== null) { | |
process.env.NODE_ENV !== 'production' ? warning(owner._warnedAboutRefsInRender, '%s is accessing getDOMNode or findDOMNode inside its render(). ' + 'render() should be a pure function of props and state. It should ' + 'never access something that requires stale data from the previous ' + 'render, such as refs. Move this logic to componentDidMount and ' + 'componentDidUpdate instead.', owner.getName() || 'A component') : undefined; | |
owner._warnedAboutRefsInRender = true; | |
} | |
} | |
if (componentOrElement == null) { | |
return null; | |
} | |
if (componentOrElement.nodeType === 1) { | |
return componentOrElement; | |
} | |
if (ReactInstanceMap.has(componentOrElement)) { | |
return ReactMount.getNodeFromInstance(componentOrElement); | |
} | |
!(componentOrElement.render == null || typeof componentOrElement.render !== 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'findDOMNode was called on an unmounted component.') : invariant(false) : undefined; | |
true ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Element appears to be neither ReactComponent nor DOMNode (keys: %s)', Object.keys(componentOrElement)) : invariant(false) : undefined; | |
} | |
module.exports = findDOMNode; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 148 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDefaultBatchingStrategy | |
*/ | |
'use strict'; | |
var ReactUpdates = __webpack_require__(111); | |
var Transaction = __webpack_require__(114); | |
var assign = __webpack_require__(29); | |
var emptyFunction = __webpack_require__(73); | |
var RESET_BATCHED_UPDATES = { | |
initialize: emptyFunction, | |
close: function () { | |
ReactDefaultBatchingStrategy.isBatchingUpdates = false; | |
} | |
}; | |
var FLUSH_BATCHED_UPDATES = { | |
initialize: emptyFunction, | |
close: ReactUpdates.flushBatchedUpdates.bind(ReactUpdates) | |
}; | |
var TRANSACTION_WRAPPERS = [FLUSH_BATCHED_UPDATES, RESET_BATCHED_UPDATES]; | |
function ReactDefaultBatchingStrategyTransaction() { | |
this.reinitializeTransaction(); | |
} | |
assign(ReactDefaultBatchingStrategyTransaction.prototype, Transaction.Mixin, { | |
getTransactionWrappers: function () { | |
return TRANSACTION_WRAPPERS; | |
} | |
}); | |
var transaction = new ReactDefaultBatchingStrategyTransaction(); | |
var ReactDefaultBatchingStrategy = { | |
isBatchingUpdates: false, | |
/** | |
* Call the provided function in a context within which calls to `setState` | |
* and friends are batched such that components aren't updated unnecessarily. | |
*/ | |
batchedUpdates: function (callback, a, b, c, d, e) { | |
var alreadyBatchingUpdates = ReactDefaultBatchingStrategy.isBatchingUpdates; | |
ReactDefaultBatchingStrategy.isBatchingUpdates = true; | |
// The code is written this way to avoid extra allocations | |
if (alreadyBatchingUpdates) { | |
callback(a, b, c, d, e); | |
} else { | |
transaction.perform(callback, null, a, b, c, d, e); | |
} | |
} | |
}; | |
module.exports = ReactDefaultBatchingStrategy; | |
/***/ }, | |
/* 149 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMComponent | |
* @typechecks static-only | |
*/ | |
/* global hasOwnProperty:true */ | |
'use strict'; | |
var AutoFocusUtils = __webpack_require__(150); | |
var CSSPropertyOperations = __webpack_require__(152); | |
var DOMProperty = __webpack_require__(81); | |
var DOMPropertyOperations = __webpack_require__(80); | |
var EventConstants = __webpack_require__(88); | |
var ReactBrowserEventEmitter = __webpack_require__(87); | |
var ReactComponentBrowserEnvironment = __webpack_require__(84); | |
var ReactDOMButton = __webpack_require__(160); | |
var ReactDOMInput = __webpack_require__(161); | |
var ReactDOMOption = __webpack_require__(165); | |
var ReactDOMSelect = __webpack_require__(168); | |
var ReactDOMTextarea = __webpack_require__(169); | |
var ReactMount = __webpack_require__(86); | |
var ReactMultiChild = __webpack_require__(170); | |
var ReactPerf = __webpack_require__(76); | |
var ReactUpdateQueue = __webpack_require__(110); | |
var assign = __webpack_require__(29); | |
var canDefineProperty = __webpack_require__(100); | |
var escapeTextContentForBrowser = __webpack_require__(79); | |
var invariant = __webpack_require__(31); | |
var isEventSupported = __webpack_require__(97); | |
var keyOf = __webpack_require__(30); | |
var setInnerHTML = __webpack_require__(77); | |
var setTextContent = __webpack_require__(78); | |
var shallowEqual = __webpack_require__(173); | |
var validateDOMNesting = __webpack_require__(127); | |
var warning = __webpack_require__(83); | |
var deleteListener = ReactBrowserEventEmitter.deleteListener; | |
var listenTo = ReactBrowserEventEmitter.listenTo; | |
var registrationNameModules = ReactBrowserEventEmitter.registrationNameModules; | |
// For quickly matching children type, to test if can be treated as content. | |
var CONTENT_TYPES = { 'string': true, 'number': true }; | |
var CHILDREN = keyOf({ children: null }); | |
var STYLE = keyOf({ style: null }); | |
var HTML = keyOf({ __html: null }); | |
var ELEMENT_NODE_TYPE = 1; | |
function getDeclarationErrorAddendum(internalInstance) { | |
if (internalInstance) { | |
var owner = internalInstance._currentElement._owner || null; | |
if (owner) { | |
var name = owner.getName(); | |
if (name) { | |
return ' This DOM node was rendered by `' + name + '`.'; | |
} | |
} | |
} | |
return ''; | |
} | |
var legacyPropsDescriptor; | |
if (process.env.NODE_ENV !== 'production') { | |
legacyPropsDescriptor = { | |
props: { | |
enumerable: false, | |
get: function () { | |
var component = this._reactInternalComponent; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .props of a DOM node; instead, ' + 'recreate the props as `render` did originally or read the DOM ' + 'properties/attributes directly from this node (e.g., ' + 'this.refs.box.className).%s', getDeclarationErrorAddendum(component)) : undefined; | |
return component._currentElement.props; | |
} | |
} | |
}; | |
} | |
function legacyGetDOMNode() { | |
if (process.env.NODE_ENV !== 'production') { | |
var component = this._reactInternalComponent; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .getDOMNode() of a DOM node; ' + 'instead, use the node directly.%s', getDeclarationErrorAddendum(component)) : undefined; | |
} | |
return this; | |
} | |
function legacyIsMounted() { | |
var component = this._reactInternalComponent; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .isMounted() of a DOM node.%s', getDeclarationErrorAddendum(component)) : undefined; | |
} | |
return !!component; | |
} | |
function legacySetStateEtc() { | |
if (process.env.NODE_ENV !== 'production') { | |
var component = this._reactInternalComponent; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .setState(), .replaceState(), or ' + '.forceUpdate() of a DOM node. This is a no-op.%s', getDeclarationErrorAddendum(component)) : undefined; | |
} | |
} | |
function legacySetProps(partialProps, callback) { | |
var component = this._reactInternalComponent; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .setProps() of a DOM node. ' + 'Instead, call ReactDOM.render again at the top level.%s', getDeclarationErrorAddendum(component)) : undefined; | |
} | |
if (!component) { | |
return; | |
} | |
ReactUpdateQueue.enqueueSetPropsInternal(component, partialProps); | |
if (callback) { | |
ReactUpdateQueue.enqueueCallbackInternal(component, callback); | |
} | |
} | |
function legacyReplaceProps(partialProps, callback) { | |
var component = this._reactInternalComponent; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'ReactDOMComponent: Do not access .replaceProps() of a DOM node. ' + 'Instead, call ReactDOM.render again at the top level.%s', getDeclarationErrorAddendum(component)) : undefined; | |
} | |
if (!component) { | |
return; | |
} | |
ReactUpdateQueue.enqueueReplacePropsInternal(component, partialProps); | |
if (callback) { | |
ReactUpdateQueue.enqueueCallbackInternal(component, callback); | |
} | |
} | |
function friendlyStringify(obj) { | |
if (typeof obj === 'object') { | |
if (Array.isArray(obj)) { | |
return '[' + obj.map(friendlyStringify).join(', ') + ']'; | |
} else { | |
var pairs = []; | |
for (var key in obj) { | |
if (Object.prototype.hasOwnProperty.call(obj, key)) { | |
var keyEscaped = /^[a-z$_][\w$_]*$/i.test(key) ? key : JSON.stringify(key); | |
pairs.push(keyEscaped + ': ' + friendlyStringify(obj[key])); | |
} | |
} | |
return '{' + pairs.join(', ') + '}'; | |
} | |
} else if (typeof obj === 'string') { | |
return JSON.stringify(obj); | |
} else if (typeof obj === 'function') { | |
return '[function object]'; | |
} | |
// Differs from JSON.stringify in that undefined becauses undefined and that | |
// inf and nan don't become null | |
return String(obj); | |
} | |
var styleMutationWarning = {}; | |
function checkAndWarnForMutatedStyle(style1, style2, component) { | |
if (style1 == null || style2 == null) { | |
return; | |
} | |
if (shallowEqual(style1, style2)) { | |
return; | |
} | |
var componentName = component._tag; | |
var owner = component._currentElement._owner; | |
var ownerName; | |
if (owner) { | |
ownerName = owner.getName(); | |
} | |
var hash = ownerName + '|' + componentName; | |
if (styleMutationWarning.hasOwnProperty(hash)) { | |
return; | |
} | |
styleMutationWarning[hash] = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, '`%s` was passed a style object that has previously been mutated. ' + 'Mutating `style` is deprecated. Consider cloning it beforehand. Check ' + 'the `render` %s. Previous style: %s. Mutated style: %s.', componentName, owner ? 'of `' + ownerName + '`' : 'using <' + componentName + '>', friendlyStringify(style1), friendlyStringify(style2)) : undefined; | |
} | |
/** | |
* @param {object} component | |
* @param {?object} props | |
*/ | |
function assertValidProps(component, props) { | |
if (!props) { | |
return; | |
} | |
// Note the use of `==` which checks for null or undefined. | |
if (process.env.NODE_ENV !== 'production') { | |
if (voidElementTags[component._tag]) { | |
process.env.NODE_ENV !== 'production' ? warning(props.children == null && props.dangerouslySetInnerHTML == null, '%s is a void element tag and must not have `children` or ' + 'use `props.dangerouslySetInnerHTML`.%s', component._tag, component._currentElement._owner ? ' Check the render method of ' + component._currentElement._owner.getName() + '.' : '') : undefined; | |
} | |
} | |
if (props.dangerouslySetInnerHTML != null) { | |
!(props.children == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Can only set one of `children` or `props.dangerouslySetInnerHTML`.') : invariant(false) : undefined; | |
!(typeof props.dangerouslySetInnerHTML === 'object' && HTML in props.dangerouslySetInnerHTML) ? process.env.NODE_ENV !== 'production' ? invariant(false, '`props.dangerouslySetInnerHTML` must be in the form `{__html: ...}`. ' + 'Please visit https://fb.me/react-invariant-dangerously-set-inner-html ' + 'for more information.') : invariant(false) : undefined; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(props.innerHTML == null, 'Directly setting property `innerHTML` is not permitted. ' + 'For more information, lookup documentation on `dangerouslySetInnerHTML`.') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!props.contentEditable || props.children == null, 'A component is `contentEditable` and contains `children` managed by ' + 'React. It is now your responsibility to guarantee that none of ' + 'those nodes are unexpectedly modified or duplicated. This is ' + 'probably not intentional.') : undefined; | |
} | |
!(props.style == null || typeof props.style === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'The `style` prop expects a mapping from style properties to values, ' + 'not a string. For example, style={{marginRight: spacing + \'em\'}} when ' + 'using JSX.%s', getDeclarationErrorAddendum(component)) : invariant(false) : undefined; | |
} | |
function enqueuePutListener(id, registrationName, listener, transaction) { | |
if (process.env.NODE_ENV !== 'production') { | |
// IE8 has no API for event capturing and the `onScroll` event doesn't | |
// bubble. | |
process.env.NODE_ENV !== 'production' ? warning(registrationName !== 'onScroll' || isEventSupported('scroll', true), 'This browser doesn\'t support the `onScroll` event') : undefined; | |
} | |
var container = ReactMount.findReactContainerForID(id); | |
if (container) { | |
var doc = container.nodeType === ELEMENT_NODE_TYPE ? container.ownerDocument : container; | |
listenTo(registrationName, doc); | |
} | |
transaction.getReactMountReady().enqueue(putListener, { | |
id: id, | |
registrationName: registrationName, | |
listener: listener | |
}); | |
} | |
function putListener() { | |
var listenerToPut = this; | |
ReactBrowserEventEmitter.putListener(listenerToPut.id, listenerToPut.registrationName, listenerToPut.listener); | |
} | |
// There are so many media events, it makes sense to just | |
// maintain a list rather than create a `trapBubbledEvent` for each | |
var mediaEvents = { | |
topAbort: 'abort', | |
topCanPlay: 'canplay', | |
topCanPlayThrough: 'canplaythrough', | |
topDurationChange: 'durationchange', | |
topEmptied: 'emptied', | |
topEncrypted: 'encrypted', | |
topEnded: 'ended', | |
topError: 'error', | |
topLoadedData: 'loadeddata', | |
topLoadedMetadata: 'loadedmetadata', | |
topLoadStart: 'loadstart', | |
topPause: 'pause', | |
topPlay: 'play', | |
topPlaying: 'playing', | |
topProgress: 'progress', | |
topRateChange: 'ratechange', | |
topSeeked: 'seeked', | |
topSeeking: 'seeking', | |
topStalled: 'stalled', | |
topSuspend: 'suspend', | |
topTimeUpdate: 'timeupdate', | |
topVolumeChange: 'volumechange', | |
topWaiting: 'waiting' | |
}; | |
function trapBubbledEventsLocal() { | |
var inst = this; | |
// If a component renders to null or if another component fatals and causes | |
// the state of the tree to be corrupted, `node` here can be null. | |
!inst._rootNodeID ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Must be mounted to trap events') : invariant(false) : undefined; | |
var node = ReactMount.getNode(inst._rootNodeID); | |
!node ? process.env.NODE_ENV !== 'production' ? invariant(false, 'trapBubbledEvent(...): Requires node to be rendered.') : invariant(false) : undefined; | |
switch (inst._tag) { | |
case 'iframe': | |
inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topLoad, 'load', node)]; | |
break; | |
case 'video': | |
case 'audio': | |
inst._wrapperState.listeners = []; | |
// create listener for each media event | |
for (var event in mediaEvents) { | |
if (mediaEvents.hasOwnProperty(event)) { | |
inst._wrapperState.listeners.push(ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes[event], mediaEvents[event], node)); | |
} | |
} | |
break; | |
case 'img': | |
inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topError, 'error', node), ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topLoad, 'load', node)]; | |
break; | |
case 'form': | |
inst._wrapperState.listeners = [ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topReset, 'reset', node), ReactBrowserEventEmitter.trapBubbledEvent(EventConstants.topLevelTypes.topSubmit, 'submit', node)]; | |
break; | |
} | |
} | |
function mountReadyInputWrapper() { | |
ReactDOMInput.mountReadyWrapper(this); | |
} | |
function postUpdateSelectWrapper() { | |
ReactDOMSelect.postUpdateWrapper(this); | |
} | |
// For HTML, certain tags should omit their close tag. We keep a whitelist for | |
// those special cased tags. | |
var omittedCloseTags = { | |
'area': true, | |
'base': true, | |
'br': true, | |
'col': true, | |
'embed': true, | |
'hr': true, | |
'img': true, | |
'input': true, | |
'keygen': true, | |
'link': true, | |
'meta': true, | |
'param': true, | |
'source': true, | |
'track': true, | |
'wbr': true | |
}; | |
// NOTE: menuitem's close tag should be omitted, but that causes problems. | |
var newlineEatingTags = { | |
'listing': true, | |
'pre': true, | |
'textarea': true | |
}; | |
// For HTML, certain tags cannot have children. This has the same purpose as | |
// `omittedCloseTags` except that `menuitem` should still have its closing tag. | |
var voidElementTags = assign({ | |
'menuitem': true | |
}, omittedCloseTags); | |
// We accept any tag to be rendered but since this gets injected into arbitrary | |
// HTML, we want to make sure that it's a safe tag. | |
// http://www.w3.org/TR/REC-xml/#NT-Name | |
var VALID_TAG_REGEX = /^[a-zA-Z][a-zA-Z:_\.\-\d]*$/; // Simplified subset | |
var validatedTagCache = {}; | |
var hasOwnProperty = ({}).hasOwnProperty; | |
function validateDangerousTag(tag) { | |
if (!hasOwnProperty.call(validatedTagCache, tag)) { | |
!VALID_TAG_REGEX.test(tag) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Invalid tag: %s', tag) : invariant(false) : undefined; | |
validatedTagCache[tag] = true; | |
} | |
} | |
function processChildContextDev(context, inst) { | |
// Pass down our tag name to child components for validation purposes | |
context = assign({}, context); | |
var info = context[validateDOMNesting.ancestorInfoContextKey]; | |
context[validateDOMNesting.ancestorInfoContextKey] = validateDOMNesting.updatedAncestorInfo(info, inst._tag, inst); | |
return context; | |
} | |
function isCustomComponent(tagName, props) { | |
return tagName.indexOf('-') >= 0 || props.is != null; | |
} | |
/** | |
* Creates a new React class that is idempotent and capable of containing other | |
* React components. It accepts event listeners and DOM properties that are | |
* valid according to `DOMProperty`. | |
* | |
* - Event listeners: `onClick`, `onMouseDown`, etc. | |
* - DOM properties: `className`, `name`, `title`, etc. | |
* | |
* The `style` property functions differently from the DOM API. It accepts an | |
* object mapping of style properties to values. | |
* | |
* @constructor ReactDOMComponent | |
* @extends ReactMultiChild | |
*/ | |
function ReactDOMComponent(tag) { | |
validateDangerousTag(tag); | |
this._tag = tag.toLowerCase(); | |
this._renderedChildren = null; | |
this._previousStyle = null; | |
this._previousStyleCopy = null; | |
this._rootNodeID = null; | |
this._wrapperState = null; | |
this._topLevelWrapper = null; | |
this._nodeWithLegacyProperties = null; | |
if (process.env.NODE_ENV !== 'production') { | |
this._unprocessedContextDev = null; | |
this._processedContextDev = null; | |
} | |
} | |
ReactDOMComponent.displayName = 'ReactDOMComponent'; | |
ReactDOMComponent.Mixin = { | |
construct: function (element) { | |
this._currentElement = element; | |
}, | |
/** | |
* Generates root tag markup then recurses. This method has side effects and | |
* is not idempotent. | |
* | |
* @internal | |
* @param {string} rootID The root DOM ID for this node. | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @param {object} context | |
* @return {string} The computed markup. | |
*/ | |
mountComponent: function (rootID, transaction, context) { | |
this._rootNodeID = rootID; | |
var props = this._currentElement.props; | |
switch (this._tag) { | |
case 'iframe': | |
case 'img': | |
case 'form': | |
case 'video': | |
case 'audio': | |
this._wrapperState = { | |
listeners: null | |
}; | |
transaction.getReactMountReady().enqueue(trapBubbledEventsLocal, this); | |
break; | |
case 'button': | |
props = ReactDOMButton.getNativeProps(this, props, context); | |
break; | |
case 'input': | |
ReactDOMInput.mountWrapper(this, props, context); | |
props = ReactDOMInput.getNativeProps(this, props, context); | |
break; | |
case 'option': | |
ReactDOMOption.mountWrapper(this, props, context); | |
props = ReactDOMOption.getNativeProps(this, props, context); | |
break; | |
case 'select': | |
ReactDOMSelect.mountWrapper(this, props, context); | |
props = ReactDOMSelect.getNativeProps(this, props, context); | |
context = ReactDOMSelect.processChildContext(this, props, context); | |
break; | |
case 'textarea': | |
ReactDOMTextarea.mountWrapper(this, props, context); | |
props = ReactDOMTextarea.getNativeProps(this, props, context); | |
break; | |
} | |
assertValidProps(this, props); | |
if (process.env.NODE_ENV !== 'production') { | |
if (context[validateDOMNesting.ancestorInfoContextKey]) { | |
validateDOMNesting(this._tag, this, context[validateDOMNesting.ancestorInfoContextKey]); | |
} | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
this._unprocessedContextDev = context; | |
this._processedContextDev = processChildContextDev(context, this); | |
context = this._processedContextDev; | |
} | |
var mountImage; | |
if (transaction.useCreateElement) { | |
var ownerDocument = context[ReactMount.ownerDocumentContextKey]; | |
var el = ownerDocument.createElement(this._currentElement.type); | |
DOMPropertyOperations.setAttributeForID(el, this._rootNodeID); | |
// Populate node cache | |
ReactMount.getID(el); | |
this._updateDOMProperties({}, props, transaction, el); | |
this._createInitialChildren(transaction, props, context, el); | |
mountImage = el; | |
} else { | |
var tagOpen = this._createOpenTagMarkupAndPutListeners(transaction, props); | |
var tagContent = this._createContentMarkup(transaction, props, context); | |
if (!tagContent && omittedCloseTags[this._tag]) { | |
mountImage = tagOpen + '/>'; | |
} else { | |
mountImage = tagOpen + '>' + tagContent + '</' + this._currentElement.type + '>'; | |
} | |
} | |
switch (this._tag) { | |
case 'input': | |
transaction.getReactMountReady().enqueue(mountReadyInputWrapper, this); | |
// falls through | |
case 'button': | |
case 'select': | |
case 'textarea': | |
if (props.autoFocus) { | |
transaction.getReactMountReady().enqueue(AutoFocusUtils.focusDOMComponent, this); | |
} | |
break; | |
} | |
return mountImage; | |
}, | |
/** | |
* Creates markup for the open tag and all attributes. | |
* | |
* This method has side effects because events get registered. | |
* | |
* Iterating over object properties is faster than iterating over arrays. | |
* @see http://jsperf.com/obj-vs-arr-iteration | |
* | |
* @private | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @param {object} props | |
* @return {string} Markup of opening tag. | |
*/ | |
_createOpenTagMarkupAndPutListeners: function (transaction, props) { | |
var ret = '<' + this._currentElement.type; | |
for (var propKey in props) { | |
if (!props.hasOwnProperty(propKey)) { | |
continue; | |
} | |
var propValue = props[propKey]; | |
if (propValue == null) { | |
continue; | |
} | |
if (registrationNameModules.hasOwnProperty(propKey)) { | |
if (propValue) { | |
enqueuePutListener(this._rootNodeID, propKey, propValue, transaction); | |
} | |
} else { | |
if (propKey === STYLE) { | |
if (propValue) { | |
if (process.env.NODE_ENV !== 'production') { | |
// See `_updateDOMProperties`. style block | |
this._previousStyle = propValue; | |
} | |
propValue = this._previousStyleCopy = assign({}, props.style); | |
} | |
propValue = CSSPropertyOperations.createMarkupForStyles(propValue); | |
} | |
var markup = null; | |
if (this._tag != null && isCustomComponent(this._tag, props)) { | |
if (propKey !== CHILDREN) { | |
markup = DOMPropertyOperations.createMarkupForCustomAttribute(propKey, propValue); | |
} | |
} else { | |
markup = DOMPropertyOperations.createMarkupForProperty(propKey, propValue); | |
} | |
if (markup) { | |
ret += ' ' + markup; | |
} | |
} | |
} | |
// For static pages, no need to put React ID and checksum. Saves lots of | |
// bytes. | |
if (transaction.renderToStaticMarkup) { | |
return ret; | |
} | |
var markupForID = DOMPropertyOperations.createMarkupForID(this._rootNodeID); | |
return ret + ' ' + markupForID; | |
}, | |
/** | |
* Creates markup for the content between the tags. | |
* | |
* @private | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @param {object} props | |
* @param {object} context | |
* @return {string} Content markup. | |
*/ | |
_createContentMarkup: function (transaction, props, context) { | |
var ret = ''; | |
// Intentional use of != to avoid catching zero/false. | |
var innerHTML = props.dangerouslySetInnerHTML; | |
if (innerHTML != null) { | |
if (innerHTML.__html != null) { | |
ret = innerHTML.__html; | |
} | |
} else { | |
var contentToUse = CONTENT_TYPES[typeof props.children] ? props.children : null; | |
var childrenToUse = contentToUse != null ? null : props.children; | |
if (contentToUse != null) { | |
// TODO: Validate that text is allowed as a child of this node | |
ret = escapeTextContentForBrowser(contentToUse); | |
} else if (childrenToUse != null) { | |
var mountImages = this.mountChildren(childrenToUse, transaction, context); | |
ret = mountImages.join(''); | |
} | |
} | |
if (newlineEatingTags[this._tag] && ret.charAt(0) === ' | |
') { | |
// text/html ignores the first character in these tags if it's a newline | |
// Prefer to break application/xml over text/html (for now) by adding | |
// a newline specifically to get eaten by the parser. (Alternately for | |
// textareas, replacing "^ | |
" with " | |
" doesn't get eaten, and the first | |
// | |
is normalized out by HTMLTextAreaElement#value.) | |
// See: <http://www.w3.org/TR/html-polyglot/#newlines-in-textarea-and-pre> | |
// See: <http://www.w3.org/TR/html5/syntax.html#element-restrictions> | |
// See: <http://www.w3.org/TR/html5/syntax.html#newlines> | |
// See: Parsing of "textarea" "listing" and "pre" elements | |
// from <http://www.w3.org/TR/html5/syntax.html#parsing-main-inbody> | |
return ' | |
' + ret; | |
} else { | |
return ret; | |
} | |
}, | |
_createInitialChildren: function (transaction, props, context, el) { | |
// Intentional use of != to avoid catching zero/false. | |
var innerHTML = props.dangerouslySetInnerHTML; | |
if (innerHTML != null) { | |
if (innerHTML.__html != null) { | |
setInnerHTML(el, innerHTML.__html); | |
} | |
} else { | |
var contentToUse = CONTENT_TYPES[typeof props.children] ? props.children : null; | |
var childrenToUse = contentToUse != null ? null : props.children; | |
if (contentToUse != null) { | |
// TODO: Validate that text is allowed as a child of this node | |
setTextContent(el, contentToUse); | |
} else if (childrenToUse != null) { | |
var mountImages = this.mountChildren(childrenToUse, transaction, context); | |
for (var i = 0; i < mountImages.length; i++) { | |
el.appendChild(mountImages[i]); | |
} | |
} | |
} | |
}, | |
/** | |
* Receives a next element and updates the component. | |
* | |
* @internal | |
* @param {ReactElement} nextElement | |
* @param {ReactReconcileTransaction|ReactServerRenderingTransaction} transaction | |
* @param {object} context | |
*/ | |
receiveComponent: function (nextElement, transaction, context) { | |
var prevElement = this._currentElement; | |
this._currentElement = nextElement; | |
this.updateComponent(transaction, prevElement, nextElement, context); | |
}, | |
/** | |
* Updates a native DOM component after it has already been allocated and | |
* attached to the DOM. Reconciles the root DOM node, then recurses. | |
* | |
* @param {ReactReconcileTransaction} transaction | |
* @param {ReactElement} prevElement | |
* @param {ReactElement} nextElement | |
* @internal | |
* @overridable | |
*/ | |
updateComponent: function (transaction, prevElement, nextElement, context) { | |
var lastProps = prevElement.props; | |
var nextProps = this._currentElement.props; | |
switch (this._tag) { | |
case 'button': | |
lastProps = ReactDOMButton.getNativeProps(this, lastProps); | |
nextProps = ReactDOMButton.getNativeProps(this, nextProps); | |
break; | |
case 'input': | |
ReactDOMInput.updateWrapper(this); | |
lastProps = ReactDOMInput.getNativeProps(this, lastProps); | |
nextProps = ReactDOMInput.getNativeProps(this, nextProps); | |
break; | |
case 'option': | |
lastProps = ReactDOMOption.getNativeProps(this, lastProps); | |
nextProps = ReactDOMOption.getNativeProps(this, nextProps); | |
break; | |
case 'select': | |
lastProps = ReactDOMSelect.getNativeProps(this, lastProps); | |
nextProps = ReactDOMSelect.getNativeProps(this, nextProps); | |
break; | |
case 'textarea': | |
ReactDOMTextarea.updateWrapper(this); | |
lastProps = ReactDOMTextarea.getNativeProps(this, lastProps); | |
nextProps = ReactDOMTextarea.getNativeProps(this, nextProps); | |
break; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
// If the context is reference-equal to the old one, pass down the same | |
// processed object so the update bailout in ReactReconciler behaves | |
// correctly (and identically in dev and prod). See #5005. | |
if (this._unprocessedContextDev !== context) { | |
this._unprocessedContextDev = context; | |
this._processedContextDev = processChildContextDev(context, this); | |
} | |
context = this._processedContextDev; | |
} | |
assertValidProps(this, nextProps); | |
this._updateDOMProperties(lastProps, nextProps, transaction, null); | |
this._updateDOMChildren(lastProps, nextProps, transaction, context); | |
if (!canDefineProperty && this._nodeWithLegacyProperties) { | |
this._nodeWithLegacyProperties.props = nextProps; | |
} | |
if (this._tag === 'select') { | |
// <select> value update needs to occur after <option> children | |
// reconciliation | |
transaction.getReactMountReady().enqueue(postUpdateSelectWrapper, this); | |
} | |
}, | |
/** | |
* Reconciles the properties by detecting differences in property values and | |
* updating the DOM as necessary. This function is probably the single most | |
* critical path for performance optimization. | |
* | |
* TODO: Benchmark whether checking for changed values in memory actually | |
* improves performance (especially statically positioned elements). | |
* TODO: Benchmark the effects of putting this at the top since 99% of props | |
* do not change for a given reconciliation. | |
* TODO: Benchmark areas that can be improved with caching. | |
* | |
* @private | |
* @param {object} lastProps | |
* @param {object} nextProps | |
* @param {ReactReconcileTransaction} transaction | |
* @param {?DOMElement} node | |
*/ | |
_updateDOMProperties: function (lastProps, nextProps, transaction, node) { | |
var propKey; | |
var styleName; | |
var styleUpdates; | |
for (propKey in lastProps) { | |
if (nextProps.hasOwnProperty(propKey) || !lastProps.hasOwnProperty(propKey)) { | |
continue; | |
} | |
if (propKey === STYLE) { | |
var lastStyle = this._previousStyleCopy; | |
for (styleName in lastStyle) { | |
if (lastStyle.hasOwnProperty(styleName)) { | |
styleUpdates = styleUpdates || {}; | |
styleUpdates[styleName] = ''; | |
} | |
} | |
this._previousStyleCopy = null; | |
} else if (registrationNameModules.hasOwnProperty(propKey)) { | |
if (lastProps[propKey]) { | |
// Only call deleteListener if there was a listener previously or | |
// else willDeleteListener gets called when there wasn't actually a | |
// listener (e.g., onClick={null}) | |
deleteListener(this._rootNodeID, propKey); | |
} | |
} else if (DOMProperty.properties[propKey] || DOMProperty.isCustomAttribute(propKey)) { | |
if (!node) { | |
node = ReactMount.getNode(this._rootNodeID); | |
} | |
DOMPropertyOperations.deleteValueForProperty(node, propKey); | |
} | |
} | |
for (propKey in nextProps) { | |
var nextProp = nextProps[propKey]; | |
var lastProp = propKey === STYLE ? this._previousStyleCopy : lastProps[propKey]; | |
if (!nextProps.hasOwnProperty(propKey) || nextProp === lastProp) { | |
continue; | |
} | |
if (propKey === STYLE) { | |
if (nextProp) { | |
if (process.env.NODE_ENV !== 'production') { | |
checkAndWarnForMutatedStyle(this._previousStyleCopy, this._previousStyle, this); | |
this._previousStyle = nextProp; | |
} | |
nextProp = this._previousStyleCopy = assign({}, nextProp); | |
} else { | |
this._previousStyleCopy = null; | |
} | |
if (lastProp) { | |
// Unset styles on `lastProp` but not on `nextProp`. | |
for (styleName in lastProp) { | |
if (lastProp.hasOwnProperty(styleName) && (!nextProp || !nextProp.hasOwnProperty(styleName))) { | |
styleUpdates = styleUpdates || {}; | |
styleUpdates[styleName] = ''; | |
} | |
} | |
// Update styles that changed since `lastProp`. | |
for (styleName in nextProp) { | |
if (nextProp.hasOwnProperty(styleName) && lastProp[styleName] !== nextProp[styleName]) { | |
styleUpdates = styleUpdates || {}; | |
styleUpdates[styleName] = nextProp[styleName]; | |
} | |
} | |
} else { | |
// Relies on `updateStylesByID` not mutating `styleUpdates`. | |
styleUpdates = nextProp; | |
} | |
} else if (registrationNameModules.hasOwnProperty(propKey)) { | |
if (nextProp) { | |
enqueuePutListener(this._rootNodeID, propKey, nextProp, transaction); | |
} else if (lastProp) { | |
deleteListener(this._rootNodeID, propKey); | |
} | |
} else if (isCustomComponent(this._tag, nextProps)) { | |
if (!node) { | |
node = ReactMount.getNode(this._rootNodeID); | |
} | |
if (propKey === CHILDREN) { | |
nextProp = null; | |
} | |
DOMPropertyOperations.setValueForAttribute(node, propKey, nextProp); | |
} else if (DOMProperty.properties[propKey] || DOMProperty.isCustomAttribute(propKey)) { | |
if (!node) { | |
node = ReactMount.getNode(this._rootNodeID); | |
} | |
// If we're updating to null or undefined, we should remove the property | |
// from the DOM node instead of inadvertantly setting to a string. This | |
// brings us in line with the same behavior we have on initial render. | |
if (nextProp != null) { | |
DOMPropertyOperations.setValueForProperty(node, propKey, nextProp); | |
} else { | |
DOMPropertyOperations.deleteValueForProperty(node, propKey); | |
} | |
} | |
} | |
if (styleUpdates) { | |
if (!node) { | |
node = ReactMount.getNode(this._rootNodeID); | |
} | |
CSSPropertyOperations.setValueForStyles(node, styleUpdates); | |
} | |
}, | |
/** | |
* Reconciles the children with the various properties that affect the | |
* children content. | |
* | |
* @param {object} lastProps | |
* @param {object} nextProps | |
* @param {ReactReconcileTransaction} transaction | |
* @param {object} context | |
*/ | |
_updateDOMChildren: function (lastProps, nextProps, transaction, context) { | |
var lastContent = CONTENT_TYPES[typeof lastProps.children] ? lastProps.children : null; | |
var nextContent = CONTENT_TYPES[typeof nextProps.children] ? nextProps.children : null; | |
var lastHtml = lastProps.dangerouslySetInnerHTML && lastProps.dangerouslySetInnerHTML.__html; | |
var nextHtml = nextProps.dangerouslySetInnerHTML && nextProps.dangerouslySetInnerHTML.__html; | |
// Note the use of `!=` which checks for null or undefined. | |
var lastChildren = lastContent != null ? null : lastProps.children; | |
var nextChildren = nextContent != null ? null : nextProps.children; | |
// If we're switching from children to content/html or vice versa, remove | |
// the old content | |
var lastHasContentOrHtml = lastContent != null || lastHtml != null; | |
var nextHasContentOrHtml = nextContent != null || nextHtml != null; | |
if (lastChildren != null && nextChildren == null) { | |
this.updateChildren(null, transaction, context); | |
} else if (lastHasContentOrHtml && !nextHasContentOrHtml) { | |
this.updateTextContent(''); | |
} | |
if (nextContent != null) { | |
if (lastContent !== nextContent) { | |
this.updateTextContent('' + nextContent); | |
} | |
} else if (nextHtml != null) { | |
if (lastHtml !== nextHtml) { | |
this.updateMarkup('' + nextHtml); | |
} | |
} else if (nextChildren != null) { | |
this.updateChildren(nextChildren, transaction, context); | |
} | |
}, | |
/** | |
* Destroys all event registrations for this instance. Does not remove from | |
* the DOM. That must be done by the parent. | |
* | |
* @internal | |
*/ | |
unmountComponent: function () { | |
switch (this._tag) { | |
case 'iframe': | |
case 'img': | |
case 'form': | |
case 'video': | |
case 'audio': | |
var listeners = this._wrapperState.listeners; | |
if (listeners) { | |
for (var i = 0; i < listeners.length; i++) { | |
listeners[i].remove(); | |
} | |
} | |
break; | |
case 'input': | |
ReactDOMInput.unmountWrapper(this); | |
break; | |
case 'html': | |
case 'head': | |
case 'body': | |
/** | |
* Components like <html> <head> and <body> can't be removed or added | |
* easily in a cross-browser way, however it's valuable to be able to | |
* take advantage of React's reconciliation for styling and <title> | |
* management. So we just document it and throw in dangerous cases. | |
*/ | |
true ? process.env.NODE_ENV !== 'production' ? invariant(false, '<%s> tried to unmount. Because of cross-browser quirks it is ' + 'impossible to unmount some top-level components (eg <html>, ' + '<head>, and <body>) reliably and efficiently. To fix this, have a ' + 'single top-level component that never unmounts render these ' + 'elements.', this._tag) : invariant(false) : undefined; | |
break; | |
} | |
this.unmountChildren(); | |
ReactBrowserEventEmitter.deleteAllListeners(this._rootNodeID); | |
ReactComponentBrowserEnvironment.unmountIDFromEnvironment(this._rootNodeID); | |
this._rootNodeID = null; | |
this._wrapperState = null; | |
if (this._nodeWithLegacyProperties) { | |
var node = this._nodeWithLegacyProperties; | |
node._reactInternalComponent = null; | |
this._nodeWithLegacyProperties = null; | |
} | |
}, | |
getPublicInstance: function () { | |
if (!this._nodeWithLegacyProperties) { | |
var node = ReactMount.getNode(this._rootNodeID); | |
node._reactInternalComponent = this; | |
node.getDOMNode = legacyGetDOMNode; | |
node.isMounted = legacyIsMounted; | |
node.setState = legacySetStateEtc; | |
node.replaceState = legacySetStateEtc; | |
node.forceUpdate = legacySetStateEtc; | |
node.setProps = legacySetProps; | |
node.replaceProps = legacyReplaceProps; | |
if (process.env.NODE_ENV !== 'production') { | |
if (canDefineProperty) { | |
Object.defineProperties(node, legacyPropsDescriptor); | |
} else { | |
// updateComponent will update this property on subsequent renders | |
node.props = this._currentElement.props; | |
} | |
} else { | |
// updateComponent will update this property on subsequent renders | |
node.props = this._currentElement.props; | |
} | |
this._nodeWithLegacyProperties = node; | |
} | |
return this._nodeWithLegacyProperties; | |
} | |
}; | |
ReactPerf.measureMethods(ReactDOMComponent, 'ReactDOMComponent', { | |
mountComponent: 'mountComponent', | |
updateComponent: 'updateComponent' | |
}); | |
assign(ReactDOMComponent.prototype, ReactDOMComponent.Mixin, ReactMultiChild.Mixin); | |
module.exports = ReactDOMComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 150 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule AutoFocusUtils | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactMount = __webpack_require__(86); | |
var findDOMNode = __webpack_require__(147); | |
var focusNode = __webpack_require__(151); | |
var Mixin = { | |
componentDidMount: function () { | |
if (this.props.autoFocus) { | |
focusNode(findDOMNode(this)); | |
} | |
} | |
}; | |
var AutoFocusUtils = { | |
Mixin: Mixin, | |
focusDOMComponent: function () { | |
focusNode(ReactMount.getNode(this._rootNodeID)); | |
} | |
}; | |
module.exports = AutoFocusUtils; | |
/***/ }, | |
/* 151 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule focusNode | |
*/ | |
'use strict'; | |
/** | |
* @param {DOMElement} node input/textarea to focus | |
*/ | |
function focusNode(node) { | |
// IE8 can throw "Can't move focus to the control because it is invisible, | |
// not enabled, or of a type that does not accept the focus." for all kinds of | |
// reasons that are too expensive and fragile to test. | |
try { | |
node.focus(); | |
} catch (e) {} | |
} | |
module.exports = focusNode; | |
/***/ }, | |
/* 152 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule CSSPropertyOperations | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var CSSProperty = __webpack_require__(153); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var ReactPerf = __webpack_require__(76); | |
var camelizeStyleName = __webpack_require__(154); | |
var dangerousStyleValue = __webpack_require__(156); | |
var hyphenateStyleName = __webpack_require__(157); | |
var memoizeStringOnly = __webpack_require__(159); | |
var warning = __webpack_require__(83); | |
var processStyleName = memoizeStringOnly(function (styleName) { | |
return hyphenateStyleName(styleName); | |
}); | |
var hasShorthandPropertyBug = false; | |
var styleFloatAccessor = 'cssFloat'; | |
if (ExecutionEnvironment.canUseDOM) { | |
var tempStyle = document.createElement('div').style; | |
try { | |
// IE8 throws "Invalid argument." if resetting shorthand style properties. | |
tempStyle.font = ''; | |
} catch (e) { | |
hasShorthandPropertyBug = true; | |
} | |
// IE8 only supports accessing cssFloat (standard) as styleFloat | |
if (document.documentElement.style.cssFloat === undefined) { | |
styleFloatAccessor = 'styleFloat'; | |
} | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
// 'msTransform' is correct, but the other prefixes should be capitalized | |
var badVendoredStyleNamePattern = /^(?:webkit|moz|o)[A-Z]/; | |
// style values shouldn't contain a semicolon | |
var badStyleValueWithSemicolonPattern = /;\s*$/; | |
var warnedStyleNames = {}; | |
var warnedStyleValues = {}; | |
var warnHyphenatedStyleName = function (name) { | |
if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) { | |
return; | |
} | |
warnedStyleNames[name] = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Unsupported style property %s. Did you mean %s?', name, camelizeStyleName(name)) : undefined; | |
}; | |
var warnBadVendoredStyleName = function (name) { | |
if (warnedStyleNames.hasOwnProperty(name) && warnedStyleNames[name]) { | |
return; | |
} | |
warnedStyleNames[name] = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Unsupported vendor-prefixed style property %s. Did you mean %s?', name, name.charAt(0).toUpperCase() + name.slice(1)) : undefined; | |
}; | |
var warnStyleValueWithSemicolon = function (name, value) { | |
if (warnedStyleValues.hasOwnProperty(value) && warnedStyleValues[value]) { | |
return; | |
} | |
warnedStyleValues[value] = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Style property values shouldn\'t contain a semicolon. ' + 'Try "%s: %s" instead.', name, value.replace(badStyleValueWithSemicolonPattern, '')) : undefined; | |
}; | |
/** | |
* @param {string} name | |
* @param {*} value | |
*/ | |
var warnValidStyle = function (name, value) { | |
if (name.indexOf('-') > -1) { | |
warnHyphenatedStyleName(name); | |
} else if (badVendoredStyleNamePattern.test(name)) { | |
warnBadVendoredStyleName(name); | |
} else if (badStyleValueWithSemicolonPattern.test(value)) { | |
warnStyleValueWithSemicolon(name, value); | |
} | |
}; | |
} | |
/** | |
* Operations for dealing with CSS properties. | |
*/ | |
var CSSPropertyOperations = { | |
/** | |
* Serializes a mapping of style properties for use as inline styles: | |
* | |
* > createMarkupForStyles({width: '200px', height: 0}) | |
* "width:200px;height:0;" | |
* | |
* Undefined values are ignored so that declarative programming is easier. | |
* The result should be HTML-escaped before insertion into the DOM. | |
* | |
* @param {object} styles | |
* @return {?string} | |
*/ | |
createMarkupForStyles: function (styles) { | |
var serialized = ''; | |
for (var styleName in styles) { | |
if (!styles.hasOwnProperty(styleName)) { | |
continue; | |
} | |
var styleValue = styles[styleName]; | |
if (process.env.NODE_ENV !== 'production') { | |
warnValidStyle(styleName, styleValue); | |
} | |
if (styleValue != null) { | |
serialized += processStyleName(styleName) + ':'; | |
serialized += dangerousStyleValue(styleName, styleValue) + ';'; | |
} | |
} | |
return serialized || null; | |
}, | |
/** | |
* Sets the value for multiple styles on a node. If a value is specified as | |
* '' (empty string), the corresponding style property will be unset. | |
* | |
* @param {DOMElement} node | |
* @param {object} styles | |
*/ | |
setValueForStyles: function (node, styles) { | |
var style = node.style; | |
for (var styleName in styles) { | |
if (!styles.hasOwnProperty(styleName)) { | |
continue; | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
warnValidStyle(styleName, styles[styleName]); | |
} | |
var styleValue = dangerousStyleValue(styleName, styles[styleName]); | |
if (styleName === 'float') { | |
styleName = styleFloatAccessor; | |
} | |
if (styleValue) { | |
style[styleName] = styleValue; | |
} else { | |
var expansion = hasShorthandPropertyBug && CSSProperty.shorthandPropertyExpansions[styleName]; | |
if (expansion) { | |
// Shorthand property that IE8 won't like unsetting, so unset each | |
// component to placate it | |
for (var individualStyleName in expansion) { | |
style[individualStyleName] = ''; | |
} | |
} else { | |
style[styleName] = ''; | |
} | |
} | |
} | |
} | |
}; | |
ReactPerf.measureMethods(CSSPropertyOperations, 'CSSPropertyOperations', { | |
setValueForStyles: 'setValueForStyles' | |
}); | |
module.exports = CSSPropertyOperations; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 153 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule CSSProperty | |
*/ | |
'use strict'; | |
/** | |
* CSS properties which accept numbers but are not in units of "px". | |
*/ | |
var isUnitlessNumber = { | |
animationIterationCount: true, | |
boxFlex: true, | |
boxFlexGroup: true, | |
boxOrdinalGroup: true, | |
columnCount: true, | |
flex: true, | |
flexGrow: true, | |
flexPositive: true, | |
flexShrink: true, | |
flexNegative: true, | |
flexOrder: true, | |
fontWeight: true, | |
lineClamp: true, | |
lineHeight: true, | |
opacity: true, | |
order: true, | |
orphans: true, | |
tabSize: true, | |
widows: true, | |
zIndex: true, | |
zoom: true, | |
// SVG-related properties | |
fillOpacity: true, | |
stopOpacity: true, | |
strokeDashoffset: true, | |
strokeOpacity: true, | |
strokeWidth: true | |
}; | |
/** | |
* @param {string} prefix vendor-specific prefix, eg: Webkit | |
* @param {string} key style name, eg: transitionDuration | |
* @return {string} style name prefixed with `prefix`, properly camelCased, eg: | |
* WebkitTransitionDuration | |
*/ | |
function prefixKey(prefix, key) { | |
return prefix + key.charAt(0).toUpperCase() + key.substring(1); | |
} | |
/** | |
* Support style names that may come passed in prefixed by adding permutations | |
* of vendor prefixes. | |
*/ | |
var prefixes = ['Webkit', 'ms', 'Moz', 'O']; | |
// Using Object.keys here, or else the vanilla for-in loop makes IE8 go into an | |
// infinite loop, because it iterates over the newly added props too. | |
Object.keys(isUnitlessNumber).forEach(function (prop) { | |
prefixes.forEach(function (prefix) { | |
isUnitlessNumber[prefixKey(prefix, prop)] = isUnitlessNumber[prop]; | |
}); | |
}); | |
/** | |
* Most style properties can be unset by doing .style[prop] = '' but IE8 | |
* doesn't like doing that with shorthand properties so for the properties that | |
* IE8 breaks on, which are listed here, we instead unset each of the | |
* individual properties. See http://bugs.jquery.com/ticket/12385. | |
* The 4-value 'clock' properties like margin, padding, border-width seem to | |
* behave without any problems. Curiously, list-style works too without any | |
* special prodding. | |
*/ | |
var shorthandPropertyExpansions = { | |
background: { | |
backgroundAttachment: true, | |
backgroundColor: true, | |
backgroundImage: true, | |
backgroundPositionX: true, | |
backgroundPositionY: true, | |
backgroundRepeat: true | |
}, | |
backgroundPosition: { | |
backgroundPositionX: true, | |
backgroundPositionY: true | |
}, | |
border: { | |
borderWidth: true, | |
borderStyle: true, | |
borderColor: true | |
}, | |
borderBottom: { | |
borderBottomWidth: true, | |
borderBottomStyle: true, | |
borderBottomColor: true | |
}, | |
borderLeft: { | |
borderLeftWidth: true, | |
borderLeftStyle: true, | |
borderLeftColor: true | |
}, | |
borderRight: { | |
borderRightWidth: true, | |
borderRightStyle: true, | |
borderRightColor: true | |
}, | |
borderTop: { | |
borderTopWidth: true, | |
borderTopStyle: true, | |
borderTopColor: true | |
}, | |
font: { | |
fontStyle: true, | |
fontVariant: true, | |
fontWeight: true, | |
fontSize: true, | |
lineHeight: true, | |
fontFamily: true | |
}, | |
outline: { | |
outlineWidth: true, | |
outlineStyle: true, | |
outlineColor: true | |
} | |
}; | |
var CSSProperty = { | |
isUnitlessNumber: isUnitlessNumber, | |
shorthandPropertyExpansions: shorthandPropertyExpansions | |
}; | |
module.exports = CSSProperty; | |
/***/ }, | |
/* 154 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule camelizeStyleName | |
* @typechecks | |
*/ | |
'use strict'; | |
var camelize = __webpack_require__(155); | |
var msPattern = /^-ms-/; | |
/** | |
* Camelcases a hyphenated CSS property name, for example: | |
* | |
* > camelizeStyleName('background-color') | |
* < "backgroundColor" | |
* > camelizeStyleName('-moz-transition') | |
* < "MozTransition" | |
* > camelizeStyleName('-ms-transition') | |
* < "msTransition" | |
* | |
* As Andi Smith suggests | |
* (http://www.andismith.com/blog/2012/02/modernizr-prefixed/), an `-ms` prefix | |
* is converted to lowercase `ms`. | |
* | |
* @param {string} string | |
* @return {string} | |
*/ | |
function camelizeStyleName(string) { | |
return camelize(string.replace(msPattern, 'ms-')); | |
} | |
module.exports = camelizeStyleName; | |
/***/ }, | |
/* 155 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule camelize | |
* @typechecks | |
*/ | |
"use strict"; | |
var _hyphenPattern = /-(.)/g; | |
/** | |
* Camelcases a hyphenated string, for example: | |
* | |
* > camelize('background-color') | |
* < "backgroundColor" | |
* | |
* @param {string} string | |
* @return {string} | |
*/ | |
function camelize(string) { | |
return string.replace(_hyphenPattern, function (_, character) { | |
return character.toUpperCase(); | |
}); | |
} | |
module.exports = camelize; | |
/***/ }, | |
/* 156 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule dangerousStyleValue | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var CSSProperty = __webpack_require__(153); | |
var isUnitlessNumber = CSSProperty.isUnitlessNumber; | |
/** | |
* Convert a value into the proper css writable value. The style name `name` | |
* should be logical (no hyphens), as specified | |
* in `CSSProperty.isUnitlessNumber`. | |
* | |
* @param {string} name CSS property name such as `topMargin`. | |
* @param {*} value CSS property value such as `10px`. | |
* @return {string} Normalized style value with dimensions applied. | |
*/ | |
function dangerousStyleValue(name, value) { | |
// Note that we've removed escapeTextForBrowser() calls here since the | |
// whole string will be escaped when the attribute is injected into | |
// the markup. If you provide unsafe user data here they can inject | |
// arbitrary CSS which may be problematic (I couldn't repro this): | |
// https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet | |
// http://www.thespanner.co.uk/2007/11/26/ultimate-xss-css-injection/ | |
// This is not an XSS hole but instead a potential CSS injection issue | |
// which has lead to a greater discussion about how we're going to | |
// trust URLs moving forward. See #2115901 | |
var isEmpty = value == null || typeof value === 'boolean' || value === ''; | |
if (isEmpty) { | |
return ''; | |
} | |
var isNonNumeric = isNaN(value); | |
if (isNonNumeric || value === 0 || isUnitlessNumber.hasOwnProperty(name) && isUnitlessNumber[name]) { | |
return '' + value; // cast to string | |
} | |
if (typeof value === 'string') { | |
value = value.trim(); | |
} | |
return value + 'px'; | |
} | |
module.exports = dangerousStyleValue; | |
/***/ }, | |
/* 157 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule hyphenateStyleName | |
* @typechecks | |
*/ | |
'use strict'; | |
var hyphenate = __webpack_require__(158); | |
var msPattern = /^ms-/; | |
/** | |
* Hyphenates a camelcased CSS property name, for example: | |
* | |
* > hyphenateStyleName('backgroundColor') | |
* < "background-color" | |
* > hyphenateStyleName('MozTransition') | |
* < "-moz-transition" | |
* > hyphenateStyleName('msTransition') | |
* < "-ms-transition" | |
* | |
* As Modernizr suggests (http://modernizr.com/docs/#prefixed), an `ms` prefix | |
* is converted to `-ms-`. | |
* | |
* @param {string} string | |
* @return {string} | |
*/ | |
function hyphenateStyleName(string) { | |
return hyphenate(string).replace(msPattern, '-ms-'); | |
} | |
module.exports = hyphenateStyleName; | |
/***/ }, | |
/* 158 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule hyphenate | |
* @typechecks | |
*/ | |
'use strict'; | |
var _uppercasePattern = /([A-Z])/g; | |
/** | |
* Hyphenates a camelcased string, for example: | |
* | |
* > hyphenate('backgroundColor') | |
* < "background-color" | |
* | |
* For CSS style names, use `hyphenateStyleName` instead which works properly | |
* with all vendor prefixes, including `ms`. | |
* | |
* @param {string} string | |
* @return {string} | |
*/ | |
function hyphenate(string) { | |
return string.replace(_uppercasePattern, '-$1').toLowerCase(); | |
} | |
module.exports = hyphenate; | |
/***/ }, | |
/* 159 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule memoizeStringOnly | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* Memoizes the return value of a function that accepts one string argument. | |
* | |
* @param {function} callback | |
* @return {function} | |
*/ | |
function memoizeStringOnly(callback) { | |
var cache = {}; | |
return function (string) { | |
if (!cache.hasOwnProperty(string)) { | |
cache[string] = callback.call(this, string); | |
} | |
return cache[string]; | |
}; | |
} | |
module.exports = memoizeStringOnly; | |
/***/ }, | |
/* 160 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMButton | |
*/ | |
'use strict'; | |
var mouseListenerNames = { | |
onClick: true, | |
onDoubleClick: true, | |
onMouseDown: true, | |
onMouseMove: true, | |
onMouseUp: true, | |
onClickCapture: true, | |
onDoubleClickCapture: true, | |
onMouseDownCapture: true, | |
onMouseMoveCapture: true, | |
onMouseUpCapture: true | |
}; | |
/** | |
* Implements a <button> native component that does not receive mouse events | |
* when `disabled` is set. | |
*/ | |
var ReactDOMButton = { | |
getNativeProps: function (inst, props, context) { | |
if (!props.disabled) { | |
return props; | |
} | |
// Copy the props, except the mouse listeners | |
var nativeProps = {}; | |
for (var key in props) { | |
if (props.hasOwnProperty(key) && !mouseListenerNames[key]) { | |
nativeProps[key] = props[key]; | |
} | |
} | |
return nativeProps; | |
} | |
}; | |
module.exports = ReactDOMButton; | |
/***/ }, | |
/* 161 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMInput | |
*/ | |
'use strict'; | |
var ReactDOMIDOperations = __webpack_require__(85); | |
var LinkedValueUtils = __webpack_require__(162); | |
var ReactMount = __webpack_require__(86); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var instancesByReactID = {}; | |
function forceUpdateIfMounted() { | |
if (this._rootNodeID) { | |
// DOM component is still mounted; update | |
ReactDOMInput.updateWrapper(this); | |
} | |
} | |
/** | |
* Implements an <input> native component that allows setting these optional | |
* props: `checked`, `value`, `defaultChecked`, and `defaultValue`. | |
* | |
* If `checked` or `value` are not supplied (or null/undefined), user actions | |
* that affect the checked state or value will trigger updates to the element. | |
* | |
* If they are supplied (and not null/undefined), the rendered element will not | |
* trigger updates to the element. Instead, the props must change in order for | |
* the rendered element to be updated. | |
* | |
* The rendered element will be initialized as unchecked (or `defaultChecked`) | |
* with an empty value (or `defaultValue`). | |
* | |
* @see http://www.w3.org/TR/2012/WD-html5-20121025/the-input-element.html | |
*/ | |
var ReactDOMInput = { | |
getNativeProps: function (inst, props, context) { | |
var value = LinkedValueUtils.getValue(props); | |
var checked = LinkedValueUtils.getChecked(props); | |
var nativeProps = assign({}, props, { | |
defaultChecked: undefined, | |
defaultValue: undefined, | |
value: value != null ? value : inst._wrapperState.initialValue, | |
checked: checked != null ? checked : inst._wrapperState.initialChecked, | |
onChange: inst._wrapperState.onChange | |
}); | |
return nativeProps; | |
}, | |
mountWrapper: function (inst, props) { | |
if (process.env.NODE_ENV !== 'production') { | |
LinkedValueUtils.checkPropTypes('input', props, inst._currentElement._owner); | |
} | |
var defaultValue = props.defaultValue; | |
inst._wrapperState = { | |
initialChecked: props.defaultChecked || false, | |
initialValue: defaultValue != null ? defaultValue : null, | |
onChange: _handleChange.bind(inst) | |
}; | |
}, | |
mountReadyWrapper: function (inst) { | |
// Can't be in mountWrapper or else server rendering leaks. | |
instancesByReactID[inst._rootNodeID] = inst; | |
}, | |
unmountWrapper: function (inst) { | |
delete instancesByReactID[inst._rootNodeID]; | |
}, | |
updateWrapper: function (inst) { | |
var props = inst._currentElement.props; | |
// TODO: Shouldn't this be getChecked(props)? | |
var checked = props.checked; | |
if (checked != null) { | |
ReactDOMIDOperations.updatePropertyByID(inst._rootNodeID, 'checked', checked || false); | |
} | |
var value = LinkedValueUtils.getValue(props); | |
if (value != null) { | |
// Cast `value` to a string to ensure the value is set correctly. While | |
// browsers typically do this as necessary, jsdom doesn't. | |
ReactDOMIDOperations.updatePropertyByID(inst._rootNodeID, 'value', '' + value); | |
} | |
} | |
}; | |
function _handleChange(event) { | |
var props = this._currentElement.props; | |
var returnValue = LinkedValueUtils.executeOnChange(props, event); | |
// Here we use asap to wait until all updates have propagated, which | |
// is important when using controlled components within layers: | |
// https://github.com/facebook/react/issues/1698 | |
ReactUpdates.asap(forceUpdateIfMounted, this); | |
var name = props.name; | |
if (props.type === 'radio' && name != null) { | |
var rootNode = ReactMount.getNode(this._rootNodeID); | |
var queryRoot = rootNode; | |
while (queryRoot.parentNode) { | |
queryRoot = queryRoot.parentNode; | |
} | |
// If `rootNode.form` was non-null, then we could try `form.elements`, | |
// but that sometimes behaves strangely in IE8. We could also try using | |
// `form.getElementsByName`, but that will only return direct children | |
// and won't include inputs that use the HTML5 `form=` attribute. Since | |
// the input might not even be in a form, let's just use the global | |
// `querySelectorAll` to ensure we don't miss anything. | |
var group = queryRoot.querySelectorAll('input[name=' + JSON.stringify('' + name) + '][type="radio"]'); | |
for (var i = 0; i < group.length; i++) { | |
var otherNode = group[i]; | |
if (otherNode === rootNode || otherNode.form !== rootNode.form) { | |
continue; | |
} | |
// This will throw if radio buttons rendered by different copies of React | |
// and the same name are rendered into the same form (same as #1939). | |
// That's probably okay; we don't support it just as we don't support | |
// mixing React with non-React. | |
var otherID = ReactMount.getID(otherNode); | |
!otherID ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactDOMInput: Mixing React and non-React radio inputs with the ' + 'same `name` is not supported.') : invariant(false) : undefined; | |
var otherInstance = instancesByReactID[otherID]; | |
!otherInstance ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactDOMInput: Unknown radio button ID %s.', otherID) : invariant(false) : undefined; | |
// If this is a controlled radio button group, forcing the input that | |
// was previously checked to update will cause it to be come re-checked | |
// as appropriate. | |
ReactUpdates.asap(forceUpdateIfMounted, otherInstance); | |
} | |
} | |
return returnValue; | |
} | |
module.exports = ReactDOMInput; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 162 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule LinkedValueUtils | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactPropTypes = __webpack_require__(163); | |
var ReactPropTypeLocations = __webpack_require__(122); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
var hasReadOnlyValue = { | |
'button': true, | |
'checkbox': true, | |
'image': true, | |
'hidden': true, | |
'radio': true, | |
'reset': true, | |
'submit': true | |
}; | |
function _assertSingleLink(inputProps) { | |
!(inputProps.checkedLink == null || inputProps.valueLink == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Cannot provide a checkedLink and a valueLink. If you want to use ' + 'checkedLink, you probably don\'t want to use valueLink and vice versa.') : invariant(false) : undefined; | |
} | |
function _assertValueLink(inputProps) { | |
_assertSingleLink(inputProps); | |
!(inputProps.value == null && inputProps.onChange == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Cannot provide a valueLink and a value or onChange event. If you want ' + 'to use value or onChange, you probably don\'t want to use valueLink.') : invariant(false) : undefined; | |
} | |
function _assertCheckedLink(inputProps) { | |
_assertSingleLink(inputProps); | |
!(inputProps.checked == null && inputProps.onChange == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Cannot provide a checkedLink and a checked property or onChange event. ' + 'If you want to use checked or onChange, you probably don\'t want to ' + 'use checkedLink') : invariant(false) : undefined; | |
} | |
var propTypes = { | |
value: function (props, propName, componentName) { | |
if (!props[propName] || hasReadOnlyValue[props.type] || props.onChange || props.readOnly || props.disabled) { | |
return null; | |
} | |
return new Error('You provided a `value` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultValue`. Otherwise, ' + 'set either `onChange` or `readOnly`.'); | |
}, | |
checked: function (props, propName, componentName) { | |
if (!props[propName] || props.onChange || props.readOnly || props.disabled) { | |
return null; | |
} | |
return new Error('You provided a `checked` prop to a form field without an ' + '`onChange` handler. This will render a read-only field. If ' + 'the field should be mutable use `defaultChecked`. Otherwise, ' + 'set either `onChange` or `readOnly`.'); | |
}, | |
onChange: ReactPropTypes.func | |
}; | |
var loggedTypeFailures = {}; | |
function getDeclarationErrorAddendum(owner) { | |
if (owner) { | |
var name = owner.getName(); | |
if (name) { | |
return ' Check the render method of `' + name + '`.'; | |
} | |
} | |
return ''; | |
} | |
/** | |
* Provide a linked `value` attribute for controlled forms. You should not use | |
* this outside of the ReactDOM controlled form components. | |
*/ | |
var LinkedValueUtils = { | |
checkPropTypes: function (tagName, props, owner) { | |
for (var propName in propTypes) { | |
if (propTypes.hasOwnProperty(propName)) { | |
var error = propTypes[propName](props, propName, tagName, ReactPropTypeLocations.prop); | |
} | |
if (error instanceof Error && !(error.message in loggedTypeFailures)) { | |
// Only monitor this failure once because there tends to be a lot of the | |
// same error. | |
loggedTypeFailures[error.message] = true; | |
var addendum = getDeclarationErrorAddendum(owner); | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Failed form propType: %s%s', error.message, addendum) : undefined; | |
} | |
} | |
}, | |
/** | |
* @param {object} inputProps Props for form component | |
* @return {*} current value of the input either from value prop or link. | |
*/ | |
getValue: function (inputProps) { | |
if (inputProps.valueLink) { | |
_assertValueLink(inputProps); | |
return inputProps.valueLink.value; | |
} | |
return inputProps.value; | |
}, | |
/** | |
* @param {object} inputProps Props for form component | |
* @return {*} current checked status of the input either from checked prop | |
* or link. | |
*/ | |
getChecked: function (inputProps) { | |
if (inputProps.checkedLink) { | |
_assertCheckedLink(inputProps); | |
return inputProps.checkedLink.value; | |
} | |
return inputProps.checked; | |
}, | |
/** | |
* @param {object} inputProps Props for form component | |
* @param {SyntheticEvent} event change event to handle | |
*/ | |
executeOnChange: function (inputProps, event) { | |
if (inputProps.valueLink) { | |
_assertValueLink(inputProps); | |
return inputProps.valueLink.requestChange(event.target.value); | |
} else if (inputProps.checkedLink) { | |
_assertCheckedLink(inputProps); | |
return inputProps.checkedLink.requestChange(event.target.checked); | |
} else if (inputProps.onChange) { | |
return inputProps.onChange.call(undefined, event); | |
} | |
} | |
}; | |
module.exports = LinkedValueUtils; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 163 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactPropTypes | |
*/ | |
'use strict'; | |
var ReactElement = __webpack_require__(99); | |
var ReactPropTypeLocationNames = __webpack_require__(123); | |
var emptyFunction = __webpack_require__(73); | |
var getIteratorFn = __webpack_require__(164); | |
/** | |
* Collection of methods that allow declaration and validation of props that are | |
* supplied to React components. Example usage: | |
* | |
* var Props = require('ReactPropTypes'); | |
* var MyArticle = React.createClass({ | |
* propTypes: { | |
* // An optional string prop named "description". | |
* description: Props.string, | |
* | |
* // A required enum prop named "category". | |
* category: Props.oneOf(['News','Photos']).isRequired, | |
* | |
* // A prop named "dialog" that requires an instance of Dialog. | |
* dialog: Props.instanceOf(Dialog).isRequired | |
* }, | |
* render: function() { ... } | |
* }); | |
* | |
* A more formal specification of how these methods are used: | |
* | |
* type := array|bool|func|object|number|string|oneOf([...])|instanceOf(...) | |
* decl := ReactPropTypes.{type}(.isRequired)? | |
* | |
* Each and every declaration produces a function with the same signature. This | |
* allows the creation of custom validation functions. For example: | |
* | |
* var MyLink = React.createClass({ | |
* propTypes: { | |
* // An optional string or URI prop named "href". | |
* href: function(props, propName, componentName) { | |
* var propValue = props[propName]; | |
* if (propValue != null && typeof propValue !== 'string' && | |
* !(propValue instanceof URI)) { | |
* return new Error( | |
* 'Expected a string or an URI for ' + propName + ' in ' + | |
* componentName | |
* ); | |
* } | |
* } | |
* }, | |
* render: function() {...} | |
* }); | |
* | |
* @internal | |
*/ | |
var ANONYMOUS = '<<anonymous>>'; | |
var ReactPropTypes = { | |
array: createPrimitiveTypeChecker('array'), | |
bool: createPrimitiveTypeChecker('boolean'), | |
func: createPrimitiveTypeChecker('function'), | |
number: createPrimitiveTypeChecker('number'), | |
object: createPrimitiveTypeChecker('object'), | |
string: createPrimitiveTypeChecker('string'), | |
any: createAnyTypeChecker(), | |
arrayOf: createArrayOfTypeChecker, | |
element: createElementTypeChecker(), | |
instanceOf: createInstanceTypeChecker, | |
node: createNodeChecker(), | |
objectOf: createObjectOfTypeChecker, | |
oneOf: createEnumTypeChecker, | |
oneOfType: createUnionTypeChecker, | |
shape: createShapeTypeChecker | |
}; | |
function createChainableTypeChecker(validate) { | |
function checkType(isRequired, props, propName, componentName, location, propFullName) { | |
componentName = componentName || ANONYMOUS; | |
propFullName = propFullName || propName; | |
if (props[propName] == null) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
if (isRequired) { | |
return new Error('Required ' + locationName + ' `' + propFullName + '` was not specified in ' + ('`' + componentName + '`.')); | |
} | |
return null; | |
} else { | |
return validate(props, propName, componentName, location, propFullName); | |
} | |
} | |
var chainedCheckType = checkType.bind(null, false); | |
chainedCheckType.isRequired = checkType.bind(null, true); | |
return chainedCheckType; | |
} | |
function createPrimitiveTypeChecker(expectedType) { | |
function validate(props, propName, componentName, location, propFullName) { | |
var propValue = props[propName]; | |
var propType = getPropType(propValue); | |
if (propType !== expectedType) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
// `propValue` being instance of, say, date/regexp, pass the 'object' | |
// check, but we can offer a more precise error message here rather than | |
// 'of type `object`'. | |
var preciseType = getPreciseType(propValue); | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of type ' + ('`' + preciseType + '` supplied to `' + componentName + '`, expected ') + ('`' + expectedType + '`.')); | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createAnyTypeChecker() { | |
return createChainableTypeChecker(emptyFunction.thatReturns(null)); | |
} | |
function createArrayOfTypeChecker(typeChecker) { | |
function validate(props, propName, componentName, location, propFullName) { | |
var propValue = props[propName]; | |
if (!Array.isArray(propValue)) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
var propType = getPropType(propValue); | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an array.')); | |
} | |
for (var i = 0; i < propValue.length; i++) { | |
var error = typeChecker(propValue, i, componentName, location, propFullName + '[' + i + ']'); | |
if (error instanceof Error) { | |
return error; | |
} | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createElementTypeChecker() { | |
function validate(props, propName, componentName, location, propFullName) { | |
if (!ReactElement.isValidElement(props[propName])) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a single ReactElement.')); | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createInstanceTypeChecker(expectedClass) { | |
function validate(props, propName, componentName, location, propFullName) { | |
if (!(props[propName] instanceof expectedClass)) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
var expectedClassName = expectedClass.name || ANONYMOUS; | |
var actualClassName = getClassName(props[propName]); | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of type ' + ('`' + actualClassName + '` supplied to `' + componentName + '`, expected ') + ('instance of `' + expectedClassName + '`.')); | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createEnumTypeChecker(expectedValues) { | |
if (!Array.isArray(expectedValues)) { | |
return createChainableTypeChecker(function () { | |
return new Error('Invalid argument supplied to oneOf, expected an instance of array.'); | |
}); | |
} | |
function validate(props, propName, componentName, location, propFullName) { | |
var propValue = props[propName]; | |
for (var i = 0; i < expectedValues.length; i++) { | |
if (propValue === expectedValues[i]) { | |
return null; | |
} | |
} | |
var locationName = ReactPropTypeLocationNames[location]; | |
var valuesString = JSON.stringify(expectedValues); | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of value `' + propValue + '` ' + ('supplied to `' + componentName + '`, expected one of ' + valuesString + '.')); | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createObjectOfTypeChecker(typeChecker) { | |
function validate(props, propName, componentName, location, propFullName) { | |
var propValue = props[propName]; | |
var propType = getPropType(propValue); | |
if (propType !== 'object') { | |
var locationName = ReactPropTypeLocationNames[location]; | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of type ' + ('`' + propType + '` supplied to `' + componentName + '`, expected an object.')); | |
} | |
for (var key in propValue) { | |
if (propValue.hasOwnProperty(key)) { | |
var error = typeChecker(propValue, key, componentName, location, propFullName + '.' + key); | |
if (error instanceof Error) { | |
return error; | |
} | |
} | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createUnionTypeChecker(arrayOfTypeCheckers) { | |
if (!Array.isArray(arrayOfTypeCheckers)) { | |
return createChainableTypeChecker(function () { | |
return new Error('Invalid argument supplied to oneOfType, expected an instance of array.'); | |
}); | |
} | |
function validate(props, propName, componentName, location, propFullName) { | |
for (var i = 0; i < arrayOfTypeCheckers.length; i++) { | |
var checker = arrayOfTypeCheckers[i]; | |
if (checker(props, propName, componentName, location, propFullName) == null) { | |
return null; | |
} | |
} | |
var locationName = ReactPropTypeLocationNames[location]; | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`.')); | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createNodeChecker() { | |
function validate(props, propName, componentName, location, propFullName) { | |
if (!isNode(props[propName])) { | |
var locationName = ReactPropTypeLocationNames[location]; | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` supplied to ' + ('`' + componentName + '`, expected a ReactNode.')); | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function createShapeTypeChecker(shapeTypes) { | |
function validate(props, propName, componentName, location, propFullName) { | |
var propValue = props[propName]; | |
var propType = getPropType(propValue); | |
if (propType !== 'object') { | |
var locationName = ReactPropTypeLocationNames[location]; | |
return new Error('Invalid ' + locationName + ' `' + propFullName + '` of type `' + propType + '` ' + ('supplied to `' + componentName + '`, expected `object`.')); | |
} | |
for (var key in shapeTypes) { | |
var checker = shapeTypes[key]; | |
if (!checker) { | |
continue; | |
} | |
var error = checker(propValue, key, componentName, location, propFullName + '.' + key); | |
if (error) { | |
return error; | |
} | |
} | |
return null; | |
} | |
return createChainableTypeChecker(validate); | |
} | |
function isNode(propValue) { | |
switch (typeof propValue) { | |
case 'number': | |
case 'string': | |
case 'undefined': | |
return true; | |
case 'boolean': | |
return !propValue; | |
case 'object': | |
if (Array.isArray(propValue)) { | |
return propValue.every(isNode); | |
} | |
if (propValue === null || ReactElement.isValidElement(propValue)) { | |
return true; | |
} | |
var iteratorFn = getIteratorFn(propValue); | |
if (iteratorFn) { | |
var iterator = iteratorFn.call(propValue); | |
var step; | |
if (iteratorFn !== propValue.entries) { | |
while (!(step = iterator.next()).done) { | |
if (!isNode(step.value)) { | |
return false; | |
} | |
} | |
} else { | |
// Iterator will provide entry [k,v] tuples rather than values. | |
while (!(step = iterator.next()).done) { | |
var entry = step.value; | |
if (entry) { | |
if (!isNode(entry[1])) { | |
return false; | |
} | |
} | |
} | |
} | |
} else { | |
return false; | |
} | |
return true; | |
default: | |
return false; | |
} | |
} | |
// Equivalent of `typeof` but with special handling for array and regexp. | |
function getPropType(propValue) { | |
var propType = typeof propValue; | |
if (Array.isArray(propValue)) { | |
return 'array'; | |
} | |
if (propValue instanceof RegExp) { | |
// Old webkits (at least until Android 4.0) return 'function' rather than | |
// 'object' for typeof a RegExp. We'll normalize this here so that /bla/ | |
// passes PropTypes.object. | |
return 'object'; | |
} | |
return propType; | |
} | |
// This handles more types than `getPropType`. Only used for error messages. | |
// See `createPrimitiveTypeChecker`. | |
function getPreciseType(propValue) { | |
var propType = getPropType(propValue); | |
if (propType === 'object') { | |
if (propValue instanceof Date) { | |
return 'date'; | |
} else if (propValue instanceof RegExp) { | |
return 'regexp'; | |
} | |
} | |
return propType; | |
} | |
// Returns class name of the object, if any. | |
function getClassName(propValue) { | |
if (!propValue.constructor || !propValue.constructor.name) { | |
return '<<anonymous>>'; | |
} | |
return propValue.constructor.name; | |
} | |
module.exports = ReactPropTypes; | |
/***/ }, | |
/* 164 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getIteratorFn | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/* global Symbol */ | |
var ITERATOR_SYMBOL = typeof Symbol === 'function' && Symbol.iterator; | |
var FAUX_ITERATOR_SYMBOL = '@@iterator'; // Before Symbol spec. | |
/** | |
* Returns the iterator method function contained on the iterable object. | |
* | |
* Be sure to invoke the function with the iterable as context: | |
* | |
* var iteratorFn = getIteratorFn(myIterable); | |
* if (iteratorFn) { | |
* var iterator = iteratorFn.call(myIterable); | |
* ... | |
* } | |
* | |
* @param {?object} maybeIterable | |
* @return {?function} | |
*/ | |
function getIteratorFn(maybeIterable) { | |
var iteratorFn = maybeIterable && (ITERATOR_SYMBOL && maybeIterable[ITERATOR_SYMBOL] || maybeIterable[FAUX_ITERATOR_SYMBOL]); | |
if (typeof iteratorFn === 'function') { | |
return iteratorFn; | |
} | |
} | |
module.exports = getIteratorFn; | |
/***/ }, | |
/* 165 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMOption | |
*/ | |
'use strict'; | |
var ReactChildren = __webpack_require__(166); | |
var ReactDOMSelect = __webpack_require__(168); | |
var assign = __webpack_require__(29); | |
var warning = __webpack_require__(83); | |
var valueContextKey = ReactDOMSelect.valueContextKey; | |
/** | |
* Implements an <option> native component that warns when `selected` is set. | |
*/ | |
var ReactDOMOption = { | |
mountWrapper: function (inst, props, context) { | |
// TODO (yungsters): Remove support for `selected` in <option>. | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(props.selected == null, 'Use the `defaultValue` or `value` props on <select> instead of ' + 'setting `selected` on <option>.') : undefined; | |
} | |
// Look up whether this option is 'selected' via context | |
var selectValue = context[valueContextKey]; | |
// If context key is null (e.g., no specified value or after initial mount) | |
// or missing (e.g., for <datalist>), we don't change props.selected | |
var selected = null; | |
if (selectValue != null) { | |
selected = false; | |
if (Array.isArray(selectValue)) { | |
// multiple | |
for (var i = 0; i < selectValue.length; i++) { | |
if ('' + selectValue[i] === '' + props.value) { | |
selected = true; | |
break; | |
} | |
} | |
} else { | |
selected = '' + selectValue === '' + props.value; | |
} | |
} | |
inst._wrapperState = { selected: selected }; | |
}, | |
getNativeProps: function (inst, props, context) { | |
var nativeProps = assign({ selected: undefined, children: undefined }, props); | |
// Read state only from initial mount because <select> updates value | |
// manually; we need the initial state only for server rendering | |
if (inst._wrapperState.selected != null) { | |
nativeProps.selected = inst._wrapperState.selected; | |
} | |
var content = ''; | |
// Flatten children and warn if they aren't strings or numbers; | |
// invalid types are ignored. | |
ReactChildren.forEach(props.children, function (child) { | |
if (child == null) { | |
return; | |
} | |
if (typeof child === 'string' || typeof child === 'number') { | |
content += child; | |
} else { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Only strings and numbers are supported as <option> children.') : undefined; | |
} | |
}); | |
if (content) { | |
nativeProps.children = content; | |
} | |
return nativeProps; | |
} | |
}; | |
module.exports = ReactDOMOption; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 166 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactChildren | |
*/ | |
'use strict'; | |
var PooledClass = __webpack_require__(113); | |
var ReactElement = __webpack_require__(99); | |
var emptyFunction = __webpack_require__(73); | |
var traverseAllChildren = __webpack_require__(167); | |
var twoArgumentPooler = PooledClass.twoArgumentPooler; | |
var fourArgumentPooler = PooledClass.fourArgumentPooler; | |
var userProvidedKeyEscapeRegex = /\/(?!\/)/g; | |
function escapeUserProvidedKey(text) { | |
return ('' + text).replace(userProvidedKeyEscapeRegex, '//'); | |
} | |
/** | |
* PooledClass representing the bookkeeping associated with performing a child | |
* traversal. Allows avoiding binding callbacks. | |
* | |
* @constructor ForEachBookKeeping | |
* @param {!function} forEachFunction Function to perform traversal with. | |
* @param {?*} forEachContext Context to perform context with. | |
*/ | |
function ForEachBookKeeping(forEachFunction, forEachContext) { | |
this.func = forEachFunction; | |
this.context = forEachContext; | |
this.count = 0; | |
} | |
ForEachBookKeeping.prototype.destructor = function () { | |
this.func = null; | |
this.context = null; | |
this.count = 0; | |
}; | |
PooledClass.addPoolingTo(ForEachBookKeeping, twoArgumentPooler); | |
function forEachSingleChild(bookKeeping, child, name) { | |
var func = bookKeeping.func; | |
var context = bookKeeping.context; | |
func.call(context, child, bookKeeping.count++); | |
} | |
/** | |
* Iterates through children that are typically specified as `props.children`. | |
* | |
* The provided forEachFunc(child, index) will be called for each | |
* leaf child. | |
* | |
* @param {?*} children Children tree container. | |
* @param {function(*, int)} forEachFunc | |
* @param {*} forEachContext Context for forEachContext. | |
*/ | |
function forEachChildren(children, forEachFunc, forEachContext) { | |
if (children == null) { | |
return children; | |
} | |
var traverseContext = ForEachBookKeeping.getPooled(forEachFunc, forEachContext); | |
traverseAllChildren(children, forEachSingleChild, traverseContext); | |
ForEachBookKeeping.release(traverseContext); | |
} | |
/** | |
* PooledClass representing the bookkeeping associated with performing a child | |
* mapping. Allows avoiding binding callbacks. | |
* | |
* @constructor MapBookKeeping | |
* @param {!*} mapResult Object containing the ordered map of results. | |
* @param {!function} mapFunction Function to perform mapping with. | |
* @param {?*} mapContext Context to perform mapping with. | |
*/ | |
function MapBookKeeping(mapResult, keyPrefix, mapFunction, mapContext) { | |
this.result = mapResult; | |
this.keyPrefix = keyPrefix; | |
this.func = mapFunction; | |
this.context = mapContext; | |
this.count = 0; | |
} | |
MapBookKeeping.prototype.destructor = function () { | |
this.result = null; | |
this.keyPrefix = null; | |
this.func = null; | |
this.context = null; | |
this.count = 0; | |
}; | |
PooledClass.addPoolingTo(MapBookKeeping, fourArgumentPooler); | |
function mapSingleChildIntoContext(bookKeeping, child, childKey) { | |
var result = bookKeeping.result; | |
var keyPrefix = bookKeeping.keyPrefix; | |
var func = bookKeeping.func; | |
var context = bookKeeping.context; | |
var mappedChild = func.call(context, child, bookKeeping.count++); | |
if (Array.isArray(mappedChild)) { | |
mapIntoWithKeyPrefixInternal(mappedChild, result, childKey, emptyFunction.thatReturnsArgument); | |
} else if (mappedChild != null) { | |
if (ReactElement.isValidElement(mappedChild)) { | |
mappedChild = ReactElement.cloneAndReplaceKey(mappedChild, | |
// Keep both the (mapped) and old keys if they differ, just as | |
// traverseAllChildren used to do for objects as children | |
keyPrefix + (mappedChild !== child ? escapeUserProvidedKey(mappedChild.key || '') + '/' : '') + childKey); | |
} | |
result.push(mappedChild); | |
} | |
} | |
function mapIntoWithKeyPrefixInternal(children, array, prefix, func, context) { | |
var escapedPrefix = ''; | |
if (prefix != null) { | |
escapedPrefix = escapeUserProvidedKey(prefix) + '/'; | |
} | |
var traverseContext = MapBookKeeping.getPooled(array, escapedPrefix, func, context); | |
traverseAllChildren(children, mapSingleChildIntoContext, traverseContext); | |
MapBookKeeping.release(traverseContext); | |
} | |
/** | |
* Maps children that are typically specified as `props.children`. | |
* | |
* The provided mapFunction(child, key, index) will be called for each | |
* leaf child. | |
* | |
* @param {?*} children Children tree container. | |
* @param {function(*, int)} func The map function. | |
* @param {*} context Context for mapFunction. | |
* @return {object} Object containing the ordered map of results. | |
*/ | |
function mapChildren(children, func, context) { | |
if (children == null) { | |
return children; | |
} | |
var result = []; | |
mapIntoWithKeyPrefixInternal(children, result, null, func, context); | |
return result; | |
} | |
function forEachSingleChildDummy(traverseContext, child, name) { | |
return null; | |
} | |
/** | |
* Count the number of children that are typically specified as | |
* `props.children`. | |
* | |
* @param {?*} children Children tree container. | |
* @return {number} The number of children. | |
*/ | |
function countChildren(children, context) { | |
return traverseAllChildren(children, forEachSingleChildDummy, null); | |
} | |
/** | |
* Flatten a children object (typically specified as `props.children`) and | |
* return an array with appropriately re-keyed children. | |
*/ | |
function toArray(children) { | |
var result = []; | |
mapIntoWithKeyPrefixInternal(children, result, null, emptyFunction.thatReturnsArgument); | |
return result; | |
} | |
var ReactChildren = { | |
forEach: forEachChildren, | |
map: mapChildren, | |
mapIntoWithKeyPrefixInternal: mapIntoWithKeyPrefixInternal, | |
count: countChildren, | |
toArray: toArray | |
}; | |
module.exports = ReactChildren; | |
/***/ }, | |
/* 167 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule traverseAllChildren | |
*/ | |
'use strict'; | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactElement = __webpack_require__(99); | |
var ReactInstanceHandles = __webpack_require__(102); | |
var getIteratorFn = __webpack_require__(164); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
var SEPARATOR = ReactInstanceHandles.SEPARATOR; | |
var SUBSEPARATOR = ':'; | |
/** | |
* TODO: Test that a single child and an array with one item have the same key | |
* pattern. | |
*/ | |
var userProvidedKeyEscaperLookup = { | |
'=': '=0', | |
'.': '=1', | |
':': '=2' | |
}; | |
var userProvidedKeyEscapeRegex = /[=.:]/g; | |
var didWarnAboutMaps = false; | |
function userProvidedKeyEscaper(match) { | |
return userProvidedKeyEscaperLookup[match]; | |
} | |
/** | |
* Generate a key string that identifies a component within a set. | |
* | |
* @param {*} component A component that could contain a manual key. | |
* @param {number} index Index that is used if a manual key is not provided. | |
* @return {string} | |
*/ | |
function getComponentKey(component, index) { | |
if (component && component.key != null) { | |
// Explicit key | |
return wrapUserProvidedKey(component.key); | |
} | |
// Implicit key determined by the index in the set | |
return index.toString(36); | |
} | |
/** | |
* Escape a component key so that it is safe to use in a reactid. | |
* | |
* @param {*} text Component key to be escaped. | |
* @return {string} An escaped string. | |
*/ | |
function escapeUserProvidedKey(text) { | |
return ('' + text).replace(userProvidedKeyEscapeRegex, userProvidedKeyEscaper); | |
} | |
/** | |
* Wrap a `key` value explicitly provided by the user to distinguish it from | |
* implicitly-generated keys generated by a component's index in its parent. | |
* | |
* @param {string} key Value of a user-provided `key` attribute | |
* @return {string} | |
*/ | |
function wrapUserProvidedKey(key) { | |
return '$' + escapeUserProvidedKey(key); | |
} | |
/** | |
* @param {?*} children Children tree container. | |
* @param {!string} nameSoFar Name of the key path so far. | |
* @param {!function} callback Callback to invoke with each child found. | |
* @param {?*} traverseContext Used to pass information throughout the traversal | |
* process. | |
* @return {!number} The number of children in this subtree. | |
*/ | |
function traverseAllChildrenImpl(children, nameSoFar, callback, traverseContext) { | |
var type = typeof children; | |
if (type === 'undefined' || type === 'boolean') { | |
// All of the above are perceived as null. | |
children = null; | |
} | |
if (children === null || type === 'string' || type === 'number' || ReactElement.isValidElement(children)) { | |
callback(traverseContext, children, | |
// If it's the only child, treat the name as if it was wrapped in an array | |
// so that it's consistent if the number of children grows. | |
nameSoFar === '' ? SEPARATOR + getComponentKey(children, 0) : nameSoFar); | |
return 1; | |
} | |
var child; | |
var nextName; | |
var subtreeCount = 0; // Count of children found in the current subtree. | |
var nextNamePrefix = nameSoFar === '' ? SEPARATOR : nameSoFar + SUBSEPARATOR; | |
if (Array.isArray(children)) { | |
for (var i = 0; i < children.length; i++) { | |
child = children[i]; | |
nextName = nextNamePrefix + getComponentKey(child, i); | |
subtreeCount += traverseAllChildrenImpl(child, nextName, callback, traverseContext); | |
} | |
} else { | |
var iteratorFn = getIteratorFn(children); | |
if (iteratorFn) { | |
var iterator = iteratorFn.call(children); | |
var step; | |
if (iteratorFn !== children.entries) { | |
var ii = 0; | |
while (!(step = iterator.next()).done) { | |
child = step.value; | |
nextName = nextNamePrefix + getComponentKey(child, ii++); | |
subtreeCount += traverseAllChildrenImpl(child, nextName, callback, traverseContext); | |
} | |
} else { | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(didWarnAboutMaps, 'Using Maps as children is not yet fully supported. It is an ' + 'experimental feature that might be removed. Convert it to a ' + 'sequence / iterable of keyed ReactElements instead.') : undefined; | |
didWarnAboutMaps = true; | |
} | |
// Iterator will provide entry [k,v] tuples rather than values. | |
while (!(step = iterator.next()).done) { | |
var entry = step.value; | |
if (entry) { | |
child = entry[1]; | |
nextName = nextNamePrefix + wrapUserProvidedKey(entry[0]) + SUBSEPARATOR + getComponentKey(child, 0); | |
subtreeCount += traverseAllChildrenImpl(child, nextName, callback, traverseContext); | |
} | |
} | |
} | |
} else if (type === 'object') { | |
var addendum = ''; | |
if (process.env.NODE_ENV !== 'production') { | |
addendum = ' If you meant to render a collection of children, use an array ' + 'instead or wrap the object using createFragment(object) from the ' + 'React add-ons.'; | |
if (children._isReactElement) { | |
addendum = ' It looks like you\'re using an element created by a different ' + 'version of React. Make sure to use only one copy of React.'; | |
} | |
if (ReactCurrentOwner.current) { | |
var name = ReactCurrentOwner.current.getName(); | |
if (name) { | |
addendum += ' Check the render method of `' + name + '`.'; | |
} | |
} | |
} | |
var childrenString = String(children); | |
true ? process.env.NODE_ENV !== 'production' ? invariant(false, 'Objects are not valid as a React child (found: %s).%s', childrenString === '[object Object]' ? 'object with keys {' + Object.keys(children).join(', ') + '}' : childrenString, addendum) : invariant(false) : undefined; | |
} | |
} | |
return subtreeCount; | |
} | |
/** | |
* Traverses children that are typically specified as `props.children`, but | |
* might also be specified through attributes: | |
* | |
* - `traverseAllChildren(this.props.children, ...)` | |
* - `traverseAllChildren(this.props.leftPanelChildren, ...)` | |
* | |
* The `traverseContext` is an optional argument that is passed through the | |
* entire traversal. It can be used to store accumulations or anything else that | |
* the callback might find relevant. | |
* | |
* @param {?*} children Children tree object. | |
* @param {!function} callback To invoke upon traversing each child. | |
* @param {?*} traverseContext Context for traversal. | |
* @return {!number} The number of children in this subtree. | |
*/ | |
function traverseAllChildren(children, callback, traverseContext) { | |
if (children == null) { | |
return 0; | |
} | |
return traverseAllChildrenImpl(children, '', callback, traverseContext); | |
} | |
module.exports = traverseAllChildren; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 168 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMSelect | |
*/ | |
'use strict'; | |
var LinkedValueUtils = __webpack_require__(162); | |
var ReactMount = __webpack_require__(86); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var warning = __webpack_require__(83); | |
var valueContextKey = '__ReactDOMSelect_value$' + Math.random().toString(36).slice(2); | |
function updateOptionsIfPendingUpdateAndMounted() { | |
if (this._rootNodeID && this._wrapperState.pendingUpdate) { | |
this._wrapperState.pendingUpdate = false; | |
var props = this._currentElement.props; | |
var value = LinkedValueUtils.getValue(props); | |
if (value != null) { | |
updateOptions(this, Boolean(props.multiple), value); | |
} | |
} | |
} | |
function getDeclarationErrorAddendum(owner) { | |
if (owner) { | |
var name = owner.getName(); | |
if (name) { | |
return ' Check the render method of `' + name + '`.'; | |
} | |
} | |
return ''; | |
} | |
var valuePropNames = ['value', 'defaultValue']; | |
/** | |
* Validation function for `value` and `defaultValue`. | |
* @private | |
*/ | |
function checkSelectPropTypes(inst, props) { | |
var owner = inst._currentElement._owner; | |
LinkedValueUtils.checkPropTypes('select', props, owner); | |
for (var i = 0; i < valuePropNames.length; i++) { | |
var propName = valuePropNames[i]; | |
if (props[propName] == null) { | |
continue; | |
} | |
if (props.multiple) { | |
process.env.NODE_ENV !== 'production' ? warning(Array.isArray(props[propName]), 'The `%s` prop supplied to <select> must be an array if ' + '`multiple` is true.%s', propName, getDeclarationErrorAddendum(owner)) : undefined; | |
} else { | |
process.env.NODE_ENV !== 'production' ? warning(!Array.isArray(props[propName]), 'The `%s` prop supplied to <select> must be a scalar ' + 'value if `multiple` is false.%s', propName, getDeclarationErrorAddendum(owner)) : undefined; | |
} | |
} | |
} | |
/** | |
* @param {ReactDOMComponent} inst | |
* @param {boolean} multiple | |
* @param {*} propValue A stringable (with `multiple`, a list of stringables). | |
* @private | |
*/ | |
function updateOptions(inst, multiple, propValue) { | |
var selectedValue, i; | |
var options = ReactMount.getNode(inst._rootNodeID).options; | |
if (multiple) { | |
selectedValue = {}; | |
for (i = 0; i < propValue.length; i++) { | |
selectedValue['' + propValue[i]] = true; | |
} | |
for (i = 0; i < options.length; i++) { | |
var selected = selectedValue.hasOwnProperty(options[i].value); | |
if (options[i].selected !== selected) { | |
options[i].selected = selected; | |
} | |
} | |
} else { | |
// Do not set `select.value` as exact behavior isn't consistent across all | |
// browsers for all cases. | |
selectedValue = '' + propValue; | |
for (i = 0; i < options.length; i++) { | |
if (options[i].value === selectedValue) { | |
options[i].selected = true; | |
return; | |
} | |
} | |
if (options.length) { | |
options[0].selected = true; | |
} | |
} | |
} | |
/** | |
* Implements a <select> native component that allows optionally setting the | |
* props `value` and `defaultValue`. If `multiple` is false, the prop must be a | |
* stringable. If `multiple` is true, the prop must be an array of stringables. | |
* | |
* If `value` is not supplied (or null/undefined), user actions that change the | |
* selected option will trigger updates to the rendered options. | |
* | |
* If it is supplied (and not null/undefined), the rendered options will not | |
* update in response to user actions. Instead, the `value` prop must change in | |
* order for the rendered options to update. | |
* | |
* If `defaultValue` is provided, any options with the supplied values will be | |
* selected. | |
*/ | |
var ReactDOMSelect = { | |
valueContextKey: valueContextKey, | |
getNativeProps: function (inst, props, context) { | |
return assign({}, props, { | |
onChange: inst._wrapperState.onChange, | |
value: undefined | |
}); | |
}, | |
mountWrapper: function (inst, props) { | |
if (process.env.NODE_ENV !== 'production') { | |
checkSelectPropTypes(inst, props); | |
} | |
var value = LinkedValueUtils.getValue(props); | |
inst._wrapperState = { | |
pendingUpdate: false, | |
initialValue: value != null ? value : props.defaultValue, | |
onChange: _handleChange.bind(inst), | |
wasMultiple: Boolean(props.multiple) | |
}; | |
}, | |
processChildContext: function (inst, props, context) { | |
// Pass down initial value so initial generated markup has correct | |
// `selected` attributes | |
var childContext = assign({}, context); | |
childContext[valueContextKey] = inst._wrapperState.initialValue; | |
return childContext; | |
}, | |
postUpdateWrapper: function (inst) { | |
var props = inst._currentElement.props; | |
// After the initial mount, we control selected-ness manually so don't pass | |
// the context value down | |
inst._wrapperState.initialValue = undefined; | |
var wasMultiple = inst._wrapperState.wasMultiple; | |
inst._wrapperState.wasMultiple = Boolean(props.multiple); | |
var value = LinkedValueUtils.getValue(props); | |
if (value != null) { | |
inst._wrapperState.pendingUpdate = false; | |
updateOptions(inst, Boolean(props.multiple), value); | |
} else if (wasMultiple !== Boolean(props.multiple)) { | |
// For simplicity, reapply `defaultValue` if `multiple` is toggled. | |
if (props.defaultValue != null) { | |
updateOptions(inst, Boolean(props.multiple), props.defaultValue); | |
} else { | |
// Revert the select back to its default unselected state. | |
updateOptions(inst, Boolean(props.multiple), props.multiple ? [] : ''); | |
} | |
} | |
} | |
}; | |
function _handleChange(event) { | |
var props = this._currentElement.props; | |
var returnValue = LinkedValueUtils.executeOnChange(props, event); | |
this._wrapperState.pendingUpdate = true; | |
ReactUpdates.asap(updateOptionsIfPendingUpdateAndMounted, this); | |
return returnValue; | |
} | |
module.exports = ReactDOMSelect; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 169 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMTextarea | |
*/ | |
'use strict'; | |
var LinkedValueUtils = __webpack_require__(162); | |
var ReactDOMIDOperations = __webpack_require__(85); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
function forceUpdateIfMounted() { | |
if (this._rootNodeID) { | |
// DOM component is still mounted; update | |
ReactDOMTextarea.updateWrapper(this); | |
} | |
} | |
/** | |
* Implements a <textarea> native component that allows setting `value`, and | |
* `defaultValue`. This differs from the traditional DOM API because value is | |
* usually set as PCDATA children. | |
* | |
* If `value` is not supplied (or null/undefined), user actions that affect the | |
* value will trigger updates to the element. | |
* | |
* If `value` is supplied (and not null/undefined), the rendered element will | |
* not trigger updates to the element. Instead, the `value` prop must change in | |
* order for the rendered element to be updated. | |
* | |
* The rendered element will be initialized with an empty value, the prop | |
* `defaultValue` if specified, or the children content (deprecated). | |
*/ | |
var ReactDOMTextarea = { | |
getNativeProps: function (inst, props, context) { | |
!(props.dangerouslySetInnerHTML == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, '`dangerouslySetInnerHTML` does not make sense on <textarea>.') : invariant(false) : undefined; | |
// Always set children to the same thing. In IE9, the selection range will | |
// get reset if `textContent` is mutated. | |
var nativeProps = assign({}, props, { | |
defaultValue: undefined, | |
value: undefined, | |
children: inst._wrapperState.initialValue, | |
onChange: inst._wrapperState.onChange | |
}); | |
return nativeProps; | |
}, | |
mountWrapper: function (inst, props) { | |
if (process.env.NODE_ENV !== 'production') { | |
LinkedValueUtils.checkPropTypes('textarea', props, inst._currentElement._owner); | |
} | |
var defaultValue = props.defaultValue; | |
// TODO (yungsters): Remove support for children content in <textarea>. | |
var children = props.children; | |
if (children != null) { | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'Use the `defaultValue` or `value` props instead of setting ' + 'children on <textarea>.') : undefined; | |
} | |
!(defaultValue == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'If you supply `defaultValue` on a <textarea>, do not pass children.') : invariant(false) : undefined; | |
if (Array.isArray(children)) { | |
!(children.length <= 1) ? process.env.NODE_ENV !== 'production' ? invariant(false, '<textarea> can only have at most one child.') : invariant(false) : undefined; | |
children = children[0]; | |
} | |
defaultValue = '' + children; | |
} | |
if (defaultValue == null) { | |
defaultValue = ''; | |
} | |
var value = LinkedValueUtils.getValue(props); | |
inst._wrapperState = { | |
// We save the initial value so that `ReactDOMComponent` doesn't update | |
// `textContent` (unnecessary since we update value). | |
// The initial value can be a boolean or object so that's why it's | |
// forced to be a string. | |
initialValue: '' + (value != null ? value : defaultValue), | |
onChange: _handleChange.bind(inst) | |
}; | |
}, | |
updateWrapper: function (inst) { | |
var props = inst._currentElement.props; | |
var value = LinkedValueUtils.getValue(props); | |
if (value != null) { | |
// Cast `value` to a string to ensure the value is set correctly. While | |
// browsers typically do this as necessary, jsdom doesn't. | |
ReactDOMIDOperations.updatePropertyByID(inst._rootNodeID, 'value', '' + value); | |
} | |
} | |
}; | |
function _handleChange(event) { | |
var props = this._currentElement.props; | |
var returnValue = LinkedValueUtils.executeOnChange(props, event); | |
ReactUpdates.asap(forceUpdateIfMounted, this); | |
return returnValue; | |
} | |
module.exports = ReactDOMTextarea; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 170 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactMultiChild | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactComponentEnvironment = __webpack_require__(121); | |
var ReactMultiChildUpdateTypes = __webpack_require__(74); | |
var ReactCurrentOwner = __webpack_require__(64); | |
var ReactReconciler = __webpack_require__(107); | |
var ReactChildReconciler = __webpack_require__(171); | |
var flattenChildren = __webpack_require__(172); | |
/** | |
* Updating children of a component may trigger recursive updates. The depth is | |
* used to batch recursive updates to render markup more efficiently. | |
* | |
* @type {number} | |
* @private | |
*/ | |
var updateDepth = 0; | |
/** | |
* Queue of update configuration objects. | |
* | |
* Each object has a `type` property that is in `ReactMultiChildUpdateTypes`. | |
* | |
* @type {array<object>} | |
* @private | |
*/ | |
var updateQueue = []; | |
/** | |
* Queue of markup to be rendered. | |
* | |
* @type {array<string>} | |
* @private | |
*/ | |
var markupQueue = []; | |
/** | |
* Enqueues markup to be rendered and inserted at a supplied index. | |
* | |
* @param {string} parentID ID of the parent component. | |
* @param {string} markup Markup that renders into an element. | |
* @param {number} toIndex Destination index. | |
* @private | |
*/ | |
function enqueueInsertMarkup(parentID, markup, toIndex) { | |
// NOTE: Null values reduce hidden classes. | |
updateQueue.push({ | |
parentID: parentID, | |
parentNode: null, | |
type: ReactMultiChildUpdateTypes.INSERT_MARKUP, | |
markupIndex: markupQueue.push(markup) - 1, | |
content: null, | |
fromIndex: null, | |
toIndex: toIndex | |
}); | |
} | |
/** | |
* Enqueues moving an existing element to another index. | |
* | |
* @param {string} parentID ID of the parent component. | |
* @param {number} fromIndex Source index of the existing element. | |
* @param {number} toIndex Destination index of the element. | |
* @private | |
*/ | |
function enqueueMove(parentID, fromIndex, toIndex) { | |
// NOTE: Null values reduce hidden classes. | |
updateQueue.push({ | |
parentID: parentID, | |
parentNode: null, | |
type: ReactMultiChildUpdateTypes.MOVE_EXISTING, | |
markupIndex: null, | |
content: null, | |
fromIndex: fromIndex, | |
toIndex: toIndex | |
}); | |
} | |
/** | |
* Enqueues removing an element at an index. | |
* | |
* @param {string} parentID ID of the parent component. | |
* @param {number} fromIndex Index of the element to remove. | |
* @private | |
*/ | |
function enqueueRemove(parentID, fromIndex) { | |
// NOTE: Null values reduce hidden classes. | |
updateQueue.push({ | |
parentID: parentID, | |
parentNode: null, | |
type: ReactMultiChildUpdateTypes.REMOVE_NODE, | |
markupIndex: null, | |
content: null, | |
fromIndex: fromIndex, | |
toIndex: null | |
}); | |
} | |
/** | |
* Enqueues setting the markup of a node. | |
* | |
* @param {string} parentID ID of the parent component. | |
* @param {string} markup Markup that renders into an element. | |
* @private | |
*/ | |
function enqueueSetMarkup(parentID, markup) { | |
// NOTE: Null values reduce hidden classes. | |
updateQueue.push({ | |
parentID: parentID, | |
parentNode: null, | |
type: ReactMultiChildUpdateTypes.SET_MARKUP, | |
markupIndex: null, | |
content: markup, | |
fromIndex: null, | |
toIndex: null | |
}); | |
} | |
/** | |
* Enqueues setting the text content. | |
* | |
* @param {string} parentID ID of the parent component. | |
* @param {string} textContent Text content to set. | |
* @private | |
*/ | |
function enqueueTextContent(parentID, textContent) { | |
// NOTE: Null values reduce hidden classes. | |
updateQueue.push({ | |
parentID: parentID, | |
parentNode: null, | |
type: ReactMultiChildUpdateTypes.TEXT_CONTENT, | |
markupIndex: null, | |
content: textContent, | |
fromIndex: null, | |
toIndex: null | |
}); | |
} | |
/** | |
* Processes any enqueued updates. | |
* | |
* @private | |
*/ | |
function processQueue() { | |
if (updateQueue.length) { | |
ReactComponentEnvironment.processChildrenUpdates(updateQueue, markupQueue); | |
clearQueue(); | |
} | |
} | |
/** | |
* Clears any enqueued updates. | |
* | |
* @private | |
*/ | |
function clearQueue() { | |
updateQueue.length = 0; | |
markupQueue.length = 0; | |
} | |
/** | |
* ReactMultiChild are capable of reconciling multiple children. | |
* | |
* @class ReactMultiChild | |
* @internal | |
*/ | |
var ReactMultiChild = { | |
/** | |
* Provides common functionality for components that must reconcile multiple | |
* children. This is used by `ReactDOMComponent` to mount, update, and | |
* unmount child components. | |
* | |
* @lends {ReactMultiChild.prototype} | |
*/ | |
Mixin: { | |
_reconcilerInstantiateChildren: function (nestedChildren, transaction, context) { | |
if (process.env.NODE_ENV !== 'production') { | |
if (this._currentElement) { | |
try { | |
ReactCurrentOwner.current = this._currentElement._owner; | |
return ReactChildReconciler.instantiateChildren(nestedChildren, transaction, context); | |
} finally { | |
ReactCurrentOwner.current = null; | |
} | |
} | |
} | |
return ReactChildReconciler.instantiateChildren(nestedChildren, transaction, context); | |
}, | |
_reconcilerUpdateChildren: function (prevChildren, nextNestedChildrenElements, transaction, context) { | |
var nextChildren; | |
if (process.env.NODE_ENV !== 'production') { | |
if (this._currentElement) { | |
try { | |
ReactCurrentOwner.current = this._currentElement._owner; | |
nextChildren = flattenChildren(nextNestedChildrenElements); | |
} finally { | |
ReactCurrentOwner.current = null; | |
} | |
return ReactChildReconciler.updateChildren(prevChildren, nextChildren, transaction, context); | |
} | |
} | |
nextChildren = flattenChildren(nextNestedChildrenElements); | |
return ReactChildReconciler.updateChildren(prevChildren, nextChildren, transaction, context); | |
}, | |
/** | |
* Generates a "mount image" for each of the supplied children. In the case | |
* of `ReactDOMComponent`, a mount image is a string of markup. | |
* | |
* @param {?object} nestedChildren Nested child maps. | |
* @return {array} An array of mounted representations. | |
* @internal | |
*/ | |
mountChildren: function (nestedChildren, transaction, context) { | |
var children = this._reconcilerInstantiateChildren(nestedChildren, transaction, context); | |
this._renderedChildren = children; | |
var mountImages = []; | |
var index = 0; | |
for (var name in children) { | |
if (children.hasOwnProperty(name)) { | |
var child = children[name]; | |
// Inlined for performance, see `ReactInstanceHandles.createReactID`. | |
var rootID = this._rootNodeID + name; | |
var mountImage = ReactReconciler.mountComponent(child, rootID, transaction, context); | |
child._mountIndex = index++; | |
mountImages.push(mountImage); | |
} | |
} | |
return mountImages; | |
}, | |
/** | |
* Replaces any rendered children with a text content string. | |
* | |
* @param {string} nextContent String of content. | |
* @internal | |
*/ | |
updateTextContent: function (nextContent) { | |
updateDepth++; | |
var errorThrown = true; | |
try { | |
var prevChildren = this._renderedChildren; | |
// Remove any rendered children. | |
ReactChildReconciler.unmountChildren(prevChildren); | |
// TODO: The setTextContent operation should be enough | |
for (var name in prevChildren) { | |
if (prevChildren.hasOwnProperty(name)) { | |
this._unmountChild(prevChildren[name]); | |
} | |
} | |
// Set new text content. | |
this.setTextContent(nextContent); | |
errorThrown = false; | |
} finally { | |
updateDepth--; | |
if (!updateDepth) { | |
if (errorThrown) { | |
clearQueue(); | |
} else { | |
processQueue(); | |
} | |
} | |
} | |
}, | |
/** | |
* Replaces any rendered children with a markup string. | |
* | |
* @param {string} nextMarkup String of markup. | |
* @internal | |
*/ | |
updateMarkup: function (nextMarkup) { | |
updateDepth++; | |
var errorThrown = true; | |
try { | |
var prevChildren = this._renderedChildren; | |
// Remove any rendered children. | |
ReactChildReconciler.unmountChildren(prevChildren); | |
for (var name in prevChildren) { | |
if (prevChildren.hasOwnProperty(name)) { | |
this._unmountChildByName(prevChildren[name], name); | |
} | |
} | |
this.setMarkup(nextMarkup); | |
errorThrown = false; | |
} finally { | |
updateDepth--; | |
if (!updateDepth) { | |
if (errorThrown) { | |
clearQueue(); | |
} else { | |
processQueue(); | |
} | |
} | |
} | |
}, | |
/** | |
* Updates the rendered children with new children. | |
* | |
* @param {?object} nextNestedChildrenElements Nested child element maps. | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
*/ | |
updateChildren: function (nextNestedChildrenElements, transaction, context) { | |
updateDepth++; | |
var errorThrown = true; | |
try { | |
this._updateChildren(nextNestedChildrenElements, transaction, context); | |
errorThrown = false; | |
} finally { | |
updateDepth--; | |
if (!updateDepth) { | |
if (errorThrown) { | |
clearQueue(); | |
} else { | |
processQueue(); | |
} | |
} | |
} | |
}, | |
/** | |
* Improve performance by isolating this hot code path from the try/catch | |
* block in `updateChildren`. | |
* | |
* @param {?object} nextNestedChildrenElements Nested child element maps. | |
* @param {ReactReconcileTransaction} transaction | |
* @final | |
* @protected | |
*/ | |
_updateChildren: function (nextNestedChildrenElements, transaction, context) { | |
var prevChildren = this._renderedChildren; | |
var nextChildren = this._reconcilerUpdateChildren(prevChildren, nextNestedChildrenElements, transaction, context); | |
this._renderedChildren = nextChildren; | |
if (!nextChildren && !prevChildren) { | |
return; | |
} | |
var name; | |
// `nextIndex` will increment for each child in `nextChildren`, but | |
// `lastIndex` will be the last index visited in `prevChildren`. | |
var lastIndex = 0; | |
var nextIndex = 0; | |
for (name in nextChildren) { | |
if (!nextChildren.hasOwnProperty(name)) { | |
continue; | |
} | |
var prevChild = prevChildren && prevChildren[name]; | |
var nextChild = nextChildren[name]; | |
if (prevChild === nextChild) { | |
this.moveChild(prevChild, nextIndex, lastIndex); | |
lastIndex = Math.max(prevChild._mountIndex, lastIndex); | |
prevChild._mountIndex = nextIndex; | |
} else { | |
if (prevChild) { | |
// Update `lastIndex` before `_mountIndex` gets unset by unmounting. | |
lastIndex = Math.max(prevChild._mountIndex, lastIndex); | |
this._unmountChild(prevChild); | |
} | |
// The child must be instantiated before it's mounted. | |
this._mountChildByNameAtIndex(nextChild, name, nextIndex, transaction, context); | |
} | |
nextIndex++; | |
} | |
// Remove children that are no longer present. | |
for (name in prevChildren) { | |
if (prevChildren.hasOwnProperty(name) && !(nextChildren && nextChildren.hasOwnProperty(name))) { | |
this._unmountChild(prevChildren[name]); | |
} | |
} | |
}, | |
/** | |
* Unmounts all rendered children. This should be used to clean up children | |
* when this component is unmounted. | |
* | |
* @internal | |
*/ | |
unmountChildren: function () { | |
var renderedChildren = this._renderedChildren; | |
ReactChildReconciler.unmountChildren(renderedChildren); | |
this._renderedChildren = null; | |
}, | |
/** | |
* Moves a child component to the supplied index. | |
* | |
* @param {ReactComponent} child Component to move. | |
* @param {number} toIndex Destination index of the element. | |
* @param {number} lastIndex Last index visited of the siblings of `child`. | |
* @protected | |
*/ | |
moveChild: function (child, toIndex, lastIndex) { | |
// If the index of `child` is less than `lastIndex`, then it needs to | |
// be moved. Otherwise, we do not need to move it because a child will be | |
// inserted or moved before `child`. | |
if (child._mountIndex < lastIndex) { | |
enqueueMove(this._rootNodeID, child._mountIndex, toIndex); | |
} | |
}, | |
/** | |
* Creates a child component. | |
* | |
* @param {ReactComponent} child Component to create. | |
* @param {string} mountImage Markup to insert. | |
* @protected | |
*/ | |
createChild: function (child, mountImage) { | |
enqueueInsertMarkup(this._rootNodeID, mountImage, child._mountIndex); | |
}, | |
/** | |
* Removes a child component. | |
* | |
* @param {ReactComponent} child Child to remove. | |
* @protected | |
*/ | |
removeChild: function (child) { | |
enqueueRemove(this._rootNodeID, child._mountIndex); | |
}, | |
/** | |
* Sets this text content string. | |
* | |
* @param {string} textContent Text content to set. | |
* @protected | |
*/ | |
setTextContent: function (textContent) { | |
enqueueTextContent(this._rootNodeID, textContent); | |
}, | |
/** | |
* Sets this markup string. | |
* | |
* @param {string} markup Markup to set. | |
* @protected | |
*/ | |
setMarkup: function (markup) { | |
enqueueSetMarkup(this._rootNodeID, markup); | |
}, | |
/** | |
* Mounts a child with the supplied name. | |
* | |
* NOTE: This is part of `updateChildren` and is here for readability. | |
* | |
* @param {ReactComponent} child Component to mount. | |
* @param {string} name Name of the child. | |
* @param {number} index Index at which to insert the child. | |
* @param {ReactReconcileTransaction} transaction | |
* @private | |
*/ | |
_mountChildByNameAtIndex: function (child, name, index, transaction, context) { | |
// Inlined for performance, see `ReactInstanceHandles.createReactID`. | |
var rootID = this._rootNodeID + name; | |
var mountImage = ReactReconciler.mountComponent(child, rootID, transaction, context); | |
child._mountIndex = index; | |
this.createChild(child, mountImage); | |
}, | |
/** | |
* Unmounts a rendered child. | |
* | |
* NOTE: This is part of `updateChildren` and is here for readability. | |
* | |
* @param {ReactComponent} child Component to unmount. | |
* @private | |
*/ | |
_unmountChild: function (child) { | |
this.removeChild(child); | |
child._mountIndex = null; | |
} | |
} | |
}; | |
module.exports = ReactMultiChild; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 171 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2014-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactChildReconciler | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var ReactReconciler = __webpack_require__(107); | |
var instantiateReactComponent = __webpack_require__(119); | |
var shouldUpdateReactComponent = __webpack_require__(124); | |
var traverseAllChildren = __webpack_require__(167); | |
var warning = __webpack_require__(83); | |
function instantiateChild(childInstances, child, name) { | |
// We found a component instance. | |
var keyUnique = childInstances[name] === undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(keyUnique, 'flattenChildren(...): Encountered two children with the same key, ' + '`%s`. Child keys must be unique; when two children share a key, only ' + 'the first child will be used.', name) : undefined; | |
} | |
if (child != null && keyUnique) { | |
childInstances[name] = instantiateReactComponent(child, null); | |
} | |
} | |
/** | |
* ReactChildReconciler provides helpers for initializing or updating a set of | |
* children. Its output is suitable for passing it onto ReactMultiChild which | |
* does diffed reordering and insertion. | |
*/ | |
var ReactChildReconciler = { | |
/** | |
* Generates a "mount image" for each of the supplied children. In the case | |
* of `ReactDOMComponent`, a mount image is a string of markup. | |
* | |
* @param {?object} nestedChildNodes Nested child maps. | |
* @return {?object} A set of child instances. | |
* @internal | |
*/ | |
instantiateChildren: function (nestedChildNodes, transaction, context) { | |
if (nestedChildNodes == null) { | |
return null; | |
} | |
var childInstances = {}; | |
traverseAllChildren(nestedChildNodes, instantiateChild, childInstances); | |
return childInstances; | |
}, | |
/** | |
* Updates the rendered children and returns a new set of children. | |
* | |
* @param {?object} prevChildren Previously initialized set of children. | |
* @param {?object} nextChildren Flat child element maps. | |
* @param {ReactReconcileTransaction} transaction | |
* @param {object} context | |
* @return {?object} A new set of child instances. | |
* @internal | |
*/ | |
updateChildren: function (prevChildren, nextChildren, transaction, context) { | |
// We currently don't have a way to track moves here but if we use iterators | |
// instead of for..in we can zip the iterators and check if an item has | |
// moved. | |
// TODO: If nothing has changed, return the prevChildren object so that we | |
// can quickly bailout if nothing has changed. | |
if (!nextChildren && !prevChildren) { | |
return null; | |
} | |
var name; | |
for (name in nextChildren) { | |
if (!nextChildren.hasOwnProperty(name)) { | |
continue; | |
} | |
var prevChild = prevChildren && prevChildren[name]; | |
var prevElement = prevChild && prevChild._currentElement; | |
var nextElement = nextChildren[name]; | |
if (prevChild != null && shouldUpdateReactComponent(prevElement, nextElement)) { | |
ReactReconciler.receiveComponent(prevChild, nextElement, transaction, context); | |
nextChildren[name] = prevChild; | |
} else { | |
if (prevChild) { | |
ReactReconciler.unmountComponent(prevChild, name); | |
} | |
// The child must be instantiated before it's mounted. | |
var nextChildInstance = instantiateReactComponent(nextElement, null); | |
nextChildren[name] = nextChildInstance; | |
} | |
} | |
// Unmount children that are no longer present. | |
for (name in prevChildren) { | |
if (prevChildren.hasOwnProperty(name) && !(nextChildren && nextChildren.hasOwnProperty(name))) { | |
ReactReconciler.unmountComponent(prevChildren[name]); | |
} | |
} | |
return nextChildren; | |
}, | |
/** | |
* Unmounts all rendered children. This should be used to clean up children | |
* when this component is unmounted. | |
* | |
* @param {?object} renderedChildren Previously initialized set of children. | |
* @internal | |
*/ | |
unmountChildren: function (renderedChildren) { | |
for (var name in renderedChildren) { | |
if (renderedChildren.hasOwnProperty(name)) { | |
var renderedChild = renderedChildren[name]; | |
ReactReconciler.unmountComponent(renderedChild); | |
} | |
} | |
} | |
}; | |
module.exports = ReactChildReconciler; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 172 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule flattenChildren | |
*/ | |
'use strict'; | |
var traverseAllChildren = __webpack_require__(167); | |
var warning = __webpack_require__(83); | |
/** | |
* @param {function} traverseContext Context passed through traversal. | |
* @param {?ReactComponent} child React child component. | |
* @param {!string} name String name of key path to child. | |
*/ | |
function flattenSingleChildIntoContext(traverseContext, child, name) { | |
// We found a component instance. | |
var result = traverseContext; | |
var keyUnique = result[name] === undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(keyUnique, 'flattenChildren(...): Encountered two children with the same key, ' + '`%s`. Child keys must be unique; when two children share a key, only ' + 'the first child will be used.', name) : undefined; | |
} | |
if (keyUnique && child != null) { | |
result[name] = child; | |
} | |
} | |
/** | |
* Flattens children that are typically specified as `props.children`. Any null | |
* children will not be included in the resulting object. | |
* @return {!object} flattened children keyed by name. | |
*/ | |
function flattenChildren(children) { | |
if (children == null) { | |
return children; | |
} | |
var result = {}; | |
traverseAllChildren(children, flattenSingleChildIntoContext, result); | |
return result; | |
} | |
module.exports = flattenChildren; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 173 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule shallowEqual | |
* @typechecks | |
* | |
*/ | |
'use strict'; | |
var hasOwnProperty = Object.prototype.hasOwnProperty; | |
/** | |
* Performs equality by iterating through keys on an object and returning false | |
* when any key has values which are not strictly equal between the arguments. | |
* Returns true when the values of all keys are strictly equal. | |
*/ | |
function shallowEqual(objA, objB) { | |
if (objA === objB) { | |
return true; | |
} | |
if (typeof objA !== 'object' || objA === null || typeof objB !== 'object' || objB === null) { | |
return false; | |
} | |
var keysA = Object.keys(objA); | |
var keysB = Object.keys(objB); | |
if (keysA.length !== keysB.length) { | |
return false; | |
} | |
// Test for A's keys different from B. | |
var bHasOwnProperty = hasOwnProperty.bind(objB); | |
for (var i = 0; i < keysA.length; i++) { | |
if (!bHasOwnProperty(keysA[i]) || objA[keysA[i]] !== objB[keysA[i]]) { | |
return false; | |
} | |
} | |
return true; | |
} | |
module.exports = shallowEqual; | |
/***/ }, | |
/* 174 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactEventListener | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var EventListener = __webpack_require__(175); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var PooledClass = __webpack_require__(113); | |
var ReactInstanceHandles = __webpack_require__(102); | |
var ReactMount = __webpack_require__(86); | |
var ReactUpdates = __webpack_require__(111); | |
var assign = __webpack_require__(29); | |
var getEventTarget = __webpack_require__(137); | |
var getUnboundedScrollPosition = __webpack_require__(176); | |
var DOCUMENT_FRAGMENT_NODE_TYPE = 11; | |
/** | |
* Finds the parent React component of `node`. | |
* | |
* @param {*} node | |
* @return {?DOMEventTarget} Parent container, or `null` if the specified node | |
* is not nested. | |
*/ | |
function findParent(node) { | |
// TODO: It may be a good idea to cache this to prevent unnecessary DOM | |
// traversal, but caching is difficult to do correctly without using a | |
// mutation observer to listen for all DOM changes. | |
var nodeID = ReactMount.getID(node); | |
var rootID = ReactInstanceHandles.getReactRootIDFromNodeID(nodeID); | |
var container = ReactMount.findReactContainerForID(rootID); | |
var parent = ReactMount.getFirstReactDOM(container); | |
return parent; | |
} | |
// Used to store ancestor hierarchy in top level callback | |
function TopLevelCallbackBookKeeping(topLevelType, nativeEvent) { | |
this.topLevelType = topLevelType; | |
this.nativeEvent = nativeEvent; | |
this.ancestors = []; | |
} | |
assign(TopLevelCallbackBookKeeping.prototype, { | |
destructor: function () { | |
this.topLevelType = null; | |
this.nativeEvent = null; | |
this.ancestors.length = 0; | |
} | |
}); | |
PooledClass.addPoolingTo(TopLevelCallbackBookKeeping, PooledClass.twoArgumentPooler); | |
function handleTopLevelImpl(bookKeeping) { | |
// TODO: Re-enable event.path handling | |
// | |
// if (bookKeeping.nativeEvent.path && bookKeeping.nativeEvent.path.length > 1) { | |
// // New browsers have a path attribute on native events | |
// handleTopLevelWithPath(bookKeeping); | |
// } else { | |
// // Legacy browsers don't have a path attribute on native events | |
// handleTopLevelWithoutPath(bookKeeping); | |
// } | |
void handleTopLevelWithPath; // temporarily unused | |
handleTopLevelWithoutPath(bookKeeping); | |
} | |
// Legacy browsers don't have a path attribute on native events | |
function handleTopLevelWithoutPath(bookKeeping) { | |
var topLevelTarget = ReactMount.getFirstReactDOM(getEventTarget(bookKeeping.nativeEvent)) || window; | |
// Loop through the hierarchy, in case there's any nested components. | |
// It's important that we build the array of ancestors before calling any | |
// event handlers, because event handlers can modify the DOM, leading to | |
// inconsistencies with ReactMount's node cache. See #1105. | |
var ancestor = topLevelTarget; | |
while (ancestor) { | |
bookKeeping.ancestors.push(ancestor); | |
ancestor = findParent(ancestor); | |
} | |
for (var i = 0; i < bookKeeping.ancestors.length; i++) { | |
topLevelTarget = bookKeeping.ancestors[i]; | |
var topLevelTargetID = ReactMount.getID(topLevelTarget) || ''; | |
ReactEventListener._handleTopLevel(bookKeeping.topLevelType, topLevelTarget, topLevelTargetID, bookKeeping.nativeEvent, getEventTarget(bookKeeping.nativeEvent)); | |
} | |
} | |
// New browsers have a path attribute on native events | |
function handleTopLevelWithPath(bookKeeping) { | |
var path = bookKeeping.nativeEvent.path; | |
var currentNativeTarget = path[0]; | |
var eventsFired = 0; | |
for (var i = 0; i < path.length; i++) { | |
var currentPathElement = path[i]; | |
if (currentPathElement.nodeType === DOCUMENT_FRAGMENT_NODE_TYPE) { | |
currentNativeTarget = path[i + 1]; | |
} | |
// TODO: slow | |
var reactParent = ReactMount.getFirstReactDOM(currentPathElement); | |
if (reactParent === currentPathElement) { | |
var currentPathElementID = ReactMount.getID(currentPathElement); | |
var newRootID = ReactInstanceHandles.getReactRootIDFromNodeID(currentPathElementID); | |
bookKeeping.ancestors.push(currentPathElement); | |
var topLevelTargetID = ReactMount.getID(currentPathElement) || ''; | |
eventsFired++; | |
ReactEventListener._handleTopLevel(bookKeeping.topLevelType, currentPathElement, topLevelTargetID, bookKeeping.nativeEvent, currentNativeTarget); | |
// Jump to the root of this React render tree | |
while (currentPathElementID !== newRootID) { | |
i++; | |
currentPathElement = path[i]; | |
currentPathElementID = ReactMount.getID(currentPathElement); | |
} | |
} | |
} | |
if (eventsFired === 0) { | |
ReactEventListener._handleTopLevel(bookKeeping.topLevelType, window, '', bookKeeping.nativeEvent, getEventTarget(bookKeeping.nativeEvent)); | |
} | |
} | |
function scrollValueMonitor(cb) { | |
var scrollPosition = getUnboundedScrollPosition(window); | |
cb(scrollPosition); | |
} | |
var ReactEventListener = { | |
_enabled: true, | |
_handleTopLevel: null, | |
WINDOW_HANDLE: ExecutionEnvironment.canUseDOM ? window : null, | |
setHandleTopLevel: function (handleTopLevel) { | |
ReactEventListener._handleTopLevel = handleTopLevel; | |
}, | |
setEnabled: function (enabled) { | |
ReactEventListener._enabled = !!enabled; | |
}, | |
isEnabled: function () { | |
return ReactEventListener._enabled; | |
}, | |
/** | |
* Traps top-level events by using event bubbling. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {string} handlerBaseName Event name (e.g. "click"). | |
* @param {object} handle Element on which to attach listener. | |
* @return {?object} An object with a remove function which will forcefully | |
* remove the listener. | |
* @internal | |
*/ | |
trapBubbledEvent: function (topLevelType, handlerBaseName, handle) { | |
var element = handle; | |
if (!element) { | |
return null; | |
} | |
return EventListener.listen(element, handlerBaseName, ReactEventListener.dispatchEvent.bind(null, topLevelType)); | |
}, | |
/** | |
* Traps a top-level event by using event capturing. | |
* | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {string} handlerBaseName Event name (e.g. "click"). | |
* @param {object} handle Element on which to attach listener. | |
* @return {?object} An object with a remove function which will forcefully | |
* remove the listener. | |
* @internal | |
*/ | |
trapCapturedEvent: function (topLevelType, handlerBaseName, handle) { | |
var element = handle; | |
if (!element) { | |
return null; | |
} | |
return EventListener.capture(element, handlerBaseName, ReactEventListener.dispatchEvent.bind(null, topLevelType)); | |
}, | |
monitorScrollValue: function (refresh) { | |
var callback = scrollValueMonitor.bind(null, refresh); | |
EventListener.listen(window, 'scroll', callback); | |
}, | |
dispatchEvent: function (topLevelType, nativeEvent) { | |
if (!ReactEventListener._enabled) { | |
return; | |
} | |
var bookKeeping = TopLevelCallbackBookKeeping.getPooled(topLevelType, nativeEvent); | |
try { | |
// Event queue being processed in the same cycle allows | |
// `preventDefault`. | |
ReactUpdates.batchedUpdates(handleTopLevelImpl, bookKeeping); | |
} finally { | |
TopLevelCallbackBookKeeping.release(bookKeeping); | |
} | |
} | |
}; | |
module.exports = ReactEventListener; | |
/***/ }, | |
/* 175 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* | |
* Licensed under the Apache License, Version 2.0 (the "License"); | |
* you may not use this file except in compliance with the License. | |
* You may obtain a copy of the License at | |
* | |
* http://www.apache.org/licenses/LICENSE-2.0 | |
* | |
* Unless required by applicable law or agreed to in writing, software | |
* distributed under the License is distributed on an "AS IS" BASIS, | |
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
* See the License for the specific language governing permissions and | |
* limitations under the License. | |
* | |
* @providesModule EventListener | |
* @typechecks | |
*/ | |
'use strict'; | |
var emptyFunction = __webpack_require__(73); | |
/** | |
* Upstream version of event listener. Does not take into account specific | |
* nature of platform. | |
*/ | |
var EventListener = { | |
/** | |
* Listen to DOM events during the bubble phase. | |
* | |
* @param {DOMEventTarget} target DOM element to register listener on. | |
* @param {string} eventType Event type, e.g. 'click' or 'mouseover'. | |
* @param {function} callback Callback function. | |
* @return {object} Object with a `remove` method. | |
*/ | |
listen: function (target, eventType, callback) { | |
if (target.addEventListener) { | |
target.addEventListener(eventType, callback, false); | |
return { | |
remove: function () { | |
target.removeEventListener(eventType, callback, false); | |
} | |
}; | |
} else if (target.attachEvent) { | |
target.attachEvent('on' + eventType, callback); | |
return { | |
remove: function () { | |
target.detachEvent('on' + eventType, callback); | |
} | |
}; | |
} | |
}, | |
/** | |
* Listen to DOM events during the capture phase. | |
* | |
* @param {DOMEventTarget} target DOM element to register listener on. | |
* @param {string} eventType Event type, e.g. 'click' or 'mouseover'. | |
* @param {function} callback Callback function. | |
* @return {object} Object with a `remove` method. | |
*/ | |
capture: function (target, eventType, callback) { | |
if (target.addEventListener) { | |
target.addEventListener(eventType, callback, true); | |
return { | |
remove: function () { | |
target.removeEventListener(eventType, callback, true); | |
} | |
}; | |
} else { | |
if (process.env.NODE_ENV !== 'production') { | |
console.error('Attempted to listen to events during the capture phase on a ' + 'browser that does not support the capture phase. Your application ' + 'will not receive some events.'); | |
} | |
return { | |
remove: emptyFunction | |
}; | |
} | |
}, | |
registerDefault: function () {} | |
}; | |
module.exports = EventListener; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 176 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getUnboundedScrollPosition | |
* @typechecks | |
*/ | |
'use strict'; | |
/** | |
* Gets the scroll position of the supplied element or window. | |
* | |
* The return values are unbounded, unlike `getScrollPosition`. This means they | |
* may be negative or exceed the element boundaries (which is possible using | |
* inertial scrolling). | |
* | |
* @param {DOMWindow|DOMElement} scrollable | |
* @return {object} Map with `x` and `y` keys. | |
*/ | |
function getUnboundedScrollPosition(scrollable) { | |
if (scrollable === window) { | |
return { | |
x: window.pageXOffset || document.documentElement.scrollLeft, | |
y: window.pageYOffset || document.documentElement.scrollTop | |
}; | |
} | |
return { | |
x: scrollable.scrollLeft, | |
y: scrollable.scrollTop | |
}; | |
} | |
module.exports = getUnboundedScrollPosition; | |
/***/ }, | |
/* 177 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactInjection | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var EventPluginHub = __webpack_require__(89); | |
var ReactComponentEnvironment = __webpack_require__(121); | |
var ReactClass = __webpack_require__(178); | |
var ReactEmptyComponent = __webpack_require__(125); | |
var ReactBrowserEventEmitter = __webpack_require__(87); | |
var ReactNativeComponent = __webpack_require__(126); | |
var ReactPerf = __webpack_require__(76); | |
var ReactRootIndex = __webpack_require__(103); | |
var ReactUpdates = __webpack_require__(111); | |
var ReactInjection = { | |
Component: ReactComponentEnvironment.injection, | |
Class: ReactClass.injection, | |
DOMProperty: DOMProperty.injection, | |
EmptyComponent: ReactEmptyComponent.injection, | |
EventPluginHub: EventPluginHub.injection, | |
EventEmitter: ReactBrowserEventEmitter.injection, | |
NativeComponent: ReactNativeComponent.injection, | |
Perf: ReactPerf.injection, | |
RootIndex: ReactRootIndex.injection, | |
Updates: ReactUpdates.injection | |
}; | |
module.exports = ReactInjection; | |
/***/ }, | |
/* 178 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactClass | |
*/ | |
'use strict'; | |
var ReactComponent = __webpack_require__(179); | |
var ReactElement = __webpack_require__(99); | |
var ReactPropTypeLocations = __webpack_require__(122); | |
var ReactPropTypeLocationNames = __webpack_require__(123); | |
var ReactNoopUpdateQueue = __webpack_require__(180); | |
var assign = __webpack_require__(29); | |
var emptyObject = __webpack_require__(115); | |
var invariant = __webpack_require__(31); | |
var keyMirror = __webpack_require__(75); | |
var keyOf = __webpack_require__(30); | |
var warning = __webpack_require__(83); | |
var MIXINS_KEY = keyOf({ mixins: null }); | |
/** | |
* Policies that describe methods in `ReactClassInterface`. | |
*/ | |
var SpecPolicy = keyMirror({ | |
/** | |
* These methods may be defined only once by the class specification or mixin. | |
*/ | |
DEFINE_ONCE: null, | |
/** | |
* These methods may be defined by both the class specification and mixins. | |
* Subsequent definitions will be chained. These methods must return void. | |
*/ | |
DEFINE_MANY: null, | |
/** | |
* These methods are overriding the base class. | |
*/ | |
OVERRIDE_BASE: null, | |
/** | |
* These methods are similar to DEFINE_MANY, except we assume they return | |
* objects. We try to merge the keys of the return values of all the mixed in | |
* functions. If there is a key conflict we throw. | |
*/ | |
DEFINE_MANY_MERGED: null | |
}); | |
var injectedMixins = []; | |
var warnedSetProps = false; | |
function warnSetProps() { | |
if (!warnedSetProps) { | |
warnedSetProps = true; | |
process.env.NODE_ENV !== 'production' ? warning(false, 'setProps(...) and replaceProps(...) are deprecated. ' + 'Instead, call render again at the top level.') : undefined; | |
} | |
} | |
/** | |
* Composite components are higher-level components that compose other composite | |
* or native components. | |
* | |
* To create a new type of `ReactClass`, pass a specification of | |
* your new class to `React.createClass`. The only requirement of your class | |
* specification is that you implement a `render` method. | |
* | |
* var MyComponent = React.createClass({ | |
* render: function() { | |
* return <div>Hello World</div>; | |
* } | |
* }); | |
* | |
* The class specification supports a specific protocol of methods that have | |
* special meaning (e.g. `render`). See `ReactClassInterface` for | |
* more the comprehensive protocol. Any other properties and methods in the | |
* class specification will be available on the prototype. | |
* | |
* @interface ReactClassInterface | |
* @internal | |
*/ | |
var ReactClassInterface = { | |
/** | |
* An array of Mixin objects to include when defining your component. | |
* | |
* @type {array} | |
* @optional | |
*/ | |
mixins: SpecPolicy.DEFINE_MANY, | |
/** | |
* An object containing properties and methods that should be defined on | |
* the component's constructor instead of its prototype (static methods). | |
* | |
* @type {object} | |
* @optional | |
*/ | |
statics: SpecPolicy.DEFINE_MANY, | |
/** | |
* Definition of prop types for this component. | |
* | |
* @type {object} | |
* @optional | |
*/ | |
propTypes: SpecPolicy.DEFINE_MANY, | |
/** | |
* Definition of context types for this component. | |
* | |
* @type {object} | |
* @optional | |
*/ | |
contextTypes: SpecPolicy.DEFINE_MANY, | |
/** | |
* Definition of context types this component sets for its children. | |
* | |
* @type {object} | |
* @optional | |
*/ | |
childContextTypes: SpecPolicy.DEFINE_MANY, | |
// ==== Definition methods ==== | |
/** | |
* Invoked when the component is mounted. Values in the mapping will be set on | |
* `this.props` if that prop is not specified (i.e. using an `in` check). | |
* | |
* This method is invoked before `getInitialState` and therefore cannot rely | |
* on `this.state` or use `this.setState`. | |
* | |
* @return {object} | |
* @optional | |
*/ | |
getDefaultProps: SpecPolicy.DEFINE_MANY_MERGED, | |
/** | |
* Invoked once before the component is mounted. The return value will be used | |
* as the initial value of `this.state`. | |
* | |
* getInitialState: function() { | |
* return { | |
* isOn: false, | |
* fooBaz: new BazFoo() | |
* } | |
* } | |
* | |
* @return {object} | |
* @optional | |
*/ | |
getInitialState: SpecPolicy.DEFINE_MANY_MERGED, | |
/** | |
* @return {object} | |
* @optional | |
*/ | |
getChildContext: SpecPolicy.DEFINE_MANY_MERGED, | |
/** | |
* Uses props from `this.props` and state from `this.state` to render the | |
* structure of the component. | |
* | |
* No guarantees are made about when or how often this method is invoked, so | |
* it must not have side effects. | |
* | |
* render: function() { | |
* var name = this.props.name; | |
* return <div>Hello, {name}!</div>; | |
* } | |
* | |
* @return {ReactComponent} | |
* @nosideeffects | |
* @required | |
*/ | |
render: SpecPolicy.DEFINE_ONCE, | |
// ==== Delegate methods ==== | |
/** | |
* Invoked when the component is initially created and about to be mounted. | |
* This may have side effects, but any external subscriptions or data created | |
* by this method must be cleaned up in `componentWillUnmount`. | |
* | |
* @optional | |
*/ | |
componentWillMount: SpecPolicy.DEFINE_MANY, | |
/** | |
* Invoked when the component has been mounted and has a DOM representation. | |
* However, there is no guarantee that the DOM node is in the document. | |
* | |
* Use this as an opportunity to operate on the DOM when the component has | |
* been mounted (initialized and rendered) for the first time. | |
* | |
* @param {DOMElement} rootNode DOM element representing the component. | |
* @optional | |
*/ | |
componentDidMount: SpecPolicy.DEFINE_MANY, | |
/** | |
* Invoked before the component receives new props. | |
* | |
* Use this as an opportunity to react to a prop transition by updating the | |
* state using `this.setState`. Current props are accessed via `this.props`. | |
* | |
* componentWillReceiveProps: function(nextProps, nextContext) { | |
* this.setState({ | |
* likesIncreasing: nextProps.likeCount > this.props.likeCount | |
* }); | |
* } | |
* | |
* NOTE: There is no equivalent `componentWillReceiveState`. An incoming prop | |
* transition may cause a state change, but the opposite is not true. If you | |
* need it, you are probably looking for `componentWillUpdate`. | |
* | |
* @param {object} nextProps | |
* @optional | |
*/ | |
componentWillReceiveProps: SpecPolicy.DEFINE_MANY, | |
/** | |
* Invoked while deciding if the component should be updated as a result of | |
* receiving new props, state and/or context. | |
* | |
* Use this as an opportunity to `return false` when you're certain that the | |
* transition to the new props/state/context will not require a component | |
* update. | |
* | |
* shouldComponentUpdate: function(nextProps, nextState, nextContext) { | |
* return !equal(nextProps, this.props) || | |
* !equal(nextState, this.state) || | |
* !equal(nextContext, this.context); | |
* } | |
* | |
* @param {object} nextProps | |
* @param {?object} nextState | |
* @param {?object} nextContext | |
* @return {boolean} True if the component should update. | |
* @optional | |
*/ | |
shouldComponentUpdate: SpecPolicy.DEFINE_ONCE, | |
/** | |
* Invoked when the component is about to update due to a transition from | |
* `this.props`, `this.state` and `this.context` to `nextProps`, `nextState` | |
* and `nextContext`. | |
* | |
* Use this as an opportunity to perform preparation before an update occurs. | |
* | |
* NOTE: You **cannot** use `this.setState()` in this method. | |
* | |
* @param {object} nextProps | |
* @param {?object} nextState | |
* @param {?object} nextContext | |
* @param {ReactReconcileTransaction} transaction | |
* @optional | |
*/ | |
componentWillUpdate: SpecPolicy.DEFINE_MANY, | |
/** | |
* Invoked when the component's DOM representation has been updated. | |
* | |
* Use this as an opportunity to operate on the DOM when the component has | |
* been updated. | |
* | |
* @param {object} prevProps | |
* @param {?object} prevState | |
* @param {?object} prevContext | |
* @param {DOMElement} rootNode DOM element representing the component. | |
* @optional | |
*/ | |
componentDidUpdate: SpecPolicy.DEFINE_MANY, | |
/** | |
* Invoked when the component is about to be removed from its parent and have | |
* its DOM representation destroyed. | |
* | |
* Use this as an opportunity to deallocate any external resources. | |
* | |
* NOTE: There is no `componentDidUnmount` since your component will have been | |
* destroyed by that point. | |
* | |
* @optional | |
*/ | |
componentWillUnmount: SpecPolicy.DEFINE_MANY, | |
// ==== Advanced methods ==== | |
/** | |
* Updates the component's currently mounted DOM representation. | |
* | |
* By default, this implements React's rendering and reconciliation algorithm. | |
* Sophisticated clients may wish to override this. | |
* | |
* @param {ReactReconcileTransaction} transaction | |
* @internal | |
* @overridable | |
*/ | |
updateComponent: SpecPolicy.OVERRIDE_BASE | |
}; | |
/** | |
* Mapping from class specification keys to special processing functions. | |
* | |
* Although these are declared like instance properties in the specification | |
* when defining classes using `React.createClass`, they are actually static | |
* and are accessible on the constructor instead of the prototype. Despite | |
* being static, they must be defined outside of the "statics" key under | |
* which all other static methods are defined. | |
*/ | |
var RESERVED_SPEC_KEYS = { | |
displayName: function (Constructor, displayName) { | |
Constructor.displayName = displayName; | |
}, | |
mixins: function (Constructor, mixins) { | |
if (mixins) { | |
for (var i = 0; i < mixins.length; i++) { | |
mixSpecIntoComponent(Constructor, mixins[i]); | |
} | |
} | |
}, | |
childContextTypes: function (Constructor, childContextTypes) { | |
if (process.env.NODE_ENV !== 'production') { | |
validateTypeDef(Constructor, childContextTypes, ReactPropTypeLocations.childContext); | |
} | |
Constructor.childContextTypes = assign({}, Constructor.childContextTypes, childContextTypes); | |
}, | |
contextTypes: function (Constructor, contextTypes) { | |
if (process.env.NODE_ENV !== 'production') { | |
validateTypeDef(Constructor, contextTypes, ReactPropTypeLocations.context); | |
} | |
Constructor.contextTypes = assign({}, Constructor.contextTypes, contextTypes); | |
}, | |
/** | |
* Special case getDefaultProps which should move into statics but requires | |
* automatic merging. | |
*/ | |
getDefaultProps: function (Constructor, getDefaultProps) { | |
if (Constructor.getDefaultProps) { | |
Constructor.getDefaultProps = createMergedResultFunction(Constructor.getDefaultProps, getDefaultProps); | |
} else { | |
Constructor.getDefaultProps = getDefaultProps; | |
} | |
}, | |
propTypes: function (Constructor, propTypes) { | |
if (process.env.NODE_ENV !== 'production') { | |
validateTypeDef(Constructor, propTypes, ReactPropTypeLocations.prop); | |
} | |
Constructor.propTypes = assign({}, Constructor.propTypes, propTypes); | |
}, | |
statics: function (Constructor, statics) { | |
mixStaticSpecIntoComponent(Constructor, statics); | |
}, | |
autobind: function () {} }; | |
// noop | |
function validateTypeDef(Constructor, typeDef, location) { | |
for (var propName in typeDef) { | |
if (typeDef.hasOwnProperty(propName)) { | |
// use a warning instead of an invariant so components | |
// don't show up in prod but not in __DEV__ | |
process.env.NODE_ENV !== 'production' ? warning(typeof typeDef[propName] === 'function', '%s: %s type `%s` is invalid; it must be a function, usually from ' + 'React.PropTypes.', Constructor.displayName || 'ReactClass', ReactPropTypeLocationNames[location], propName) : undefined; | |
} | |
} | |
} | |
function validateMethodOverride(proto, name) { | |
var specPolicy = ReactClassInterface.hasOwnProperty(name) ? ReactClassInterface[name] : null; | |
// Disallow overriding of base class methods unless explicitly allowed. | |
if (ReactClassMixin.hasOwnProperty(name)) { | |
!(specPolicy === SpecPolicy.OVERRIDE_BASE) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClassInterface: You are attempting to override ' + '`%s` from your class specification. Ensure that your method names ' + 'do not overlap with React methods.', name) : invariant(false) : undefined; | |
} | |
// Disallow defining methods more than once unless explicitly allowed. | |
if (proto.hasOwnProperty(name)) { | |
!(specPolicy === SpecPolicy.DEFINE_MANY || specPolicy === SpecPolicy.DEFINE_MANY_MERGED) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClassInterface: You are attempting to define ' + '`%s` on your component more than once. This conflict may be due ' + 'to a mixin.', name) : invariant(false) : undefined; | |
} | |
} | |
/** | |
* Mixin helper which handles policy validation and reserved | |
* specification keys when building React classses. | |
*/ | |
function mixSpecIntoComponent(Constructor, spec) { | |
if (!spec) { | |
return; | |
} | |
!(typeof spec !== 'function') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You\'re attempting to ' + 'use a component class as a mixin. Instead, just use a regular object.') : invariant(false) : undefined; | |
!!ReactElement.isValidElement(spec) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You\'re attempting to ' + 'use a component as a mixin. Instead, just use a regular object.') : invariant(false) : undefined; | |
var proto = Constructor.prototype; | |
// By handling mixins before any other properties, we ensure the same | |
// chaining order is applied to methods with DEFINE_MANY policy, whether | |
// mixins are listed before or after these methods in the spec. | |
if (spec.hasOwnProperty(MIXINS_KEY)) { | |
RESERVED_SPEC_KEYS.mixins(Constructor, spec.mixins); | |
} | |
for (var name in spec) { | |
if (!spec.hasOwnProperty(name)) { | |
continue; | |
} | |
if (name === MIXINS_KEY) { | |
// We have already handled mixins in a special case above. | |
continue; | |
} | |
var property = spec[name]; | |
validateMethodOverride(proto, name); | |
if (RESERVED_SPEC_KEYS.hasOwnProperty(name)) { | |
RESERVED_SPEC_KEYS[name](Constructor, property); | |
} else { | |
// Setup methods on prototype: | |
// The following member methods should not be automatically bound: | |
// 1. Expected ReactClass methods (in the "interface"). | |
// 2. Overridden methods (that were mixed in). | |
var isReactClassMethod = ReactClassInterface.hasOwnProperty(name); | |
var isAlreadyDefined = proto.hasOwnProperty(name); | |
var isFunction = typeof property === 'function'; | |
var shouldAutoBind = isFunction && !isReactClassMethod && !isAlreadyDefined && spec.autobind !== false; | |
if (shouldAutoBind) { | |
if (!proto.__reactAutoBindMap) { | |
proto.__reactAutoBindMap = {}; | |
} | |
proto.__reactAutoBindMap[name] = property; | |
proto[name] = property; | |
} else { | |
if (isAlreadyDefined) { | |
var specPolicy = ReactClassInterface[name]; | |
// These cases should already be caught by validateMethodOverride. | |
!(isReactClassMethod && (specPolicy === SpecPolicy.DEFINE_MANY_MERGED || specPolicy === SpecPolicy.DEFINE_MANY)) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: Unexpected spec policy %s for key %s ' + 'when mixing in component specs.', specPolicy, name) : invariant(false) : undefined; | |
// For methods which are defined more than once, call the existing | |
// methods before calling the new property, merging if appropriate. | |
if (specPolicy === SpecPolicy.DEFINE_MANY_MERGED) { | |
proto[name] = createMergedResultFunction(proto[name], property); | |
} else if (specPolicy === SpecPolicy.DEFINE_MANY) { | |
proto[name] = createChainedFunction(proto[name], property); | |
} | |
} else { | |
proto[name] = property; | |
if (process.env.NODE_ENV !== 'production') { | |
// Add verbose displayName to the function, which helps when looking | |
// at profiling tools. | |
if (typeof property === 'function' && spec.displayName) { | |
proto[name].displayName = spec.displayName + '_' + name; | |
} | |
} | |
} | |
} | |
} | |
} | |
} | |
function mixStaticSpecIntoComponent(Constructor, statics) { | |
if (!statics) { | |
return; | |
} | |
for (var name in statics) { | |
var property = statics[name]; | |
if (!statics.hasOwnProperty(name)) { | |
continue; | |
} | |
var isReserved = (name in RESERVED_SPEC_KEYS); | |
!!isReserved ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You are attempting to define a reserved ' + 'property, `%s`, that shouldn\'t be on the "statics" key. Define it ' + 'as an instance property instead; it will still be accessible on the ' + 'constructor.', name) : invariant(false) : undefined; | |
var isInherited = (name in Constructor); | |
!!isInherited ? process.env.NODE_ENV !== 'production' ? invariant(false, 'ReactClass: You are attempting to define ' + '`%s` on your component more than once. This conflict may be ' + 'due to a mixin.', name) : invariant(false) : undefined; | |
Constructor[name] = property; | |
} | |
} | |
/** | |
* Merge two objects, but throw if both contain the same key. | |
* | |
* @param {object} one The first object, which is mutated. | |
* @param {object} two The second object | |
* @return {object} one after it has been mutated to contain everything in two. | |
*/ | |
function mergeIntoWithNoDuplicateKeys(one, two) { | |
!(one && two && typeof one === 'object' && typeof two === 'object') ? process.env.NODE_ENV !== 'production' ? invariant(false, 'mergeIntoWithNoDuplicateKeys(): Cannot merge non-objects.') : invariant(false) : undefined; | |
for (var key in two) { | |
if (two.hasOwnProperty(key)) { | |
!(one[key] === undefined) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'mergeIntoWithNoDuplicateKeys(): ' + 'Tried to merge two objects with the same key: `%s`. This conflict ' + 'may be due to a mixin; in particular, this may be caused by two ' + 'getInitialState() or getDefaultProps() methods returning objects ' + 'with clashing keys.', key) : invariant(false) : undefined; | |
one[key] = two[key]; | |
} | |
} | |
return one; | |
} | |
/** | |
* Creates a function that invokes two functions and merges their return values. | |
* | |
* @param {function} one Function to invoke first. | |
* @param {function} two Function to invoke second. | |
* @return {function} Function that invokes the two argument functions. | |
* @private | |
*/ | |
function createMergedResultFunction(one, two) { | |
return function mergedResult() { | |
var a = one.apply(this, arguments); | |
var b = two.apply(this, arguments); | |
if (a == null) { | |
return b; | |
} else if (b == null) { | |
return a; | |
} | |
var c = {}; | |
mergeIntoWithNoDuplicateKeys(c, a); | |
mergeIntoWithNoDuplicateKeys(c, b); | |
return c; | |
}; | |
} | |
/** | |
* Creates a function that invokes two functions and ignores their return vales. | |
* | |
* @param {function} one Function to invoke first. | |
* @param {function} two Function to invoke second. | |
* @return {function} Function that invokes the two argument functions. | |
* @private | |
*/ | |
function createChainedFunction(one, two) { | |
return function chainedFunction() { | |
one.apply(this, arguments); | |
two.apply(this, arguments); | |
}; | |
} | |
/** | |
* Binds a method to the component. | |
* | |
* @param {object} component Component whose method is going to be bound. | |
* @param {function} method Method to be bound. | |
* @return {function} The bound method. | |
*/ | |
function bindAutoBindMethod(component, method) { | |
var boundMethod = method.bind(component); | |
if (process.env.NODE_ENV !== 'production') { | |
boundMethod.__reactBoundContext = component; | |
boundMethod.__reactBoundMethod = method; | |
boundMethod.__reactBoundArguments = null; | |
var componentName = component.constructor.displayName; | |
var _bind = boundMethod.bind; | |
/* eslint-disable block-scoped-var, no-undef */ | |
boundMethod.bind = function (newThis) { | |
for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) { | |
args[_key - 1] = arguments[_key]; | |
} | |
// User is trying to bind() an autobound method; we effectively will | |
// ignore the value of "this" that the user is trying to use, so | |
// let's warn. | |
if (newThis !== component && newThis !== null) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'bind(): React component methods may only be bound to the ' + 'component instance. See %s', componentName) : undefined; | |
} else if (!args.length) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'bind(): You are binding a component method to the component. ' + 'React does this for you automatically in a high-performance ' + 'way, so you can safely remove this call. See %s', componentName) : undefined; | |
return boundMethod; | |
} | |
var reboundMethod = _bind.apply(boundMethod, arguments); | |
reboundMethod.__reactBoundContext = component; | |
reboundMethod.__reactBoundMethod = method; | |
reboundMethod.__reactBoundArguments = args; | |
return reboundMethod; | |
/* eslint-enable */ | |
}; | |
} | |
return boundMethod; | |
} | |
/** | |
* Binds all auto-bound methods in a component. | |
* | |
* @param {object} component Component whose method is going to be bound. | |
*/ | |
function bindAutoBindMethods(component) { | |
for (var autoBindKey in component.__reactAutoBindMap) { | |
if (component.__reactAutoBindMap.hasOwnProperty(autoBindKey)) { | |
var method = component.__reactAutoBindMap[autoBindKey]; | |
component[autoBindKey] = bindAutoBindMethod(component, method); | |
} | |
} | |
} | |
/** | |
* Add more to the ReactClass base class. These are all legacy features and | |
* therefore not already part of the modern ReactComponent. | |
*/ | |
var ReactClassMixin = { | |
/** | |
* TODO: This will be deprecated because state should always keep a consistent | |
* type signature and the only use case for this, is to avoid that. | |
*/ | |
replaceState: function (newState, callback) { | |
this.updater.enqueueReplaceState(this, newState); | |
if (callback) { | |
this.updater.enqueueCallback(this, callback); | |
} | |
}, | |
/** | |
* Checks whether or not this composite component is mounted. | |
* @return {boolean} True if mounted, false otherwise. | |
* @protected | |
* @final | |
*/ | |
isMounted: function () { | |
return this.updater.isMounted(this); | |
}, | |
/** | |
* Sets a subset of the props. | |
* | |
* @param {object} partialProps Subset of the next props. | |
* @param {?function} callback Called after props are updated. | |
* @final | |
* @public | |
* @deprecated | |
*/ | |
setProps: function (partialProps, callback) { | |
if (process.env.NODE_ENV !== 'production') { | |
warnSetProps(); | |
} | |
this.updater.enqueueSetProps(this, partialProps); | |
if (callback) { | |
this.updater.enqueueCallback(this, callback); | |
} | |
}, | |
/** | |
* Replace all the props. | |
* | |
* @param {object} newProps Subset of the next props. | |
* @param {?function} callback Called after props are updated. | |
* @final | |
* @public | |
* @deprecated | |
*/ | |
replaceProps: function (newProps, callback) { | |
if (process.env.NODE_ENV !== 'production') { | |
warnSetProps(); | |
} | |
this.updater.enqueueReplaceProps(this, newProps); | |
if (callback) { | |
this.updater.enqueueCallback(this, callback); | |
} | |
} | |
}; | |
var ReactClassComponent = function () {}; | |
assign(ReactClassComponent.prototype, ReactComponent.prototype, ReactClassMixin); | |
/** | |
* Module for creating composite components. | |
* | |
* @class ReactClass | |
*/ | |
var ReactClass = { | |
/** | |
* Creates a composite component class given a class specification. | |
* | |
* @param {object} spec Class specification (which must define `render`). | |
* @return {function} Component constructor function. | |
* @public | |
*/ | |
createClass: function (spec) { | |
var Constructor = function (props, context, updater) { | |
// This constructor is overridden by mocks. The argument is used | |
// by mocks to assert on what gets mounted. | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(this instanceof Constructor, 'Something is calling a React component directly. Use a factory or ' + 'JSX instead. See: https://fb.me/react-legacyfactory') : undefined; | |
} | |
// Wire up auto-binding | |
if (this.__reactAutoBindMap) { | |
bindAutoBindMethods(this); | |
} | |
this.props = props; | |
this.context = context; | |
this.refs = emptyObject; | |
this.updater = updater || ReactNoopUpdateQueue; | |
this.state = null; | |
// ReactClasses doesn't have constructors. Instead, they use the | |
// getInitialState and componentWillMount methods for initialization. | |
var initialState = this.getInitialState ? this.getInitialState() : null; | |
if (process.env.NODE_ENV !== 'production') { | |
// We allow auto-mocks to proceed as if they're returning null. | |
if (typeof initialState === 'undefined' && this.getInitialState._isMockFunction) { | |
// This is probably bad practice. Consider warning here and | |
// deprecating this convenience. | |
initialState = null; | |
} | |
} | |
!(typeof initialState === 'object' && !Array.isArray(initialState)) ? process.env.NODE_ENV !== 'production' ? invariant(false, '%s.getInitialState(): must return an object or null', Constructor.displayName || 'ReactCompositeComponent') : invariant(false) : undefined; | |
this.state = initialState; | |
}; | |
Constructor.prototype = new ReactClassComponent(); | |
Constructor.prototype.constructor = Constructor; | |
injectedMixins.forEach(mixSpecIntoComponent.bind(null, Constructor)); | |
mixSpecIntoComponent(Constructor, spec); | |
// Initialize the defaultProps property after all mixins have been merged. | |
if (Constructor.getDefaultProps) { | |
Constructor.defaultProps = Constructor.getDefaultProps(); | |
} | |
if (process.env.NODE_ENV !== 'production') { | |
// This is a tag to indicate that the use of these method names is ok, | |
// since it's used with createClass. If it's not, then it's likely a | |
// mistake so we'll warn you to use the static property, property | |
// initializer or constructor respectively. | |
if (Constructor.getDefaultProps) { | |
Constructor.getDefaultProps.isReactClassApproved = {}; | |
} | |
if (Constructor.prototype.getInitialState) { | |
Constructor.prototype.getInitialState.isReactClassApproved = {}; | |
} | |
} | |
!Constructor.prototype.render ? process.env.NODE_ENV !== 'production' ? invariant(false, 'createClass(...): Class specification must implement a `render` method.') : invariant(false) : undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(!Constructor.prototype.componentShouldUpdate, '%s has a method called ' + 'componentShouldUpdate(). Did you mean shouldComponentUpdate()? ' + 'The name is phrased as a question because the function is ' + 'expected to return a value.', spec.displayName || 'A component') : undefined; | |
process.env.NODE_ENV !== 'production' ? warning(!Constructor.prototype.componentWillRecieveProps, '%s has a method called ' + 'componentWillRecieveProps(). Did you mean componentWillReceiveProps()?', spec.displayName || 'A component') : undefined; | |
} | |
// Reduce time spent doing lookups by setting these on the prototype. | |
for (var methodName in ReactClassInterface) { | |
if (!Constructor.prototype[methodName]) { | |
Constructor.prototype[methodName] = null; | |
} | |
} | |
return Constructor; | |
}, | |
injection: { | |
injectMixin: function (mixin) { | |
injectedMixins.push(mixin); | |
} | |
} | |
}; | |
module.exports = ReactClass; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 179 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactComponent | |
*/ | |
'use strict'; | |
var ReactNoopUpdateQueue = __webpack_require__(180); | |
var canDefineProperty = __webpack_require__(100); | |
var emptyObject = __webpack_require__(115); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
/** | |
* Base class helpers for the updating state of a component. | |
*/ | |
function ReactComponent(props, context, updater) { | |
this.props = props; | |
this.context = context; | |
this.refs = emptyObject; | |
// We initialize the default updater but the real one gets injected by the | |
// renderer. | |
this.updater = updater || ReactNoopUpdateQueue; | |
} | |
ReactComponent.prototype.isReactComponent = {}; | |
/** | |
* Sets a subset of the state. Always use this to mutate | |
* state. You should treat `this.state` as immutable. | |
* | |
* There is no guarantee that `this.state` will be immediately updated, so | |
* accessing `this.state` after calling this method may return the old value. | |
* | |
* There is no guarantee that calls to `setState` will run synchronously, | |
* as they may eventually be batched together. You can provide an optional | |
* callback that will be executed when the call to setState is actually | |
* completed. | |
* | |
* When a function is provided to setState, it will be called at some point in | |
* the future (not synchronously). It will be called with the up to date | |
* component arguments (state, props, context). These values can be different | |
* from this.* because your function may be called after receiveProps but before | |
* shouldComponentUpdate, and this new state, props, and context will not yet be | |
* assigned to this. | |
* | |
* @param {object|function} partialState Next partial state or function to | |
* produce next partial state to be merged with current state. | |
* @param {?function} callback Called after state is updated. | |
* @final | |
* @protected | |
*/ | |
ReactComponent.prototype.setState = function (partialState, callback) { | |
!(typeof partialState === 'object' || typeof partialState === 'function' || partialState == null) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'setState(...): takes an object of state variables to update or a ' + 'function which returns an object of state variables.') : invariant(false) : undefined; | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(partialState != null, 'setState(...): You passed an undefined or null state object; ' + 'instead, use forceUpdate().') : undefined; | |
} | |
this.updater.enqueueSetState(this, partialState); | |
if (callback) { | |
this.updater.enqueueCallback(this, callback); | |
} | |
}; | |
/** | |
* Forces an update. This should only be invoked when it is known with | |
* certainty that we are **not** in a DOM transaction. | |
* | |
* You may want to call this when you know that some deeper aspect of the | |
* component's state has changed but `setState` was not called. | |
* | |
* This will not invoke `shouldComponentUpdate`, but it will invoke | |
* `componentWillUpdate` and `componentDidUpdate`. | |
* | |
* @param {?function} callback Called after update is complete. | |
* @final | |
* @protected | |
*/ | |
ReactComponent.prototype.forceUpdate = function (callback) { | |
this.updater.enqueueForceUpdate(this); | |
if (callback) { | |
this.updater.enqueueCallback(this, callback); | |
} | |
}; | |
/** | |
* Deprecated APIs. These APIs used to exist on classic React classes but since | |
* we would like to deprecate them, we're not going to move them over to this | |
* modern base class. Instead, we define a getter that warns if it's accessed. | |
*/ | |
if (process.env.NODE_ENV !== 'production') { | |
var deprecatedAPIs = { | |
getDOMNode: ['getDOMNode', 'Use ReactDOM.findDOMNode(component) instead.'], | |
isMounted: ['isMounted', 'Instead, make sure to clean up subscriptions and pending requests in ' + 'componentWillUnmount to prevent memory leaks.'], | |
replaceProps: ['replaceProps', 'Instead, call render again at the top level.'], | |
replaceState: ['replaceState', 'Refactor your code to use setState instead (see ' + 'https://github.com/facebook/react/issues/3236).'], | |
setProps: ['setProps', 'Instead, call render again at the top level.'] | |
}; | |
var defineDeprecationWarning = function (methodName, info) { | |
if (canDefineProperty) { | |
Object.defineProperty(ReactComponent.prototype, methodName, { | |
get: function () { | |
process.env.NODE_ENV !== 'production' ? warning(false, '%s(...) is deprecated in plain JavaScript React classes. %s', info[0], info[1]) : undefined; | |
return undefined; | |
} | |
}); | |
} | |
}; | |
for (var fnName in deprecatedAPIs) { | |
if (deprecatedAPIs.hasOwnProperty(fnName)) { | |
defineDeprecationWarning(fnName, deprecatedAPIs[fnName]); | |
} | |
} | |
} | |
module.exports = ReactComponent; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 180 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactNoopUpdateQueue | |
*/ | |
'use strict'; | |
var warning = __webpack_require__(83); | |
function warnTDZ(publicInstance, callerName) { | |
if (process.env.NODE_ENV !== 'production') { | |
process.env.NODE_ENV !== 'production' ? warning(false, '%s(...): Can only update a mounted or mounting component. ' + 'This usually means you called %s() on an unmounted component. ' + 'This is a no-op. Please check the code for the %s component.', callerName, callerName, publicInstance.constructor && publicInstance.constructor.displayName || '') : undefined; | |
} | |
} | |
/** | |
* This is the abstract API for an update queue. | |
*/ | |
var ReactNoopUpdateQueue = { | |
/** | |
* Checks whether or not this composite component is mounted. | |
* @param {ReactClass} publicInstance The instance we want to test. | |
* @return {boolean} True if mounted, false otherwise. | |
* @protected | |
* @final | |
*/ | |
isMounted: function (publicInstance) { | |
return false; | |
}, | |
/** | |
* Enqueue a callback that will be executed after all the pending updates | |
* have processed. | |
* | |
* @param {ReactClass} publicInstance The instance to use as `this` context. | |
* @param {?function} callback Called after state is updated. | |
* @internal | |
*/ | |
enqueueCallback: function (publicInstance, callback) {}, | |
/** | |
* Forces an update. This should only be invoked when it is known with | |
* certainty that we are **not** in a DOM transaction. | |
* | |
* You may want to call this when you know that some deeper aspect of the | |
* component's state has changed but `setState` was not called. | |
* | |
* This will not invoke `shouldComponentUpdate`, but it will invoke | |
* `componentWillUpdate` and `componentDidUpdate`. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @internal | |
*/ | |
enqueueForceUpdate: function (publicInstance) { | |
warnTDZ(publicInstance, 'forceUpdate'); | |
}, | |
/** | |
* Replaces all of the state. Always use this or `setState` to mutate state. | |
* You should treat `this.state` as immutable. | |
* | |
* There is no guarantee that `this.state` will be immediately updated, so | |
* accessing `this.state` after calling this method may return the old value. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} completeState Next state. | |
* @internal | |
*/ | |
enqueueReplaceState: function (publicInstance, completeState) { | |
warnTDZ(publicInstance, 'replaceState'); | |
}, | |
/** | |
* Sets a subset of the state. This only exists because _pendingState is | |
* internal. This provides a merging strategy that is not available to deep | |
* properties which is confusing. TODO: Expose pendingState or don't use it | |
* during the merge. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} partialState Next partial state to be merged with state. | |
* @internal | |
*/ | |
enqueueSetState: function (publicInstance, partialState) { | |
warnTDZ(publicInstance, 'setState'); | |
}, | |
/** | |
* Sets a subset of the props. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} partialProps Subset of the next props. | |
* @internal | |
*/ | |
enqueueSetProps: function (publicInstance, partialProps) { | |
warnTDZ(publicInstance, 'setProps'); | |
}, | |
/** | |
* Replaces all of the props. | |
* | |
* @param {ReactClass} publicInstance The instance that should rerender. | |
* @param {object} props New props. | |
* @internal | |
*/ | |
enqueueReplaceProps: function (publicInstance, props) { | |
warnTDZ(publicInstance, 'replaceProps'); | |
} | |
}; | |
module.exports = ReactNoopUpdateQueue; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 181 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactReconcileTransaction | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var CallbackQueue = __webpack_require__(112); | |
var PooledClass = __webpack_require__(113); | |
var ReactBrowserEventEmitter = __webpack_require__(87); | |
var ReactDOMFeatureFlags = __webpack_require__(98); | |
var ReactInputSelection = __webpack_require__(182); | |
var Transaction = __webpack_require__(114); | |
var assign = __webpack_require__(29); | |
/** | |
* Ensures that, when possible, the selection range (currently selected text | |
* input) is not disturbed by performing the transaction. | |
*/ | |
var SELECTION_RESTORATION = { | |
/** | |
* @return {Selection} Selection information. | |
*/ | |
initialize: ReactInputSelection.getSelectionInformation, | |
/** | |
* @param {Selection} sel Selection information returned from `initialize`. | |
*/ | |
close: ReactInputSelection.restoreSelection | |
}; | |
/** | |
* Suppresses events (blur/focus) that could be inadvertently dispatched due to | |
* high level DOM manipulations (like temporarily removing a text input from the | |
* DOM). | |
*/ | |
var EVENT_SUPPRESSION = { | |
/** | |
* @return {boolean} The enabled status of `ReactBrowserEventEmitter` before | |
* the reconciliation. | |
*/ | |
initialize: function () { | |
var currentlyEnabled = ReactBrowserEventEmitter.isEnabled(); | |
ReactBrowserEventEmitter.setEnabled(false); | |
return currentlyEnabled; | |
}, | |
/** | |
* @param {boolean} previouslyEnabled Enabled status of | |
* `ReactBrowserEventEmitter` before the reconciliation occurred. `close` | |
* restores the previous value. | |
*/ | |
close: function (previouslyEnabled) { | |
ReactBrowserEventEmitter.setEnabled(previouslyEnabled); | |
} | |
}; | |
/** | |
* Provides a queue for collecting `componentDidMount` and | |
* `componentDidUpdate` callbacks during the the transaction. | |
*/ | |
var ON_DOM_READY_QUEUEING = { | |
/** | |
* Initializes the internal `onDOMReady` queue. | |
*/ | |
initialize: function () { | |
this.reactMountReady.reset(); | |
}, | |
/** | |
* After DOM is flushed, invoke all registered `onDOMReady` callbacks. | |
*/ | |
close: function () { | |
this.reactMountReady.notifyAll(); | |
} | |
}; | |
/** | |
* Executed within the scope of the `Transaction` instance. Consider these as | |
* being member methods, but with an implied ordering while being isolated from | |
* each other. | |
*/ | |
var TRANSACTION_WRAPPERS = [SELECTION_RESTORATION, EVENT_SUPPRESSION, ON_DOM_READY_QUEUEING]; | |
/** | |
* Currently: | |
* - The order that these are listed in the transaction is critical: | |
* - Suppresses events. | |
* - Restores selection range. | |
* | |
* Future: | |
* - Restore document/overflow scroll positions that were unintentionally | |
* modified via DOM insertions above the top viewport boundary. | |
* - Implement/integrate with customized constraint based layout system and keep | |
* track of which dimensions must be remeasured. | |
* | |
* @class ReactReconcileTransaction | |
*/ | |
function ReactReconcileTransaction(forceHTML) { | |
this.reinitializeTransaction(); | |
// Only server-side rendering really needs this option (see | |
// `ReactServerRendering`), but server-side uses | |
// `ReactServerRenderingTransaction` instead. This option is here so that it's | |
// accessible and defaults to false when `ReactDOMComponent` and | |
// `ReactTextComponent` checks it in `mountComponent`.` | |
this.renderToStaticMarkup = false; | |
this.reactMountReady = CallbackQueue.getPooled(null); | |
this.useCreateElement = !forceHTML && ReactDOMFeatureFlags.useCreateElement; | |
} | |
var Mixin = { | |
/** | |
* @see Transaction | |
* @abstract | |
* @final | |
* @return {array<object>} List of operation wrap procedures. | |
* TODO: convert to array<TransactionWrapper> | |
*/ | |
getTransactionWrappers: function () { | |
return TRANSACTION_WRAPPERS; | |
}, | |
/** | |
* @return {object} The queue to collect `onDOMReady` callbacks with. | |
*/ | |
getReactMountReady: function () { | |
return this.reactMountReady; | |
}, | |
/** | |
* `PooledClass` looks for this, and will invoke this before allowing this | |
* instance to be reused. | |
*/ | |
destructor: function () { | |
CallbackQueue.release(this.reactMountReady); | |
this.reactMountReady = null; | |
} | |
}; | |
assign(ReactReconcileTransaction.prototype, Transaction.Mixin, Mixin); | |
PooledClass.addPoolingTo(ReactReconcileTransaction); | |
module.exports = ReactReconcileTransaction; | |
/***/ }, | |
/* 182 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactInputSelection | |
*/ | |
'use strict'; | |
var ReactDOMSelection = __webpack_require__(183); | |
var containsNode = __webpack_require__(116); | |
var focusNode = __webpack_require__(151); | |
var getActiveElement = __webpack_require__(185); | |
function isInDocument(node) { | |
return containsNode(document.documentElement, node); | |
} | |
/** | |
* @ReactInputSelection: React input selection module. Based on Selection.js, | |
* but modified to be suitable for react and has a couple of bug fixes (doesn't | |
* assume buttons have range selections allowed). | |
* Input selection module for React. | |
*/ | |
var ReactInputSelection = { | |
hasSelectionCapabilities: function (elem) { | |
var nodeName = elem && elem.nodeName && elem.nodeName.toLowerCase(); | |
return nodeName && (nodeName === 'input' && elem.type === 'text' || nodeName === 'textarea' || elem.contentEditable === 'true'); | |
}, | |
getSelectionInformation: function () { | |
var focusedElem = getActiveElement(); | |
return { | |
focusedElem: focusedElem, | |
selectionRange: ReactInputSelection.hasSelectionCapabilities(focusedElem) ? ReactInputSelection.getSelection(focusedElem) : null | |
}; | |
}, | |
/** | |
* @restoreSelection: If any selection information was potentially lost, | |
* restore it. This is useful when performing operations that could remove dom | |
* nodes and place them back in, resulting in focus being lost. | |
*/ | |
restoreSelection: function (priorSelectionInformation) { | |
var curFocusedElem = getActiveElement(); | |
var priorFocusedElem = priorSelectionInformation.focusedElem; | |
var priorSelectionRange = priorSelectionInformation.selectionRange; | |
if (curFocusedElem !== priorFocusedElem && isInDocument(priorFocusedElem)) { | |
if (ReactInputSelection.hasSelectionCapabilities(priorFocusedElem)) { | |
ReactInputSelection.setSelection(priorFocusedElem, priorSelectionRange); | |
} | |
focusNode(priorFocusedElem); | |
} | |
}, | |
/** | |
* @getSelection: Gets the selection bounds of a focused textarea, input or | |
* contentEditable node. | |
* -@input: Look up selection bounds of this input | |
* -@return {start: selectionStart, end: selectionEnd} | |
*/ | |
getSelection: function (input) { | |
var selection; | |
if ('selectionStart' in input) { | |
// Modern browser with input or textarea. | |
selection = { | |
start: input.selectionStart, | |
end: input.selectionEnd | |
}; | |
} else if (document.selection && (input.nodeName && input.nodeName.toLowerCase() === 'input')) { | |
// IE8 input. | |
var range = document.selection.createRange(); | |
// There can only be one selection per document in IE, so it must | |
// be in our element. | |
if (range.parentElement() === input) { | |
selection = { | |
start: -range.moveStart('character', -input.value.length), | |
end: -range.moveEnd('character', -input.value.length) | |
}; | |
} | |
} else { | |
// Content editable or old IE textarea. | |
selection = ReactDOMSelection.getOffsets(input); | |
} | |
return selection || { start: 0, end: 0 }; | |
}, | |
/** | |
* @setSelection: Sets the selection bounds of a textarea or input and focuses | |
* the input. | |
* -@input Set selection bounds of this input or textarea | |
* -@offsets Object of same form that is returned from get* | |
*/ | |
setSelection: function (input, offsets) { | |
var start = offsets.start; | |
var end = offsets.end; | |
if (typeof end === 'undefined') { | |
end = start; | |
} | |
if ('selectionStart' in input) { | |
input.selectionStart = start; | |
input.selectionEnd = Math.min(end, input.value.length); | |
} else if (document.selection && (input.nodeName && input.nodeName.toLowerCase() === 'input')) { | |
var range = input.createTextRange(); | |
range.collapse(true); | |
range.moveStart('character', start); | |
range.moveEnd('character', end - start); | |
range.select(); | |
} else { | |
ReactDOMSelection.setOffsets(input, offsets); | |
} | |
} | |
}; | |
module.exports = ReactInputSelection; | |
/***/ }, | |
/* 183 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDOMSelection | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var getNodeForCharacterOffset = __webpack_require__(184); | |
var getTextContentAccessor = __webpack_require__(132); | |
/** | |
* While `isCollapsed` is available on the Selection object and `collapsed` | |
* is available on the Range object, IE11 sometimes gets them wrong. | |
* If the anchor/focus nodes and offsets are the same, the range is collapsed. | |
*/ | |
function isCollapsed(anchorNode, anchorOffset, focusNode, focusOffset) { | |
return anchorNode === focusNode && anchorOffset === focusOffset; | |
} | |
/** | |
* Get the appropriate anchor and focus node/offset pairs for IE. | |
* | |
* The catch here is that IE's selection API doesn't provide information | |
* about whether the selection is forward or backward, so we have to | |
* behave as though it's always forward. | |
* | |
* IE text differs from modern selection in that it behaves as though | |
* block elements end with a new line. This means character offsets will | |
* differ between the two APIs. | |
* | |
* @param {DOMElement} node | |
* @return {object} | |
*/ | |
function getIEOffsets(node) { | |
var selection = document.selection; | |
var selectedRange = selection.createRange(); | |
var selectedLength = selectedRange.text.length; | |
// Duplicate selection so we can move range without breaking user selection. | |
var fromStart = selectedRange.duplicate(); | |
fromStart.moveToElementText(node); | |
fromStart.setEndPoint('EndToStart', selectedRange); | |
var startOffset = fromStart.text.length; | |
var endOffset = startOffset + selectedLength; | |
return { | |
start: startOffset, | |
end: endOffset | |
}; | |
} | |
/** | |
* @param {DOMElement} node | |
* @return {?object} | |
*/ | |
function getModernOffsets(node) { | |
var selection = window.getSelection && window.getSelection(); | |
if (!selection || selection.rangeCount === 0) { | |
return null; | |
} | |
var anchorNode = selection.anchorNode; | |
var anchorOffset = selection.anchorOffset; | |
var focusNode = selection.focusNode; | |
var focusOffset = selection.focusOffset; | |
var currentRange = selection.getRangeAt(0); | |
// In Firefox, range.startContainer and range.endContainer can be "anonymous | |
// divs", e.g. the up/down buttons on an <input type="number">. Anonymous | |
// divs do not seem to expose properties, triggering a "Permission denied | |
// error" if any of its properties are accessed. The only seemingly possible | |
// way to avoid erroring is to access a property that typically works for | |
// non-anonymous divs and catch any error that may otherwise arise. See | |
// https://bugzilla.mozilla.org/show_bug.cgi?id=208427 | |
try { | |
/* eslint-disable no-unused-expressions */ | |
currentRange.startContainer.nodeType; | |
currentRange.endContainer.nodeType; | |
/* eslint-enable no-unused-expressions */ | |
} catch (e) { | |
return null; | |
} | |
// If the node and offset values are the same, the selection is collapsed. | |
// `Selection.isCollapsed` is available natively, but IE sometimes gets | |
// this value wrong. | |
var isSelectionCollapsed = isCollapsed(selection.anchorNode, selection.anchorOffset, selection.focusNode, selection.focusOffset); | |
var rangeLength = isSelectionCollapsed ? 0 : currentRange.toString().length; | |
var tempRange = currentRange.cloneRange(); | |
tempRange.selectNodeContents(node); | |
tempRange.setEnd(currentRange.startContainer, currentRange.startOffset); | |
var isTempRangeCollapsed = isCollapsed(tempRange.startContainer, tempRange.startOffset, tempRange.endContainer, tempRange.endOffset); | |
var start = isTempRangeCollapsed ? 0 : tempRange.toString().length; | |
var end = start + rangeLength; | |
// Detect whether the selection is backward. | |
var detectionRange = document.createRange(); | |
detectionRange.setStart(anchorNode, anchorOffset); | |
detectionRange.setEnd(focusNode, focusOffset); | |
var isBackward = detectionRange.collapsed; | |
return { | |
start: isBackward ? end : start, | |
end: isBackward ? start : end | |
}; | |
} | |
/** | |
* @param {DOMElement|DOMTextNode} node | |
* @param {object} offsets | |
*/ | |
function setIEOffsets(node, offsets) { | |
var range = document.selection.createRange().duplicate(); | |
var start, end; | |
if (typeof offsets.end === 'undefined') { | |
start = offsets.start; | |
end = start; | |
} else if (offsets.start > offsets.end) { | |
start = offsets.end; | |
end = offsets.start; | |
} else { | |
start = offsets.start; | |
end = offsets.end; | |
} | |
range.moveToElementText(node); | |
range.moveStart('character', start); | |
range.setEndPoint('EndToStart', range); | |
range.moveEnd('character', end - start); | |
range.select(); | |
} | |
/** | |
* In modern non-IE browsers, we can support both forward and backward | |
* selections. | |
* | |
* Note: IE10+ supports the Selection object, but it does not support | |
* the `extend` method, which means that even in modern IE, it's not possible | |
* to programatically create a backward selection. Thus, for all IE | |
* versions, we use the old IE API to create our selections. | |
* | |
* @param {DOMElement|DOMTextNode} node | |
* @param {object} offsets | |
*/ | |
function setModernOffsets(node, offsets) { | |
if (!window.getSelection) { | |
return; | |
} | |
var selection = window.getSelection(); | |
var length = node[getTextContentAccessor()].length; | |
var start = Math.min(offsets.start, length); | |
var end = typeof offsets.end === 'undefined' ? start : Math.min(offsets.end, length); | |
// IE 11 uses modern selection, but doesn't support the extend method. | |
// Flip backward selections, so we can set with a single range. | |
if (!selection.extend && start > end) { | |
var temp = end; | |
end = start; | |
start = temp; | |
} | |
var startMarker = getNodeForCharacterOffset(node, start); | |
var endMarker = getNodeForCharacterOffset(node, end); | |
if (startMarker && endMarker) { | |
var range = document.createRange(); | |
range.setStart(startMarker.node, startMarker.offset); | |
selection.removeAllRanges(); | |
if (start > end) { | |
selection.addRange(range); | |
selection.extend(endMarker.node, endMarker.offset); | |
} else { | |
range.setEnd(endMarker.node, endMarker.offset); | |
selection.addRange(range); | |
} | |
} | |
} | |
var useIEOffsets = ExecutionEnvironment.canUseDOM && 'selection' in document && !('getSelection' in window); | |
var ReactDOMSelection = { | |
/** | |
* @param {DOMElement} node | |
*/ | |
getOffsets: useIEOffsets ? getIEOffsets : getModernOffsets, | |
/** | |
* @param {DOMElement|DOMTextNode} node | |
* @param {object} offsets | |
*/ | |
setOffsets: useIEOffsets ? setIEOffsets : setModernOffsets | |
}; | |
module.exports = ReactDOMSelection; | |
/***/ }, | |
/* 184 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getNodeForCharacterOffset | |
*/ | |
'use strict'; | |
/** | |
* Given any node return the first leaf node without children. | |
* | |
* @param {DOMElement|DOMTextNode} node | |
* @return {DOMElement|DOMTextNode} | |
*/ | |
function getLeafNode(node) { | |
while (node && node.firstChild) { | |
node = node.firstChild; | |
} | |
return node; | |
} | |
/** | |
* Get the next sibling within a container. This will walk up the | |
* DOM if a node's siblings have been exhausted. | |
* | |
* @param {DOMElement|DOMTextNode} node | |
* @return {?DOMElement|DOMTextNode} | |
*/ | |
function getSiblingNode(node) { | |
while (node) { | |
if (node.nextSibling) { | |
return node.nextSibling; | |
} | |
node = node.parentNode; | |
} | |
} | |
/** | |
* Get object describing the nodes which contain characters at offset. | |
* | |
* @param {DOMElement|DOMTextNode} root | |
* @param {number} offset | |
* @return {?object} | |
*/ | |
function getNodeForCharacterOffset(root, offset) { | |
var node = getLeafNode(root); | |
var nodeStart = 0; | |
var nodeEnd = 0; | |
while (node) { | |
if (node.nodeType === 3) { | |
nodeEnd = nodeStart + node.textContent.length; | |
if (nodeStart <= offset && nodeEnd >= offset) { | |
return { | |
node: node, | |
offset: offset - nodeStart | |
}; | |
} | |
nodeStart = nodeEnd; | |
} | |
node = getLeafNode(getSiblingNode(node)); | |
} | |
} | |
module.exports = getNodeForCharacterOffset; | |
/***/ }, | |
/* 185 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getActiveElement | |
* @typechecks | |
*/ | |
/* eslint-disable fb-www/typeof-undefined */ | |
/** | |
* Same as document.activeElement but wraps in a try-catch block. In IE it is | |
* not safe to call document.activeElement if there is nothing focused. | |
* | |
* The activeElement will be null only if the document or document body is not | |
* yet defined. | |
*/ | |
'use strict'; | |
function getActiveElement() /*?DOMElement*/{ | |
if (typeof document === 'undefined') { | |
return null; | |
} | |
try { | |
return document.activeElement || document.body; | |
} catch (e) { | |
return document.body; | |
} | |
} | |
module.exports = getActiveElement; | |
/***/ }, | |
/* 186 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SelectEventPlugin | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventPropagators = __webpack_require__(130); | |
var ExecutionEnvironment = __webpack_require__(68); | |
var ReactInputSelection = __webpack_require__(182); | |
var SyntheticEvent = __webpack_require__(134); | |
var getActiveElement = __webpack_require__(185); | |
var isTextInputElement = __webpack_require__(138); | |
var keyOf = __webpack_require__(30); | |
var shallowEqual = __webpack_require__(173); | |
var topLevelTypes = EventConstants.topLevelTypes; | |
var skipSelectionChangeEvent = ExecutionEnvironment.canUseDOM && 'documentMode' in document && document.documentMode <= 11; | |
var eventTypes = { | |
select: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onSelect: null }), | |
captured: keyOf({ onSelectCapture: null }) | |
}, | |
dependencies: [topLevelTypes.topBlur, topLevelTypes.topContextMenu, topLevelTypes.topFocus, topLevelTypes.topKeyDown, topLevelTypes.topMouseDown, topLevelTypes.topMouseUp, topLevelTypes.topSelectionChange] | |
} | |
}; | |
var activeElement = null; | |
var activeElementID = null; | |
var lastSelection = null; | |
var mouseDown = false; | |
// Track whether a listener exists for this plugin. If none exist, we do | |
// not extract events. | |
var hasListener = false; | |
var ON_SELECT_KEY = keyOf({ onSelect: null }); | |
/** | |
* Get an object which is a unique representation of the current selection. | |
* | |
* The return value will not be consistent across nodes or browsers, but | |
* two identical selections on the same node will return identical objects. | |
* | |
* @param {DOMElement} node | |
* @return {object} | |
*/ | |
function getSelection(node) { | |
if ('selectionStart' in node && ReactInputSelection.hasSelectionCapabilities(node)) { | |
return { | |
start: node.selectionStart, | |
end: node.selectionEnd | |
}; | |
} else if (window.getSelection) { | |
var selection = window.getSelection(); | |
return { | |
anchorNode: selection.anchorNode, | |
anchorOffset: selection.anchorOffset, | |
focusNode: selection.focusNode, | |
focusOffset: selection.focusOffset | |
}; | |
} else if (document.selection) { | |
var range = document.selection.createRange(); | |
return { | |
parentElement: range.parentElement(), | |
text: range.text, | |
top: range.boundingTop, | |
left: range.boundingLeft | |
}; | |
} | |
} | |
/** | |
* Poll selection to see whether it's changed. | |
* | |
* @param {object} nativeEvent | |
* @return {?SyntheticEvent} | |
*/ | |
function constructSelectEvent(nativeEvent, nativeEventTarget) { | |
// Ensure we have the right element, and that the user is not dragging a | |
// selection (this matches native `select` event behavior). In HTML5, select | |
// fires only on input and textarea thus if there's no focused element we | |
// won't dispatch. | |
if (mouseDown || activeElement == null || activeElement !== getActiveElement()) { | |
return null; | |
} | |
// Only fire when selection has actually changed. | |
var currentSelection = getSelection(activeElement); | |
if (!lastSelection || !shallowEqual(lastSelection, currentSelection)) { | |
lastSelection = currentSelection; | |
var syntheticEvent = SyntheticEvent.getPooled(eventTypes.select, activeElementID, nativeEvent, nativeEventTarget); | |
syntheticEvent.type = 'select'; | |
syntheticEvent.target = activeElement; | |
EventPropagators.accumulateTwoPhaseDispatches(syntheticEvent); | |
return syntheticEvent; | |
} | |
return null; | |
} | |
/** | |
* This plugin creates an `onSelect` event that normalizes select events | |
* across form elements. | |
* | |
* Supported elements are: | |
* - input (see `isTextInputElement`) | |
* - textarea | |
* - contentEditable | |
* | |
* This differs from native browser implementations in the following ways: | |
* - Fires on contentEditable fields as well as inputs. | |
* - Fires for collapsed selection. | |
* - Fires after user input. | |
*/ | |
var SelectEventPlugin = { | |
eventTypes: eventTypes, | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @see {EventPluginHub.extractEvents} | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
if (!hasListener) { | |
return null; | |
} | |
switch (topLevelType) { | |
// Track the input node that has focus. | |
case topLevelTypes.topFocus: | |
if (isTextInputElement(topLevelTarget) || topLevelTarget.contentEditable === 'true') { | |
activeElement = topLevelTarget; | |
activeElementID = topLevelTargetID; | |
lastSelection = null; | |
} | |
break; | |
case topLevelTypes.topBlur: | |
activeElement = null; | |
activeElementID = null; | |
lastSelection = null; | |
break; | |
// Don't fire the event while the user is dragging. This matches the | |
// semantics of the native select event. | |
case topLevelTypes.topMouseDown: | |
mouseDown = true; | |
break; | |
case topLevelTypes.topContextMenu: | |
case topLevelTypes.topMouseUp: | |
mouseDown = false; | |
return constructSelectEvent(nativeEvent, nativeEventTarget); | |
// Chrome and IE fire non-standard event when selection is changed (and | |
// sometimes when it hasn't). IE's event fires out of order with respect | |
// to key and input events on deletion, so we discard it. | |
// | |
// Firefox doesn't support selectionchange, so check selection status | |
// after each key entry. The selection changes after keydown and before | |
// keyup, but we check on keydown as well in the case of holding down a | |
// key, when multiple keydown events are fired but only one keyup is. | |
// This is also our approach for IE handling, for the reason above. | |
case topLevelTypes.topSelectionChange: | |
if (skipSelectionChangeEvent) { | |
break; | |
} | |
// falls through | |
case topLevelTypes.topKeyDown: | |
case topLevelTypes.topKeyUp: | |
return constructSelectEvent(nativeEvent, nativeEventTarget); | |
} | |
return null; | |
}, | |
didPutListener: function (id, registrationName, listener) { | |
if (registrationName === ON_SELECT_KEY) { | |
hasListener = true; | |
} | |
} | |
}; | |
module.exports = SelectEventPlugin; | |
/***/ }, | |
/* 187 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ServerReactRootIndex | |
* @typechecks | |
*/ | |
'use strict'; | |
/** | |
* Size of the reactRoot ID space. We generate random numbers for React root | |
* IDs and if there's a collision the events and DOM update system will | |
* get confused. In the future we need a way to generate GUIDs but for | |
* now this will work on a smaller scale. | |
*/ | |
var GLOBAL_MOUNT_POINT_MAX = Math.pow(2, 53); | |
var ServerReactRootIndex = { | |
createReactRootIndex: function () { | |
return Math.ceil(Math.random() * GLOBAL_MOUNT_POINT_MAX); | |
} | |
}; | |
module.exports = ServerReactRootIndex; | |
/***/ }, | |
/* 188 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SimpleEventPlugin | |
*/ | |
'use strict'; | |
var EventConstants = __webpack_require__(88); | |
var EventListener = __webpack_require__(175); | |
var EventPropagators = __webpack_require__(130); | |
var ReactMount = __webpack_require__(86); | |
var SyntheticClipboardEvent = __webpack_require__(189); | |
var SyntheticEvent = __webpack_require__(134); | |
var SyntheticFocusEvent = __webpack_require__(190); | |
var SyntheticKeyboardEvent = __webpack_require__(191); | |
var SyntheticMouseEvent = __webpack_require__(142); | |
var SyntheticDragEvent = __webpack_require__(194); | |
var SyntheticTouchEvent = __webpack_require__(195); | |
var SyntheticUIEvent = __webpack_require__(143); | |
var SyntheticWheelEvent = __webpack_require__(196); | |
var emptyFunction = __webpack_require__(73); | |
var getEventCharCode = __webpack_require__(192); | |
var invariant = __webpack_require__(31); | |
var keyOf = __webpack_require__(30); | |
var topLevelTypes = EventConstants.topLevelTypes; | |
var eventTypes = { | |
abort: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onAbort: true }), | |
captured: keyOf({ onAbortCapture: true }) | |
} | |
}, | |
blur: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onBlur: true }), | |
captured: keyOf({ onBlurCapture: true }) | |
} | |
}, | |
canPlay: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCanPlay: true }), | |
captured: keyOf({ onCanPlayCapture: true }) | |
} | |
}, | |
canPlayThrough: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCanPlayThrough: true }), | |
captured: keyOf({ onCanPlayThroughCapture: true }) | |
} | |
}, | |
click: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onClick: true }), | |
captured: keyOf({ onClickCapture: true }) | |
} | |
}, | |
contextMenu: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onContextMenu: true }), | |
captured: keyOf({ onContextMenuCapture: true }) | |
} | |
}, | |
copy: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCopy: true }), | |
captured: keyOf({ onCopyCapture: true }) | |
} | |
}, | |
cut: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onCut: true }), | |
captured: keyOf({ onCutCapture: true }) | |
} | |
}, | |
doubleClick: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDoubleClick: true }), | |
captured: keyOf({ onDoubleClickCapture: true }) | |
} | |
}, | |
drag: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDrag: true }), | |
captured: keyOf({ onDragCapture: true }) | |
} | |
}, | |
dragEnd: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragEnd: true }), | |
captured: keyOf({ onDragEndCapture: true }) | |
} | |
}, | |
dragEnter: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragEnter: true }), | |
captured: keyOf({ onDragEnterCapture: true }) | |
} | |
}, | |
dragExit: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragExit: true }), | |
captured: keyOf({ onDragExitCapture: true }) | |
} | |
}, | |
dragLeave: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragLeave: true }), | |
captured: keyOf({ onDragLeaveCapture: true }) | |
} | |
}, | |
dragOver: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragOver: true }), | |
captured: keyOf({ onDragOverCapture: true }) | |
} | |
}, | |
dragStart: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDragStart: true }), | |
captured: keyOf({ onDragStartCapture: true }) | |
} | |
}, | |
drop: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDrop: true }), | |
captured: keyOf({ onDropCapture: true }) | |
} | |
}, | |
durationChange: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onDurationChange: true }), | |
captured: keyOf({ onDurationChangeCapture: true }) | |
} | |
}, | |
emptied: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onEmptied: true }), | |
captured: keyOf({ onEmptiedCapture: true }) | |
} | |
}, | |
encrypted: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onEncrypted: true }), | |
captured: keyOf({ onEncryptedCapture: true }) | |
} | |
}, | |
ended: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onEnded: true }), | |
captured: keyOf({ onEndedCapture: true }) | |
} | |
}, | |
error: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onError: true }), | |
captured: keyOf({ onErrorCapture: true }) | |
} | |
}, | |
focus: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onFocus: true }), | |
captured: keyOf({ onFocusCapture: true }) | |
} | |
}, | |
input: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onInput: true }), | |
captured: keyOf({ onInputCapture: true }) | |
} | |
}, | |
keyDown: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onKeyDown: true }), | |
captured: keyOf({ onKeyDownCapture: true }) | |
} | |
}, | |
keyPress: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onKeyPress: true }), | |
captured: keyOf({ onKeyPressCapture: true }) | |
} | |
}, | |
keyUp: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onKeyUp: true }), | |
captured: keyOf({ onKeyUpCapture: true }) | |
} | |
}, | |
load: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onLoad: true }), | |
captured: keyOf({ onLoadCapture: true }) | |
} | |
}, | |
loadedData: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onLoadedData: true }), | |
captured: keyOf({ onLoadedDataCapture: true }) | |
} | |
}, | |
loadedMetadata: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onLoadedMetadata: true }), | |
captured: keyOf({ onLoadedMetadataCapture: true }) | |
} | |
}, | |
loadStart: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onLoadStart: true }), | |
captured: keyOf({ onLoadStartCapture: true }) | |
} | |
}, | |
// Note: We do not allow listening to mouseOver events. Instead, use the | |
// onMouseEnter/onMouseLeave created by `EnterLeaveEventPlugin`. | |
mouseDown: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onMouseDown: true }), | |
captured: keyOf({ onMouseDownCapture: true }) | |
} | |
}, | |
mouseMove: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onMouseMove: true }), | |
captured: keyOf({ onMouseMoveCapture: true }) | |
} | |
}, | |
mouseOut: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onMouseOut: true }), | |
captured: keyOf({ onMouseOutCapture: true }) | |
} | |
}, | |
mouseOver: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onMouseOver: true }), | |
captured: keyOf({ onMouseOverCapture: true }) | |
} | |
}, | |
mouseUp: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onMouseUp: true }), | |
captured: keyOf({ onMouseUpCapture: true }) | |
} | |
}, | |
paste: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onPaste: true }), | |
captured: keyOf({ onPasteCapture: true }) | |
} | |
}, | |
pause: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onPause: true }), | |
captured: keyOf({ onPauseCapture: true }) | |
} | |
}, | |
play: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onPlay: true }), | |
captured: keyOf({ onPlayCapture: true }) | |
} | |
}, | |
playing: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onPlaying: true }), | |
captured: keyOf({ onPlayingCapture: true }) | |
} | |
}, | |
progress: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onProgress: true }), | |
captured: keyOf({ onProgressCapture: true }) | |
} | |
}, | |
rateChange: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onRateChange: true }), | |
captured: keyOf({ onRateChangeCapture: true }) | |
} | |
}, | |
reset: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onReset: true }), | |
captured: keyOf({ onResetCapture: true }) | |
} | |
}, | |
scroll: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onScroll: true }), | |
captured: keyOf({ onScrollCapture: true }) | |
} | |
}, | |
seeked: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onSeeked: true }), | |
captured: keyOf({ onSeekedCapture: true }) | |
} | |
}, | |
seeking: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onSeeking: true }), | |
captured: keyOf({ onSeekingCapture: true }) | |
} | |
}, | |
stalled: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onStalled: true }), | |
captured: keyOf({ onStalledCapture: true }) | |
} | |
}, | |
submit: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onSubmit: true }), | |
captured: keyOf({ onSubmitCapture: true }) | |
} | |
}, | |
suspend: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onSuspend: true }), | |
captured: keyOf({ onSuspendCapture: true }) | |
} | |
}, | |
timeUpdate: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onTimeUpdate: true }), | |
captured: keyOf({ onTimeUpdateCapture: true }) | |
} | |
}, | |
touchCancel: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onTouchCancel: true }), | |
captured: keyOf({ onTouchCancelCapture: true }) | |
} | |
}, | |
touchEnd: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onTouchEnd: true }), | |
captured: keyOf({ onTouchEndCapture: true }) | |
} | |
}, | |
touchMove: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onTouchMove: true }), | |
captured: keyOf({ onTouchMoveCapture: true }) | |
} | |
}, | |
touchStart: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onTouchStart: true }), | |
captured: keyOf({ onTouchStartCapture: true }) | |
} | |
}, | |
volumeChange: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onVolumeChange: true }), | |
captured: keyOf({ onVolumeChangeCapture: true }) | |
} | |
}, | |
waiting: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onWaiting: true }), | |
captured: keyOf({ onWaitingCapture: true }) | |
} | |
}, | |
wheel: { | |
phasedRegistrationNames: { | |
bubbled: keyOf({ onWheel: true }), | |
captured: keyOf({ onWheelCapture: true }) | |
} | |
} | |
}; | |
var topLevelEventsToDispatchConfig = { | |
topAbort: eventTypes.abort, | |
topBlur: eventTypes.blur, | |
topCanPlay: eventTypes.canPlay, | |
topCanPlayThrough: eventTypes.canPlayThrough, | |
topClick: eventTypes.click, | |
topContextMenu: eventTypes.contextMenu, | |
topCopy: eventTypes.copy, | |
topCut: eventTypes.cut, | |
topDoubleClick: eventTypes.doubleClick, | |
topDrag: eventTypes.drag, | |
topDragEnd: eventTypes.dragEnd, | |
topDragEnter: eventTypes.dragEnter, | |
topDragExit: eventTypes.dragExit, | |
topDragLeave: eventTypes.dragLeave, | |
topDragOver: eventTypes.dragOver, | |
topDragStart: eventTypes.dragStart, | |
topDrop: eventTypes.drop, | |
topDurationChange: eventTypes.durationChange, | |
topEmptied: eventTypes.emptied, | |
topEncrypted: eventTypes.encrypted, | |
topEnded: eventTypes.ended, | |
topError: eventTypes.error, | |
topFocus: eventTypes.focus, | |
topInput: eventTypes.input, | |
topKeyDown: eventTypes.keyDown, | |
topKeyPress: eventTypes.keyPress, | |
topKeyUp: eventTypes.keyUp, | |
topLoad: eventTypes.load, | |
topLoadedData: eventTypes.loadedData, | |
topLoadedMetadata: eventTypes.loadedMetadata, | |
topLoadStart: eventTypes.loadStart, | |
topMouseDown: eventTypes.mouseDown, | |
topMouseMove: eventTypes.mouseMove, | |
topMouseOut: eventTypes.mouseOut, | |
topMouseOver: eventTypes.mouseOver, | |
topMouseUp: eventTypes.mouseUp, | |
topPaste: eventTypes.paste, | |
topPause: eventTypes.pause, | |
topPlay: eventTypes.play, | |
topPlaying: eventTypes.playing, | |
topProgress: eventTypes.progress, | |
topRateChange: eventTypes.rateChange, | |
topReset: eventTypes.reset, | |
topScroll: eventTypes.scroll, | |
topSeeked: eventTypes.seeked, | |
topSeeking: eventTypes.seeking, | |
topStalled: eventTypes.stalled, | |
topSubmit: eventTypes.submit, | |
topSuspend: eventTypes.suspend, | |
topTimeUpdate: eventTypes.timeUpdate, | |
topTouchCancel: eventTypes.touchCancel, | |
topTouchEnd: eventTypes.touchEnd, | |
topTouchMove: eventTypes.touchMove, | |
topTouchStart: eventTypes.touchStart, | |
topVolumeChange: eventTypes.volumeChange, | |
topWaiting: eventTypes.waiting, | |
topWheel: eventTypes.wheel | |
}; | |
for (var type in topLevelEventsToDispatchConfig) { | |
topLevelEventsToDispatchConfig[type].dependencies = [type]; | |
} | |
var ON_CLICK_KEY = keyOf({ onClick: null }); | |
var onClickListeners = {}; | |
var SimpleEventPlugin = { | |
eventTypes: eventTypes, | |
/** | |
* @param {string} topLevelType Record from `EventConstants`. | |
* @param {DOMEventTarget} topLevelTarget The listening component root node. | |
* @param {string} topLevelTargetID ID of `topLevelTarget`. | |
* @param {object} nativeEvent Native browser event. | |
* @return {*} An accumulation of synthetic events. | |
* @see {EventPluginHub.extractEvents} | |
*/ | |
extractEvents: function (topLevelType, topLevelTarget, topLevelTargetID, nativeEvent, nativeEventTarget) { | |
var dispatchConfig = topLevelEventsToDispatchConfig[topLevelType]; | |
if (!dispatchConfig) { | |
return null; | |
} | |
var EventConstructor; | |
switch (topLevelType) { | |
case topLevelTypes.topAbort: | |
case topLevelTypes.topCanPlay: | |
case topLevelTypes.topCanPlayThrough: | |
case topLevelTypes.topDurationChange: | |
case topLevelTypes.topEmptied: | |
case topLevelTypes.topEncrypted: | |
case topLevelTypes.topEnded: | |
case topLevelTypes.topError: | |
case topLevelTypes.topInput: | |
case topLevelTypes.topLoad: | |
case topLevelTypes.topLoadedData: | |
case topLevelTypes.topLoadedMetadata: | |
case topLevelTypes.topLoadStart: | |
case topLevelTypes.topPause: | |
case topLevelTypes.topPlay: | |
case topLevelTypes.topPlaying: | |
case topLevelTypes.topProgress: | |
case topLevelTypes.topRateChange: | |
case topLevelTypes.topReset: | |
case topLevelTypes.topSeeked: | |
case topLevelTypes.topSeeking: | |
case topLevelTypes.topStalled: | |
case topLevelTypes.topSubmit: | |
case topLevelTypes.topSuspend: | |
case topLevelTypes.topTimeUpdate: | |
case topLevelTypes.topVolumeChange: | |
case topLevelTypes.topWaiting: | |
// HTML Events | |
// @see http://www.w3.org/TR/html5/index.html#events-0 | |
EventConstructor = SyntheticEvent; | |
break; | |
case topLevelTypes.topKeyPress: | |
// FireFox creates a keypress event for function keys too. This removes | |
// the unwanted keypress events. Enter is however both printable and | |
// non-printable. One would expect Tab to be as well (but it isn't). | |
if (getEventCharCode(nativeEvent) === 0) { | |
return null; | |
} | |
/* falls through */ | |
case topLevelTypes.topKeyDown: | |
case topLevelTypes.topKeyUp: | |
EventConstructor = SyntheticKeyboardEvent; | |
break; | |
case topLevelTypes.topBlur: | |
case topLevelTypes.topFocus: | |
EventConstructor = SyntheticFocusEvent; | |
break; | |
case topLevelTypes.topClick: | |
// Firefox creates a click event on right mouse clicks. This removes the | |
// unwanted click events. | |
if (nativeEvent.button === 2) { | |
return null; | |
} | |
/* falls through */ | |
case topLevelTypes.topContextMenu: | |
case topLevelTypes.topDoubleClick: | |
case topLevelTypes.topMouseDown: | |
case topLevelTypes.topMouseMove: | |
case topLevelTypes.topMouseOut: | |
case topLevelTypes.topMouseOver: | |
case topLevelTypes.topMouseUp: | |
EventConstructor = SyntheticMouseEvent; | |
break; | |
case topLevelTypes.topDrag: | |
case topLevelTypes.topDragEnd: | |
case topLevelTypes.topDragEnter: | |
case topLevelTypes.topDragExit: | |
case topLevelTypes.topDragLeave: | |
case topLevelTypes.topDragOver: | |
case topLevelTypes.topDragStart: | |
case topLevelTypes.topDrop: | |
EventConstructor = SyntheticDragEvent; | |
break; | |
case topLevelTypes.topTouchCancel: | |
case topLevelTypes.topTouchEnd: | |
case topLevelTypes.topTouchMove: | |
case topLevelTypes.topTouchStart: | |
EventConstructor = SyntheticTouchEvent; | |
break; | |
case topLevelTypes.topScroll: | |
EventConstructor = SyntheticUIEvent; | |
break; | |
case topLevelTypes.topWheel: | |
EventConstructor = SyntheticWheelEvent; | |
break; | |
case topLevelTypes.topCopy: | |
case topLevelTypes.topCut: | |
case topLevelTypes.topPaste: | |
EventConstructor = SyntheticClipboardEvent; | |
break; | |
} | |
!EventConstructor ? process.env.NODE_ENV !== 'production' ? invariant(false, 'SimpleEventPlugin: Unhandled event type, `%s`.', topLevelType) : invariant(false) : undefined; | |
var event = EventConstructor.getPooled(dispatchConfig, topLevelTargetID, nativeEvent, nativeEventTarget); | |
EventPropagators.accumulateTwoPhaseDispatches(event); | |
return event; | |
}, | |
didPutListener: function (id, registrationName, listener) { | |
// Mobile Safari does not fire properly bubble click events on | |
// non-interactive elements, which means delegated click listeners do not | |
// fire. The workaround for this bug involves attaching an empty click | |
// listener on the target node. | |
if (registrationName === ON_CLICK_KEY) { | |
var node = ReactMount.getNode(id); | |
if (!onClickListeners[id]) { | |
onClickListeners[id] = EventListener.listen(node, 'click', emptyFunction); | |
} | |
} | |
}, | |
willDeleteListener: function (id, registrationName) { | |
if (registrationName === ON_CLICK_KEY) { | |
onClickListeners[id].remove(); | |
delete onClickListeners[id]; | |
} | |
} | |
}; | |
module.exports = SimpleEventPlugin; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 189 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticClipboardEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticEvent = __webpack_require__(134); | |
/** | |
* @interface Event | |
* @see http://www.w3.org/TR/clipboard-apis/ | |
*/ | |
var ClipboardEventInterface = { | |
clipboardData: function (event) { | |
return 'clipboardData' in event ? event.clipboardData : window.clipboardData; | |
} | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticClipboardEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticEvent.augmentClass(SyntheticClipboardEvent, ClipboardEventInterface); | |
module.exports = SyntheticClipboardEvent; | |
/***/ }, | |
/* 190 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticFocusEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticUIEvent = __webpack_require__(143); | |
/** | |
* @interface FocusEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var FocusEventInterface = { | |
relatedTarget: null | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticFocusEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticUIEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticUIEvent.augmentClass(SyntheticFocusEvent, FocusEventInterface); | |
module.exports = SyntheticFocusEvent; | |
/***/ }, | |
/* 191 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticKeyboardEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticUIEvent = __webpack_require__(143); | |
var getEventCharCode = __webpack_require__(192); | |
var getEventKey = __webpack_require__(193); | |
var getEventModifierState = __webpack_require__(144); | |
/** | |
* @interface KeyboardEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var KeyboardEventInterface = { | |
key: getEventKey, | |
location: null, | |
ctrlKey: null, | |
shiftKey: null, | |
altKey: null, | |
metaKey: null, | |
repeat: null, | |
locale: null, | |
getModifierState: getEventModifierState, | |
// Legacy Interface | |
charCode: function (event) { | |
// `charCode` is the result of a KeyPress event and represents the value of | |
// the actual printable character. | |
// KeyPress is deprecated, but its replacement is not yet final and not | |
// implemented in any major browser. Only KeyPress has charCode. | |
if (event.type === 'keypress') { | |
return getEventCharCode(event); | |
} | |
return 0; | |
}, | |
keyCode: function (event) { | |
// `keyCode` is the result of a KeyDown/Up event and represents the value of | |
// physical keyboard key. | |
// The actual meaning of the value depends on the users' keyboard layout | |
// which cannot be detected. Assuming that it is a US keyboard layout | |
// provides a surprisingly accurate mapping for US and European users. | |
// Due to this, it is left to the user to implement at this time. | |
if (event.type === 'keydown' || event.type === 'keyup') { | |
return event.keyCode; | |
} | |
return 0; | |
}, | |
which: function (event) { | |
// `which` is an alias for either `keyCode` or `charCode` depending on the | |
// type of the event. | |
if (event.type === 'keypress') { | |
return getEventCharCode(event); | |
} | |
if (event.type === 'keydown' || event.type === 'keyup') { | |
return event.keyCode; | |
} | |
return 0; | |
} | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticKeyboardEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticUIEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticUIEvent.augmentClass(SyntheticKeyboardEvent, KeyboardEventInterface); | |
module.exports = SyntheticKeyboardEvent; | |
/***/ }, | |
/* 192 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getEventCharCode | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
/** | |
* `charCode` represents the actual "character code" and is safe to use with | |
* `String.fromCharCode`. As such, only keys that correspond to printable | |
* characters produce a valid `charCode`, the only exception to this is Enter. | |
* The Tab-key is considered non-printable and does not have a `charCode`, | |
* presumably because it does not produce a tab-character in browsers. | |
* | |
* @param {object} nativeEvent Native browser event. | |
* @return {number} Normalized `charCode` property. | |
*/ | |
function getEventCharCode(nativeEvent) { | |
var charCode; | |
var keyCode = nativeEvent.keyCode; | |
if ('charCode' in nativeEvent) { | |
charCode = nativeEvent.charCode; | |
// FF does not set `charCode` for the Enter-key, check against `keyCode`. | |
if (charCode === 0 && keyCode === 13) { | |
charCode = 13; | |
} | |
} else { | |
// IE8 does not implement `charCode`, but `keyCode` has the correct value. | |
charCode = keyCode; | |
} | |
// Some non-printable keys are reported in `charCode`/`keyCode`, discard them. | |
// Must not discard the (non-)printable Enter-key. | |
if (charCode >= 32 || charCode === 13) { | |
return charCode; | |
} | |
return 0; | |
} | |
module.exports = getEventCharCode; | |
/***/ }, | |
/* 193 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule getEventKey | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var getEventCharCode = __webpack_require__(192); | |
/** | |
* Normalization of deprecated HTML5 `key` values | |
* @see https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent#Key_names | |
*/ | |
var normalizeKey = { | |
'Esc': 'Escape', | |
'Spacebar': ' ', | |
'Left': 'ArrowLeft', | |
'Up': 'ArrowUp', | |
'Right': 'ArrowRight', | |
'Down': 'ArrowDown', | |
'Del': 'Delete', | |
'Win': 'OS', | |
'Menu': 'ContextMenu', | |
'Apps': 'ContextMenu', | |
'Scroll': 'ScrollLock', | |
'MozPrintableKey': 'Unidentified' | |
}; | |
/** | |
* Translation from legacy `keyCode` to HTML5 `key` | |
* Only special keys supported, all others depend on keyboard layout or browser | |
* @see https://developer.mozilla.org/en-US/docs/Web/API/KeyboardEvent#Key_names | |
*/ | |
var translateToKey = { | |
8: 'Backspace', | |
9: 'Tab', | |
12: 'Clear', | |
13: 'Enter', | |
16: 'Shift', | |
17: 'Control', | |
18: 'Alt', | |
19: 'Pause', | |
20: 'CapsLock', | |
27: 'Escape', | |
32: ' ', | |
33: 'PageUp', | |
34: 'PageDown', | |
35: 'End', | |
36: 'Home', | |
37: 'ArrowLeft', | |
38: 'ArrowUp', | |
39: 'ArrowRight', | |
40: 'ArrowDown', | |
45: 'Insert', | |
46: 'Delete', | |
112: 'F1', 113: 'F2', 114: 'F3', 115: 'F4', 116: 'F5', 117: 'F6', | |
118: 'F7', 119: 'F8', 120: 'F9', 121: 'F10', 122: 'F11', 123: 'F12', | |
144: 'NumLock', | |
145: 'ScrollLock', | |
224: 'Meta' | |
}; | |
/** | |
* @param {object} nativeEvent Native browser event. | |
* @return {string} Normalized `key` property. | |
*/ | |
function getEventKey(nativeEvent) { | |
if (nativeEvent.key) { | |
// Normalize inconsistent values reported by browsers due to | |
// implementations of a working draft specification. | |
// FireFox implements `key` but returns `MozPrintableKey` for all | |
// printable characters (normalized to `Unidentified`), ignore it. | |
var key = normalizeKey[nativeEvent.key] || nativeEvent.key; | |
if (key !== 'Unidentified') { | |
return key; | |
} | |
} | |
// Browser does not implement `key`, polyfill as much of it as we can. | |
if (nativeEvent.type === 'keypress') { | |
var charCode = getEventCharCode(nativeEvent); | |
// The enter-key is technically both printable and non-printable and can | |
// thus be captured by `keypress`, no other non-printable key should. | |
return charCode === 13 ? 'Enter' : String.fromCharCode(charCode); | |
} | |
if (nativeEvent.type === 'keydown' || nativeEvent.type === 'keyup') { | |
// While user keyboard layout determines the actual meaning of each | |
// `keyCode` value, almost all function keys have a universal value. | |
return translateToKey[nativeEvent.keyCode] || 'Unidentified'; | |
} | |
return ''; | |
} | |
module.exports = getEventKey; | |
/***/ }, | |
/* 194 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticDragEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticMouseEvent = __webpack_require__(142); | |
/** | |
* @interface DragEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var DragEventInterface = { | |
dataTransfer: null | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticDragEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticMouseEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticMouseEvent.augmentClass(SyntheticDragEvent, DragEventInterface); | |
module.exports = SyntheticDragEvent; | |
/***/ }, | |
/* 195 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticTouchEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticUIEvent = __webpack_require__(143); | |
var getEventModifierState = __webpack_require__(144); | |
/** | |
* @interface TouchEvent | |
* @see http://www.w3.org/TR/touch-events/ | |
*/ | |
var TouchEventInterface = { | |
touches: null, | |
targetTouches: null, | |
changedTouches: null, | |
altKey: null, | |
metaKey: null, | |
ctrlKey: null, | |
shiftKey: null, | |
getModifierState: getEventModifierState | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticUIEvent} | |
*/ | |
function SyntheticTouchEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticUIEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticUIEvent.augmentClass(SyntheticTouchEvent, TouchEventInterface); | |
module.exports = SyntheticTouchEvent; | |
/***/ }, | |
/* 196 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SyntheticWheelEvent | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var SyntheticMouseEvent = __webpack_require__(142); | |
/** | |
* @interface WheelEvent | |
* @see http://www.w3.org/TR/DOM-Level-3-Events/ | |
*/ | |
var WheelEventInterface = { | |
deltaX: function (event) { | |
return 'deltaX' in event ? event.deltaX : | |
// Fallback to `wheelDeltaX` for Webkit and normalize (right is positive). | |
'wheelDeltaX' in event ? -event.wheelDeltaX : 0; | |
}, | |
deltaY: function (event) { | |
return 'deltaY' in event ? event.deltaY : | |
// Fallback to `wheelDeltaY` for Webkit and normalize (down is positive). | |
'wheelDeltaY' in event ? -event.wheelDeltaY : | |
// Fallback to `wheelDelta` for IE<9 and normalize (down is positive). | |
'wheelDelta' in event ? -event.wheelDelta : 0; | |
}, | |
deltaZ: null, | |
// Browsers without "deltaMode" is reporting in raw wheel delta where one | |
// notch on the scroll is always +/- 120, roughly equivalent to pixels. | |
// A good approximation of DOM_DELTA_LINE (1) is 5% of viewport size or | |
// ~40 pixels, for DOM_DELTA_SCREEN (2) it is 87.5% of viewport size. | |
deltaMode: null | |
}; | |
/** | |
* @param {object} dispatchConfig Configuration used to dispatch this event. | |
* @param {string} dispatchMarker Marker identifying the event target. | |
* @param {object} nativeEvent Native browser event. | |
* @extends {SyntheticMouseEvent} | |
*/ | |
function SyntheticWheelEvent(dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget) { | |
SyntheticMouseEvent.call(this, dispatchConfig, dispatchMarker, nativeEvent, nativeEventTarget); | |
} | |
SyntheticMouseEvent.augmentClass(SyntheticWheelEvent, WheelEventInterface); | |
module.exports = SyntheticWheelEvent; | |
/***/ }, | |
/* 197 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule SVGDOMPropertyConfig | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var MUST_USE_ATTRIBUTE = DOMProperty.injection.MUST_USE_ATTRIBUTE; | |
var NS = { | |
xlink: 'http://www.w3.org/1999/xlink', | |
xml: 'http://www.w3.org/XML/1998/namespace' | |
}; | |
var SVGDOMPropertyConfig = { | |
Properties: { | |
clipPath: MUST_USE_ATTRIBUTE, | |
cx: MUST_USE_ATTRIBUTE, | |
cy: MUST_USE_ATTRIBUTE, | |
d: MUST_USE_ATTRIBUTE, | |
dx: MUST_USE_ATTRIBUTE, | |
dy: MUST_USE_ATTRIBUTE, | |
fill: MUST_USE_ATTRIBUTE, | |
fillOpacity: MUST_USE_ATTRIBUTE, | |
fontFamily: MUST_USE_ATTRIBUTE, | |
fontSize: MUST_USE_ATTRIBUTE, | |
fx: MUST_USE_ATTRIBUTE, | |
fy: MUST_USE_ATTRIBUTE, | |
gradientTransform: MUST_USE_ATTRIBUTE, | |
gradientUnits: MUST_USE_ATTRIBUTE, | |
markerEnd: MUST_USE_ATTRIBUTE, | |
markerMid: MUST_USE_ATTRIBUTE, | |
markerStart: MUST_USE_ATTRIBUTE, | |
offset: MUST_USE_ATTRIBUTE, | |
opacity: MUST_USE_ATTRIBUTE, | |
patternContentUnits: MUST_USE_ATTRIBUTE, | |
patternUnits: MUST_USE_ATTRIBUTE, | |
points: MUST_USE_ATTRIBUTE, | |
preserveAspectRatio: MUST_USE_ATTRIBUTE, | |
r: MUST_USE_ATTRIBUTE, | |
rx: MUST_USE_ATTRIBUTE, | |
ry: MUST_USE_ATTRIBUTE, | |
spreadMethod: MUST_USE_ATTRIBUTE, | |
stopColor: MUST_USE_ATTRIBUTE, | |
stopOpacity: MUST_USE_ATTRIBUTE, | |
stroke: MUST_USE_ATTRIBUTE, | |
strokeDasharray: MUST_USE_ATTRIBUTE, | |
strokeLinecap: MUST_USE_ATTRIBUTE, | |
strokeOpacity: MUST_USE_ATTRIBUTE, | |
strokeWidth: MUST_USE_ATTRIBUTE, | |
textAnchor: MUST_USE_ATTRIBUTE, | |
transform: MUST_USE_ATTRIBUTE, | |
version: MUST_USE_ATTRIBUTE, | |
viewBox: MUST_USE_ATTRIBUTE, | |
x1: MUST_USE_ATTRIBUTE, | |
x2: MUST_USE_ATTRIBUTE, | |
x: MUST_USE_ATTRIBUTE, | |
xlinkActuate: MUST_USE_ATTRIBUTE, | |
xlinkArcrole: MUST_USE_ATTRIBUTE, | |
xlinkHref: MUST_USE_ATTRIBUTE, | |
xlinkRole: MUST_USE_ATTRIBUTE, | |
xlinkShow: MUST_USE_ATTRIBUTE, | |
xlinkTitle: MUST_USE_ATTRIBUTE, | |
xlinkType: MUST_USE_ATTRIBUTE, | |
xmlBase: MUST_USE_ATTRIBUTE, | |
xmlLang: MUST_USE_ATTRIBUTE, | |
xmlSpace: MUST_USE_ATTRIBUTE, | |
y1: MUST_USE_ATTRIBUTE, | |
y2: MUST_USE_ATTRIBUTE, | |
y: MUST_USE_ATTRIBUTE | |
}, | |
DOMAttributeNamespaces: { | |
xlinkActuate: NS.xlink, | |
xlinkArcrole: NS.xlink, | |
xlinkHref: NS.xlink, | |
xlinkRole: NS.xlink, | |
xlinkShow: NS.xlink, | |
xlinkTitle: NS.xlink, | |
xlinkType: NS.xlink, | |
xmlBase: NS.xml, | |
xmlLang: NS.xml, | |
xmlSpace: NS.xml | |
}, | |
DOMAttributeNames: { | |
clipPath: 'clip-path', | |
fillOpacity: 'fill-opacity', | |
fontFamily: 'font-family', | |
fontSize: 'font-size', | |
gradientTransform: 'gradientTransform', | |
gradientUnits: 'gradientUnits', | |
markerEnd: 'marker-end', | |
markerMid: 'marker-mid', | |
markerStart: 'marker-start', | |
patternContentUnits: 'patternContentUnits', | |
patternUnits: 'patternUnits', | |
preserveAspectRatio: 'preserveAspectRatio', | |
spreadMethod: 'spreadMethod', | |
stopColor: 'stop-color', | |
stopOpacity: 'stop-opacity', | |
strokeDasharray: 'stroke-dasharray', | |
strokeLinecap: 'stroke-linecap', | |
strokeOpacity: 'stroke-opacity', | |
strokeWidth: 'stroke-width', | |
textAnchor: 'text-anchor', | |
viewBox: 'viewBox', | |
xlinkActuate: 'xlink:actuate', | |
xlinkArcrole: 'xlink:arcrole', | |
xlinkHref: 'xlink:href', | |
xlinkRole: 'xlink:role', | |
xlinkShow: 'xlink:show', | |
xlinkTitle: 'xlink:title', | |
xlinkType: 'xlink:type', | |
xmlBase: 'xml:base', | |
xmlLang: 'xml:lang', | |
xmlSpace: 'xml:space' | |
} | |
}; | |
module.exports = SVGDOMPropertyConfig; | |
/***/ }, | |
/* 198 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDefaultPerf | |
* @typechecks static-only | |
*/ | |
'use strict'; | |
var DOMProperty = __webpack_require__(81); | |
var ReactDefaultPerfAnalysis = __webpack_require__(199); | |
var ReactMount = __webpack_require__(86); | |
var ReactPerf = __webpack_require__(76); | |
var performanceNow = __webpack_require__(200); | |
function roundFloat(val) { | |
return Math.floor(val * 100) / 100; | |
} | |
function addValue(obj, key, val) { | |
obj[key] = (obj[key] || 0) + val; | |
} | |
var ReactDefaultPerf = { | |
_allMeasurements: [], // last item in the list is the current one | |
_mountStack: [0], | |
_injected: false, | |
start: function () { | |
if (!ReactDefaultPerf._injected) { | |
ReactPerf.injection.injectMeasure(ReactDefaultPerf.measure); | |
} | |
ReactDefaultPerf._allMeasurements.length = 0; | |
ReactPerf.enableMeasure = true; | |
}, | |
stop: function () { | |
ReactPerf.enableMeasure = false; | |
}, | |
getLastMeasurements: function () { | |
return ReactDefaultPerf._allMeasurements; | |
}, | |
printExclusive: function (measurements) { | |
measurements = measurements || ReactDefaultPerf._allMeasurements; | |
var summary = ReactDefaultPerfAnalysis.getExclusiveSummary(measurements); | |
console.table(summary.map(function (item) { | |
return { | |
'Component class name': item.componentName, | |
'Total inclusive time (ms)': roundFloat(item.inclusive), | |
'Exclusive mount time (ms)': roundFloat(item.exclusive), | |
'Exclusive render time (ms)': roundFloat(item.render), | |
'Mount time per instance (ms)': roundFloat(item.exclusive / item.count), | |
'Render time per instance (ms)': roundFloat(item.render / item.count), | |
'Instances': item.count | |
}; | |
})); | |
// TODO: ReactDefaultPerfAnalysis.getTotalTime() does not return the correct | |
// number. | |
}, | |
printInclusive: function (measurements) { | |
measurements = measurements || ReactDefaultPerf._allMeasurements; | |
var summary = ReactDefaultPerfAnalysis.getInclusiveSummary(measurements); | |
console.table(summary.map(function (item) { | |
return { | |
'Owner > component': item.componentName, | |
'Inclusive time (ms)': roundFloat(item.time), | |
'Instances': item.count | |
}; | |
})); | |
console.log('Total time:', ReactDefaultPerfAnalysis.getTotalTime(measurements).toFixed(2) + ' ms'); | |
}, | |
getMeasurementsSummaryMap: function (measurements) { | |
var summary = ReactDefaultPerfAnalysis.getInclusiveSummary(measurements, true); | |
return summary.map(function (item) { | |
return { | |
'Owner > component': item.componentName, | |
'Wasted time (ms)': item.time, | |
'Instances': item.count | |
}; | |
}); | |
}, | |
printWasted: function (measurements) { | |
measurements = measurements || ReactDefaultPerf._allMeasurements; | |
console.table(ReactDefaultPerf.getMeasurementsSummaryMap(measurements)); | |
console.log('Total time:', ReactDefaultPerfAnalysis.getTotalTime(measurements).toFixed(2) + ' ms'); | |
}, | |
printDOM: function (measurements) { | |
measurements = measurements || ReactDefaultPerf._allMeasurements; | |
var summary = ReactDefaultPerfAnalysis.getDOMSummary(measurements); | |
console.table(summary.map(function (item) { | |
var result = {}; | |
result[DOMProperty.ID_ATTRIBUTE_NAME] = item.id; | |
result.type = item.type; | |
result.args = JSON.stringify(item.args); | |
return result; | |
})); | |
console.log('Total time:', ReactDefaultPerfAnalysis.getTotalTime(measurements).toFixed(2) + ' ms'); | |
}, | |
_recordWrite: function (id, fnName, totalTime, args) { | |
// TODO: totalTime isn't that useful since it doesn't count paints/reflows | |
var writes = ReactDefaultPerf._allMeasurements[ReactDefaultPerf._allMeasurements.length - 1].writes; | |
writes[id] = writes[id] || []; | |
writes[id].push({ | |
type: fnName, | |
time: totalTime, | |
args: args | |
}); | |
}, | |
measure: function (moduleName, fnName, func) { | |
return function () { | |
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { | |
args[_key] = arguments[_key]; | |
} | |
var totalTime; | |
var rv; | |
var start; | |
if (fnName === '_renderNewRootComponent' || fnName === 'flushBatchedUpdates') { | |
// A "measurement" is a set of metrics recorded for each flush. We want | |
// to group the metrics for a given flush together so we can look at the | |
// components that rendered and the DOM operations that actually | |
// happened to determine the amount of "wasted work" performed. | |
ReactDefaultPerf._allMeasurements.push({ | |
exclusive: {}, | |
inclusive: {}, | |
render: {}, | |
counts: {}, | |
writes: {}, | |
displayNames: {}, | |
totalTime: 0, | |
created: {} | |
}); | |
start = performanceNow(); | |
rv = func.apply(this, args); | |
ReactDefaultPerf._allMeasurements[ReactDefaultPerf._allMeasurements.length - 1].totalTime = performanceNow() - start; | |
return rv; | |
} else if (fnName === '_mountImageIntoNode' || moduleName === 'ReactBrowserEventEmitter' || moduleName === 'ReactDOMIDOperations' || moduleName === 'CSSPropertyOperations' || moduleName === 'DOMChildrenOperations' || moduleName === 'DOMPropertyOperations') { | |
start = performanceNow(); | |
rv = func.apply(this, args); | |
totalTime = performanceNow() - start; | |
if (fnName === '_mountImageIntoNode') { | |
var mountID = ReactMount.getID(args[1]); | |
ReactDefaultPerf._recordWrite(mountID, fnName, totalTime, args[0]); | |
} else if (fnName === 'dangerouslyProcessChildrenUpdates') { | |
// special format | |
args[0].forEach(function (update) { | |
var writeArgs = {}; | |
if (update.fromIndex !== null) { | |
writeArgs.fromIndex = update.fromIndex; | |
} | |
if (update.toIndex !== null) { | |
writeArgs.toIndex = update.toIndex; | |
} | |
if (update.textContent !== null) { | |
writeArgs.textContent = update.textContent; | |
} | |
if (update.markupIndex !== null) { | |
writeArgs.markup = args[1][update.markupIndex]; | |
} | |
ReactDefaultPerf._recordWrite(update.parentID, update.type, totalTime, writeArgs); | |
}); | |
} else { | |
// basic format | |
var id = args[0]; | |
if (typeof id === 'object') { | |
id = ReactMount.getID(args[0]); | |
} | |
ReactDefaultPerf._recordWrite(id, fnName, totalTime, Array.prototype.slice.call(args, 1)); | |
} | |
return rv; | |
} else if (moduleName === 'ReactCompositeComponent' && (fnName === 'mountComponent' || fnName === 'updateComponent' || // TODO: receiveComponent()? | |
fnName === '_renderValidatedComponent')) { | |
if (this._currentElement.type === ReactMount.TopLevelWrapper) { | |
return func.apply(this, args); | |
} | |
var rootNodeID = fnName === 'mountComponent' ? args[0] : this._rootNodeID; | |
var isRender = fnName === '_renderValidatedComponent'; | |
var isMount = fnName === 'mountComponent'; | |
var mountStack = ReactDefaultPerf._mountStack; | |
var entry = ReactDefaultPerf._allMeasurements[ReactDefaultPerf._allMeasurements.length - 1]; | |
if (isRender) { | |
addValue(entry.counts, rootNodeID, 1); | |
} else if (isMount) { | |
entry.created[rootNodeID] = true; | |
mountStack.push(0); | |
} | |
start = performanceNow(); | |
rv = func.apply(this, args); | |
totalTime = performanceNow() - start; | |
if (isRender) { | |
addValue(entry.render, rootNodeID, totalTime); | |
} else if (isMount) { | |
var subMountTime = mountStack.pop(); | |
mountStack[mountStack.length - 1] += totalTime; | |
addValue(entry.exclusive, rootNodeID, totalTime - subMountTime); | |
addValue(entry.inclusive, rootNodeID, totalTime); | |
} else { | |
addValue(entry.inclusive, rootNodeID, totalTime); | |
} | |
entry.displayNames[rootNodeID] = { | |
current: this.getName(), | |
owner: this._currentElement._owner ? this._currentElement._owner.getName() : '<root>' | |
}; | |
return rv; | |
} else { | |
return func.apply(this, args); | |
} | |
}; | |
} | |
}; | |
module.exports = ReactDefaultPerf; | |
/***/ }, | |
/* 199 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactDefaultPerfAnalysis | |
*/ | |
'use strict'; | |
var assign = __webpack_require__(29); | |
// Don't try to save users less than 1.2ms (a number I made up) | |
var DONT_CARE_THRESHOLD = 1.2; | |
var DOM_OPERATION_TYPES = { | |
'_mountImageIntoNode': 'set innerHTML', | |
INSERT_MARKUP: 'set innerHTML', | |
MOVE_EXISTING: 'move', | |
REMOVE_NODE: 'remove', | |
SET_MARKUP: 'set innerHTML', | |
TEXT_CONTENT: 'set textContent', | |
'setValueForProperty': 'update attribute', | |
'setValueForAttribute': 'update attribute', | |
'deleteValueForProperty': 'remove attribute', | |
'setValueForStyles': 'update styles', | |
'replaceNodeWithMarkup': 'replace', | |
'updateTextContent': 'set textContent' | |
}; | |
function getTotalTime(measurements) { | |
// TODO: return number of DOM ops? could be misleading. | |
// TODO: measure dropped frames after reconcile? | |
// TODO: log total time of each reconcile and the top-level component | |
// class that triggered it. | |
var totalTime = 0; | |
for (var i = 0; i < measurements.length; i++) { | |
var measurement = measurements[i]; | |
totalTime += measurement.totalTime; | |
} | |
return totalTime; | |
} | |
function getDOMSummary(measurements) { | |
var items = []; | |
measurements.forEach(function (measurement) { | |
Object.keys(measurement.writes).forEach(function (id) { | |
measurement.writes[id].forEach(function (write) { | |
items.push({ | |
id: id, | |
type: DOM_OPERATION_TYPES[write.type] || write.type, | |
args: write.args | |
}); | |
}); | |
}); | |
}); | |
return items; | |
} | |
function getExclusiveSummary(measurements) { | |
var candidates = {}; | |
var displayName; | |
for (var i = 0; i < measurements.length; i++) { | |
var measurement = measurements[i]; | |
var allIDs = assign({}, measurement.exclusive, measurement.inclusive); | |
for (var id in allIDs) { | |
displayName = measurement.displayNames[id].current; | |
candidates[displayName] = candidates[displayName] || { | |
componentName: displayName, | |
inclusive: 0, | |
exclusive: 0, | |
render: 0, | |
count: 0 | |
}; | |
if (measurement.render[id]) { | |
candidates[displayName].render += measurement.render[id]; | |
} | |
if (measurement.exclusive[id]) { | |
candidates[displayName].exclusive += measurement.exclusive[id]; | |
} | |
if (measurement.inclusive[id]) { | |
candidates[displayName].inclusive += measurement.inclusive[id]; | |
} | |
if (measurement.counts[id]) { | |
candidates[displayName].count += measurement.counts[id]; | |
} | |
} | |
} | |
// Now make a sorted array with the results. | |
var arr = []; | |
for (displayName in candidates) { | |
if (candidates[displayName].exclusive >= DONT_CARE_THRESHOLD) { | |
arr.push(candidates[displayName]); | |
} | |
} | |
arr.sort(function (a, b) { | |
return b.exclusive - a.exclusive; | |
}); | |
return arr; | |
} | |
function getInclusiveSummary(measurements, onlyClean) { | |
var candidates = {}; | |
var inclusiveKey; | |
for (var i = 0; i < measurements.length; i++) { | |
var measurement = measurements[i]; | |
var allIDs = assign({}, measurement.exclusive, measurement.inclusive); | |
var cleanComponents; | |
if (onlyClean) { | |
cleanComponents = getUnchangedComponents(measurement); | |
} | |
for (var id in allIDs) { | |
if (onlyClean && !cleanComponents[id]) { | |
continue; | |
} | |
var displayName = measurement.displayNames[id]; | |
// Inclusive time is not useful for many components without knowing where | |
// they are instantiated. So we aggregate inclusive time with both the | |
// owner and current displayName as the key. | |
inclusiveKey = displayName.owner + ' > ' + displayName.current; | |
candidates[inclusiveKey] = candidates[inclusiveKey] || { | |
componentName: inclusiveKey, | |
time: 0, | |
count: 0 | |
}; | |
if (measurement.inclusive[id]) { | |
candidates[inclusiveKey].time += measurement.inclusive[id]; | |
} | |
if (measurement.counts[id]) { | |
candidates[inclusiveKey].count += measurement.counts[id]; | |
} | |
} | |
} | |
// Now make a sorted array with the results. | |
var arr = []; | |
for (inclusiveKey in candidates) { | |
if (candidates[inclusiveKey].time >= DONT_CARE_THRESHOLD) { | |
arr.push(candidates[inclusiveKey]); | |
} | |
} | |
arr.sort(function (a, b) { | |
return b.time - a.time; | |
}); | |
return arr; | |
} | |
function getUnchangedComponents(measurement) { | |
// For a given reconcile, look at which components did not actually | |
// render anything to the DOM and return a mapping of their ID to | |
// the amount of time it took to render the entire subtree. | |
var cleanComponents = {}; | |
var dirtyLeafIDs = Object.keys(measurement.writes); | |
var allIDs = assign({}, measurement.exclusive, measurement.inclusive); | |
for (var id in allIDs) { | |
var isDirty = false; | |
// For each component that rendered, see if a component that triggered | |
// a DOM op is in its subtree. | |
for (var i = 0; i < dirtyLeafIDs.length; i++) { | |
if (dirtyLeafIDs[i].indexOf(id) === 0) { | |
isDirty = true; | |
break; | |
} | |
} | |
// check if component newly created | |
if (measurement.created[id]) { | |
isDirty = true; | |
} | |
if (!isDirty && measurement.counts[id] > 0) { | |
cleanComponents[id] = true; | |
} | |
} | |
return cleanComponents; | |
} | |
var ReactDefaultPerfAnalysis = { | |
getExclusiveSummary: getExclusiveSummary, | |
getInclusiveSummary: getInclusiveSummary, | |
getDOMSummary: getDOMSummary, | |
getTotalTime: getTotalTime | |
}; | |
module.exports = ReactDefaultPerfAnalysis; | |
/***/ }, | |
/* 200 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule performanceNow | |
* @typechecks | |
*/ | |
'use strict'; | |
var performance = __webpack_require__(201); | |
var performanceNow; | |
/** | |
* Detect if we can use `window.performance.now()` and gracefully fallback to | |
* `Date.now()` if it doesn't exist. We need to support Firefox < 15 for now | |
* because of Facebook's testing infrastructure. | |
*/ | |
if (performance.now) { | |
performanceNow = function () { | |
return performance.now(); | |
}; | |
} else { | |
performanceNow = function () { | |
return Date.now(); | |
}; | |
} | |
module.exports = performanceNow; | |
/***/ }, | |
/* 201 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule performance | |
* @typechecks | |
*/ | |
'use strict'; | |
var ExecutionEnvironment = __webpack_require__(68); | |
var performance; | |
if (ExecutionEnvironment.canUseDOM) { | |
performance = window.performance || window.msPerformance || window.webkitPerformance; | |
} | |
module.exports = performance || {}; | |
/***/ }, | |
/* 202 */ | |
/***/ function(module, exports) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactVersion | |
*/ | |
'use strict'; | |
module.exports = '0.14.7'; | |
/***/ }, | |
/* 203 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule renderSubtreeIntoContainer | |
*/ | |
'use strict'; | |
var ReactMount = __webpack_require__(86); | |
module.exports = ReactMount.renderSubtreeIntoContainer; | |
/***/ }, | |
/* 204 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var ClockNumber = _react2.default.createClass({ | |
displayName: 'ClockNumber', | |
propTypes: { | |
isSelected: _react2.default.PropTypes.bool, | |
onSelected: _react2.default.PropTypes.func, | |
type: _react2.default.PropTypes.oneOf(['hour', 'minute']), | |
value: _react2.default.PropTypes.number | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
value: 0, | |
type: 'minute', | |
isSelected: false | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
getTheme: function getTheme() { | |
return this.state.muiTheme.timePicker; | |
}, | |
render: function render() { | |
var pos = this.props.value; | |
var inner = false; | |
if (this.props.type === 'hour') { | |
inner = pos < 1 || pos > 12; | |
pos %= 12; | |
} else { | |
pos = pos / 5; | |
} | |
var positions = [[0, 5], [54.5, 16.6], [94.4, 59.5], [109, 114], [94.4, 168.5], [54.5, 208.4], [0, 223], [-54.5, 208.4], [-94.4, 168.5], [-109, 114], [-94.4, 59.5], [-54.5, 19.6]]; | |
var innerPositions = [[0, 40], [36.9, 49.9], [64, 77], [74, 114], [64, 151], [37, 178], [0, 188], [-37, 178], [-64, 151], [-74, 114], [-64, 77], [-37, 50]]; | |
var styles = { | |
root: { | |
display: 'inline-block', | |
position: 'absolute', | |
width: 32, | |
height: 32, | |
borderRadius: '100%', | |
left: 'calc(50% - 16px)', | |
top: 10, | |
textAlign: 'center', | |
paddingTop: 5, | |
userSelect: 'none', /* Chrome all / Safari all */ | |
fontSize: '1.1em', | |
pointerEvents: 'none', | |
boxSizing: 'border-box' | |
} | |
}; | |
if (this.props.isSelected) { | |
styles.root.backgroundColor = this.getTheme().accentColor; | |
styles.root.color = this.getTheme().selectTextColor; | |
} | |
var transformPos = positions[pos]; | |
if (inner) { | |
styles.root.width = 28; | |
styles.root.height = 28; | |
styles.root.left = 'calc(50% - 14px)'; | |
transformPos = innerPositions[pos]; | |
} | |
var _transformPos = transformPos; | |
var _transformPos2 = _slicedToArray(_transformPos, 2); | |
var x = _transformPos2[0]; | |
var y = _transformPos2[1]; | |
styles.root.transform = 'translate(' + x + 'px, ' + y + 'px)'; | |
return _react2.default.createElement( | |
'span', | |
{ style: this.prepareStyles(styles.root) }, | |
this.props.value | |
); | |
} | |
}); | |
exports.default = ClockNumber; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 205 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var ClockPointer = _react2.default.createClass({ | |
displayName: 'ClockPointer', | |
propTypes: { | |
hasSelected: _react2.default.PropTypes.bool, | |
type: _react2.default.PropTypes.oneOf(['hour', 'minute']), | |
value: _react2.default.PropTypes.number | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
value: null, | |
type: 'minute', | |
hasSelected: false | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
inner: this.isInner(this.props.value), | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ | |
inner: this.isInner(nextProps.value), | |
muiTheme: newMuiTheme | |
}); | |
}, | |
isInner: function isInner(value) { | |
if (this.props.type !== 'hour') { | |
return false; | |
} | |
return value < 1 || value > 12; | |
}, | |
getAngle: function getAngle() { | |
if (this.props.type === 'hour') { | |
return this.calcAngle(this.props.value, 12); | |
} | |
return this.calcAngle(this.props.value, 60); | |
}, | |
calcAngle: function calcAngle(value, base) { | |
value %= base; | |
var angle = 360 / base * value; | |
return angle; | |
}, | |
getTheme: function getTheme() { | |
return this.state.muiTheme.timePicker; | |
}, | |
render: function render() { | |
if (this.props.value === null) { | |
return _react2.default.createElement('span', null); | |
} | |
var angle = this.getAngle(); | |
var styles = { | |
root: { | |
height: '30%', | |
background: this.getTheme().accentColor, | |
width: 2, | |
left: 'calc(50% - 1px)', | |
position: 'absolute', | |
bottom: '50%', | |
transformOrigin: 'bottom', | |
pointerEvents: 'none', | |
transform: 'rotateZ(' + angle + 'deg)' | |
}, | |
mark: { | |
background: this.getTheme().selectTextColor, | |
border: '4px solid ' + this.getTheme().accentColor, | |
width: 7, | |
height: 7, | |
position: 'absolute', | |
top: -5, | |
left: -6, | |
borderRadius: '100%' | |
} | |
}; | |
if (!this.state.inner) { | |
styles.root.height = '40%'; | |
} | |
if (this.props.hasSelected) { | |
styles.mark.display = 'none'; | |
} | |
return _react2.default.createElement( | |
'div', | |
{ style: this.prepareStyles(styles.root) }, | |
_react2.default.createElement('div', { style: this.prepareStyles(styles.mark) }) | |
); | |
} | |
}); | |
exports.default = ClockPointer; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 206 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactDom = __webpack_require__(62); | |
var _reactDom2 = _interopRequireDefault(_reactDom); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _clockNumber = __webpack_require__(204); | |
var _clockNumber2 = _interopRequireDefault(_clockNumber); | |
var _clockPointer = __webpack_require__(205); | |
var _clockPointer2 = _interopRequireDefault(_clockPointer); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function rad2deg(rad) { | |
return rad * 57.29577951308232; | |
} | |
function getTouchEventOffsetValues(e) { | |
var el = e.target; | |
var boundingRect = el.getBoundingClientRect(); | |
var offset = { | |
offsetX: e.clientX - boundingRect.left, | |
offsetY: e.clientY - boundingRect.top | |
}; | |
return offset; | |
} | |
var ClockMinutes = _react2.default.createClass({ | |
displayName: 'ClockMinutes', | |
propTypes: { | |
initialMinutes: _react2.default.PropTypes.number, | |
onChange: _react2.default.PropTypes.func | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
initialMinutes: new Date().getMinutes(), | |
onChange: function onChange() {} | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentDidMount: function componentDidMount() { | |
var clockElement = _reactDom2.default.findDOMNode(this.refs.mask); | |
this.center = { | |
x: clockElement.offsetWidth / 2, | |
y: clockElement.offsetHeight / 2 | |
}; | |
this.basePoint = { | |
x: this.center.x, | |
y: 0 | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
center: { x: 0, y: 0 }, | |
basePoint: { x: 0, y: 0 }, | |
isMousePressed: function isMousePressed(e) { | |
if (typeof e.buttons === 'undefined') { | |
return e.nativeEvent.which; | |
} | |
return e.buttons; | |
}, | |
handleUp: function handleUp(e) { | |
e.preventDefault(); | |
this.setClock(e.nativeEvent, true); | |
}, | |
handleMove: function handleMove(e) { | |
e.preventDefault(); | |
if (this.isMousePressed(e) !== 1) return; | |
this.setClock(e.nativeEvent, false); | |
}, | |
handleTouch: function handleTouch(e) { | |
e.preventDefault(); | |
this.setClock(e.changedTouches[0], false); | |
}, | |
setClock: function setClock(e, finish) { | |
if (typeof e.offsetX === 'undefined') { | |
var offset = getTouchEventOffsetValues(e); | |
e.offsetX = offset.offsetX; | |
e.offsetY = offset.offsetY; | |
} | |
var minutes = this.getMinutes(e.offsetX, e.offsetY); | |
this.props.onChange(minutes, finish); | |
}, | |
getMinutes: function getMinutes(offsetX, offsetY) { | |
var step = 6; | |
var x = offsetX - this.center.x; | |
var y = offsetY - this.center.y; | |
var cx = this.basePoint.x - this.center.x; | |
var cy = this.basePoint.y - this.center.y; | |
var atan = Math.atan2(cx, cy) - Math.atan2(x, y); | |
var deg = rad2deg(atan); | |
deg = Math.round(deg / step) * step; | |
deg %= 360; | |
var value = Math.floor(deg / step) || 0; | |
return value; | |
}, | |
_getMinuteNumbers: function _getMinuteNumbers() { | |
var minutes = []; | |
for (var i = 0; i < 12; i++) { | |
minutes.push(i * 5); | |
} | |
var selectedMinutes = this.props.initialMinutes; | |
var hasSelected = false; | |
var numbers = minutes.map(function (minute) { | |
var isSelected = selectedMinutes === minute; | |
if (isSelected) hasSelected = true; | |
return _react2.default.createElement(_clockNumber2.default, { | |
key: minute, isSelected: isSelected, type: 'minute', | |
value: minute | |
}); | |
}); | |
return { | |
numbers: numbers, | |
hasSelected: hasSelected, | |
selected: selectedMinutes | |
}; | |
}, | |
render: function render() { | |
var styles = { | |
root: { | |
height: '100%', | |
width: '100%', | |
borderRadius: '100%', | |
position: 'relative', | |
pointerEvents: 'none', | |
boxSizing: 'border-box' | |
}, | |
hitMask: { | |
height: '100%', | |
width: '100%', | |
pointerEvents: 'auto' | |
} | |
}; | |
var minutes = this._getMinuteNumbers(); | |
return _react2.default.createElement( | |
'div', | |
{ ref: 'clock', style: this.prepareStyles(styles.root) }, | |
_react2.default.createElement(_clockPointer2.default, { value: minutes.selected, type: 'minute' }), | |
minutes.numbers, | |
_react2.default.createElement('div', { ref: 'mask', style: this.prepareStyles(styles.hitMask), hasSelected: minutes.hasSelected, | |
onTouchMove: this.handleTouch, onTouchEnd: this.handleTouch, | |
onMouseUp: this.handleUp, onMouseMove: this.handleMove | |
}) | |
); | |
} | |
}); | |
exports.default = ClockMinutes; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 207 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactDom = __webpack_require__(62); | |
var _reactDom2 = _interopRequireDefault(_reactDom); | |
var _windowListenable = __webpack_require__(32); | |
var _windowListenable2 = _interopRequireDefault(_windowListenable); | |
var _keyCode = __webpack_require__(35); | |
var _keyCode2 = _interopRequireDefault(_keyCode); | |
var _transitions = __webpack_require__(208); | |
var _transitions2 = _interopRequireDefault(_transitions); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _flatButton = __webpack_require__(209); | |
var _flatButton2 = _interopRequireDefault(_flatButton); | |
var _overlay = __webpack_require__(241); | |
var _overlay2 = _interopRequireDefault(_overlay); | |
var _renderToLayer = __webpack_require__(242); | |
var _renderToLayer2 = _interopRequireDefault(_renderToLayer); | |
var _paper = __webpack_require__(243); | |
var _paper2 = _interopRequireDefault(_paper); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
var _warning = __webpack_require__(26); | |
var _warning2 = _interopRequireDefault(_warning); | |
var _deprecatedPropType = __webpack_require__(245); | |
var _deprecatedPropType2 = _interopRequireDefault(_deprecatedPropType); | |
var _reactAddonsTransitionGroup = __webpack_require__(222); | |
var _reactAddonsTransitionGroup2 = _interopRequireDefault(_reactAddonsTransitionGroup); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var TransitionItem = _react2.default.createClass({ | |
displayName: 'TransitionItem', | |
propTypes: { | |
children: _react2.default.PropTypes.node, | |
style: _react2.default.PropTypes.object | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_stylePropable2.default], | |
getInitialState: function getInitialState() { | |
return { | |
style: {}, | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
componentWillEnter: function componentWillEnter(callback) { | |
this.componentWillAppear(callback); | |
}, | |
componentWillAppear: function componentWillAppear(callback) { | |
var spacing = this.state.muiTheme.rawTheme.spacing; | |
this.setState({ | |
style: { | |
opacity: 1, | |
transform: 'translate3d(0, ' + spacing.desktopKeylineIncrement + 'px, 0)' | |
} | |
}); | |
setTimeout(callback, 450); // matches transition duration | |
}, | |
componentWillLeave: function componentWillLeave(callback) { | |
var _this = this; | |
this.setState({ | |
style: { | |
opacity: 0, | |
transform: 'translate3d(0, 0, 0)' | |
} | |
}); | |
setTimeout(function () { | |
if (_this.isMounted()) callback(); | |
}, 450); // matches transition duration | |
}, | |
render: function render() { | |
var _props = this.props; | |
var style = _props.style; | |
var children = _props.children; | |
var other = _objectWithoutProperties(_props, ['style', 'children']); | |
return _react2.default.createElement( | |
'div', | |
_extends({}, other, { style: this.prepareStyles(this.state.style, style) }), | |
children | |
); | |
} | |
}); | |
var DialogInline = _react2.default.createClass({ | |
displayName: 'DialogInline', | |
propTypes: { | |
actionFocus: _react2.default.PropTypes.string, | |
actions: _react2.default.PropTypes.node, | |
actionsContainerClassName: _react2.default.PropTypes.string, | |
actionsContainerStyle: _react2.default.PropTypes.object, | |
autoDetectWindowHeight: _react2.default.PropTypes.bool, | |
autoScrollBodyContent: _react2.default.PropTypes.bool, | |
bodyClassName: _react2.default.PropTypes.string, | |
bodyStyle: _react2.default.PropTypes.object, | |
children: _react2.default.PropTypes.node, | |
className: _react2.default.PropTypes.string, | |
contentClassName: _react2.default.PropTypes.string, | |
contentStyle: _react2.default.PropTypes.object, | |
modal: _react2.default.PropTypes.bool, | |
onRequestClose: _react2.default.PropTypes.func, | |
open: _react2.default.PropTypes.bool.isRequired, | |
overlayClassName: _react2.default.PropTypes.string, | |
overlayStyle: _react2.default.PropTypes.object, | |
repositionOnUpdate: _react2.default.PropTypes.bool, | |
style: _react2.default.PropTypes.object, | |
title: _react2.default.PropTypes.node, | |
titleClassName: _react2.default.PropTypes.string, | |
titleStyle: _react2.default.PropTypes.object, | |
width: _react2.default.PropTypes.any | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_windowListenable2.default, _stylePropable2.default], | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentDidMount: function componentDidMount() { | |
this._positionDialog(); | |
}, | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
componentDidUpdate: function componentDidUpdate() { | |
this._positionDialog(); | |
}, | |
windowListeners: { | |
keyup: '_handleWindowKeyUp', | |
resize: '_handleResize' | |
}, | |
getStyles: function getStyles() { | |
var _props2 = this.props; | |
var autoScrollBodyContent = _props2.autoScrollBodyContent; | |
var open = _props2.open; | |
var width = _props2.width; | |
var muiTheme = this.state.muiTheme; | |
var rawTheme = muiTheme.rawTheme; | |
var spacing = rawTheme.spacing; | |
var gutter = spacing.desktopGutter; | |
return { | |
root: { | |
position: 'fixed', | |
boxSizing: 'border-box', | |
WebkitTapHighlightColor: 'rgba(0,0,0,0)', | |
zIndex: muiTheme.zIndex.dialog, | |
top: 0, | |
left: open ? 0 : -10000, | |
width: '100%', | |
height: '100%', | |
transition: open ? _transitions2.default.easeOut('0ms', 'left', '0ms') : _transitions2.default.easeOut('0ms', 'left', '450ms') | |
}, | |
content: { | |
boxSizing: 'border-box', | |
WebkitTapHighlightColor: 'rgba(0,0,0,0)', | |
transition: _transitions2.default.easeOut(), | |
position: 'relative', | |
width: width || '75%', | |
maxWidth: spacing.desktopKeylineIncrement * 12, | |
margin: '0 auto', | |
zIndex: muiTheme.zIndex.dialog | |
}, | |
body: { | |
padding: spacing.desktopGutter, | |
overflowY: autoScrollBodyContent ? 'auto' : 'hidden', | |
overflowX: 'hidden' | |
}, | |
actionsContainer: { | |
boxSizing: 'border-box', | |
WebkitTapHighlightColor: 'rgba(0,0,0,0)', | |
padding: 8, | |
marginBottom: 8, | |
width: '100%', | |
textAlign: 'right' | |
}, | |
paper: { | |
background: rawTheme.palette.canvasColor | |
}, | |
overlay: { | |
zIndex: muiTheme.zIndex.dialogOverlay | |
}, | |
title: { | |
margin: 0, | |
padding: gutter + 'px ' + gutter + 'px 0 ' + gutter + 'px', | |
color: rawTheme.palette.textColor, | |
fontSize: 24, | |
lineHeight: '32px', | |
fontWeight: 400 | |
} | |
}; | |
}, | |
_getAction: function _getAction(actionJSON) { | |
var _this2 = this; | |
process.env.NODE_ENV !== "production" ? (0, _warning2.default)(false, 'using actionsJSON is deprecated on Dialog, please provide an array of | |
buttons, or any other components instead. For more information please refer to documentations.') : undefined; | |
var props = { | |
secondary: true, | |
onClick: actionJSON.onClick, | |
onTouchTap: function onTouchTap() { | |
if (actionJSON.onTouchTap) { | |
actionJSON.onTouchTap.call(undefined); | |
} | |
if (!(actionJSON.onClick || actionJSON.onTouchTap)) { | |
_this2._requestClose(true); | |
} | |
}, | |
label: actionJSON.text, | |
style: { | |
marginRight: 8 | |
} | |
}; | |
if (actionJSON.ref) { | |
props.ref = actionJSON.ref; | |
props.keyboardFocused = actionJSON.ref === this.props.actionFocus; | |
} | |
if (actionJSON.id) { | |
props.id = actionJSON.id; | |
} | |
return _react2.default.createElement(_flatButton2.default, props); | |
}, | |
_getActionObjects: function _getActionObjects(actions) { | |
var _this3 = this; | |
var actionObjects = []; | |
// ------- Replace this selction with: | |
// | |
// React.Children.forEach(actions, action => { | |
// if (React.isValidElement(action)) { | |
// actionObjects.push(action); | |
// } | |
// }); | |
// | |
// Also the return element will not need a call to React.Children.toArray | |
// | |
// for the 0.15.0 release | |
if (actions) { | |
if (_react2.default.isValidElement(actions)) { | |
actionObjects.push(actions); | |
} else { | |
actions.forEach(function (action) { | |
if (action) { | |
if (!_react2.default.isValidElement(action)) { | |
action = _this3._getAction(action); | |
} | |
actionObjects.push(action); | |
} | |
}); | |
} | |
} | |
// ------- End of section | |
return actionObjects; | |
}, | |
_getActionsContainer: function _getActionsContainer(actions, styles, className) { | |
var actionObjects = this._getActionObjects(actions); | |
return actionObjects.length > 0 && _react2.default.createElement( | |
'div', | |
{ className: className, style: this.prepareStyles(styles) }, | |
_react2.default.Children.toArray(actionObjects) | |
); | |
}, | |
_positionDialog: function _positionDialog() { | |
var _props3 = this.props; | |
var actions = _props3.actions; | |
var autoDetectWindowHeight = _props3.autoDetectWindowHeight; | |
var autoScrollBodyContent = _props3.autoScrollBodyContent; | |
var bodyStyle = _props3.bodyStyle; | |
var open = _props3.open; | |
var repositionOnUpdate = _props3.repositionOnUpdate; | |
var title = _props3.title; | |
if (!open) { | |
return; | |
} | |
var clientHeight = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight; | |
var container = _reactDom2.default.findDOMNode(this); | |
var dialogWindow = _reactDom2.default.findDOMNode(this.refs.dialogWindow); | |
var dialogContent = _reactDom2.default.findDOMNode(this.refs.dialogContent); | |
var minPaddingTop = 16; | |
//Reset the height in case the window was resized. | |
dialogWindow.style.height = ''; | |
dialogContent.style.height = ''; | |
var dialogWindowHeight = dialogWindow.offsetHeight; | |
var paddingTop = (clientHeight - dialogWindowHeight) / 2 - 64; | |
if (paddingTop < minPaddingTop) paddingTop = minPaddingTop; | |
//Vertically center the dialog window, but make sure it doesn't | |
//transition to that position. | |
if (repositionOnUpdate || !container.style.paddingTop) { | |
container.style.paddingTop = paddingTop + 'px'; | |
} | |
// Force a height if the dialog is taller than clientHeight | |
if (autoDetectWindowHeight || autoScrollBodyContent) { | |
var styles = this.getStyles(); | |
styles.body = this.mergeStyles(styles.body, bodyStyle); | |
var maxDialogContentHeight = clientHeight - 2 * (styles.body.padding + 64); | |
if (title) maxDialogContentHeight -= dialogContent.previousSibling.offsetHeight; | |
var hasActions = this._getActionObjects(actions).length > 0; | |
if (hasActions) maxDialogContentHeight -= dialogContent.nextSibling.offsetHeight; | |
dialogContent.style.maxHeight = maxDialogContentHeight + 'px'; | |
} | |
}, | |
_requestClose: function _requestClose(buttonClicked) { | |
if (!buttonClicked && this.props.modal) { | |
return; | |
} | |
if (this.props.onRequestClose) { | |
this.props.onRequestClose(!!buttonClicked); | |
} | |
}, | |
_handleOverlayTouchTap: function _handleOverlayTouchTap() { | |
this._requestClose(false); | |
}, | |
_handleWindowKeyUp: function _handleWindowKeyUp(event) { | |
if (event.keyCode === _keyCode2.default.ESC) { | |
this._requestClose(false); | |
} | |
}, | |
_handleResize: function _handleResize() { | |
if (this.props.open) { | |
this._positionDialog(); | |
} | |
}, | |
render: function render() { | |
var _props4 = this.props; | |
var actions = _props4.actions; | |
var actionsContainerClassName = _props4.actionsContainerClassName; | |
var actionsContainerStyle = _props4.actionsContainerStyle; | |
var bodyClassName = _props4.bodyClassName; | |
var bodyStyle = _props4.bodyStyle; | |
var children = _props4.children; | |
var className = _props4.className; | |
var contentClassName = _props4.contentClassName; | |
var contentStyle = _props4.contentStyle; | |
var overlayClassName = _props4.overlayClassName; | |
var overlayStyle = _props4.overlayStyle; | |
var open = _props4.open; | |
var titleClassName = _props4.titleClassName; | |
var titleStyle = _props4.titleStyle; | |
var title = _props4.title; | |
var style = _props4.style; | |
var styles = this.getStyles(); | |
styles.root = this.mergeStyles(styles.root, style); | |
styles.content = this.mergeStyles(styles.content, contentStyle); | |
styles.body = this.mergeStyles(styles.body, bodyStyle); | |
styles.actionsContainer = this.mergeStyles(styles.actionsContainer, actionsContainerStyle); | |
styles.overlay = this.mergeStyles(styles.overlay, overlayStyle); | |
styles.title = this.mergeStyles(styles.title, titleStyle); | |
var actionsContainer = this._getActionsContainer(actions, styles.actionsContainer, actionsContainerClassName); | |
var titleElement = typeof title === 'string' ? _react2.default.createElement( | |
'h3', | |
{ className: titleClassName, style: this.prepareStyles(styles.title) }, | |
title | |
) : title; | |
return _react2.default.createElement( | |
'div', | |
{ className: className, style: this.prepareStyles(styles.root) }, | |
_react2.default.createElement( | |
_reactAddonsTransitionGroup2.default, | |
{ | |
component: 'div', ref: 'dialogWindow', | |
transitionAppear: true, transitionAppearTimeout: 450, | |
transitionEnter: true, transitionEnterTimeout: 450 | |
}, | |
open && _react2.default.createElement( | |
TransitionItem, | |
{ | |
className: contentClassName, | |
style: styles.content | |
}, | |
_react2.default.createElement( | |
_paper2.default, | |
{ | |
style: styles.paper, | |
zDepth: 4 | |
}, | |
titleElement, | |
_react2.default.createElement( | |
'div', | |
{ | |
ref: 'dialogContent', | |
className: bodyClassName, | |
style: this.prepareStyles(styles.body) | |
}, | |
children | |
), | |
actionsContainer | |
) | |
) | |
), | |
_react2.default.createElement(_overlay2.default, { | |
show: open, | |
className: overlayClassName, | |
style: styles.overlay, | |
onTouchTap: this._handleOverlayTouchTap | |
}) | |
); | |
} | |
}); | |
var Dialog = _react2.default.createClass({ | |
displayName: 'Dialog', | |
propTypes: { | |
/** | |
* The `ref` of the action to focus on when the `Dialog` is displayed. | |
*/ | |
actionFocus: (0, _deprecatedPropType2.default)(_react2.default.PropTypes.string, 'Instead, use a custom `actions` property.'), | |
/** | |
* This prop can be either a JSON object containing the actions to render (This is **DEPRECATED**), | |
* a react elements, or an array of react elements. | |
*/ | |
actions: _react2.default.PropTypes.node, | |
/** | |
* The `className` to add to the actions container's root element. | |
*/ | |
actionsContainerClassName: _react2.default.PropTypes.string, | |
/** | |
* Overrides the inline-styles of the actions container's root element. | |
*/ | |
actionsContainerStyle: _react2.default.PropTypes.object, | |
/** | |
* If set to true, the height of the `Dialog` will be auto detected. A max height | |
* will be enforced so that the content does not extend beyond the viewport. | |
*/ | |
autoDetectWindowHeight: _react2.default.PropTypes.bool, | |
/** | |
* If set to true, the body content of the `Dialog` will be scrollable. | |
*/ | |
autoScrollBodyContent: _react2.default.PropTypes.bool, | |
/** | |
* The `className` to add to the content's root element under the title. | |
*/ | |
bodyClassName: _react2.default.PropTypes.string, | |
/** | |
* Overrides the inline-styles of the content's root element under the title. | |
*/ | |
bodyStyle: _react2.default.PropTypes.object, | |
/** | |
* The contents of the `Dialog`. | |
*/ | |
children: _react2.default.PropTypes.node, | |
/** | |
* The css class name of the root element. | |
*/ | |
className: _react2.default.PropTypes.string, | |
/** | |
* The `className` to add to the content container. | |
*/ | |
contentClassName: _react2.default.PropTypes.string, | |
/** | |
* Overrides the inline-styles of the content container. | |
*/ | |
contentStyle: _react2.default.PropTypes.object, | |
/** | |
* Force the user to use one of the actions in the `Dialog`. | |
* Clicking outside the `Dialog` will not trigger the `onRequestClose`. | |
*/ | |
modal: _react2.default.PropTypes.bool, | |
/** | |
* Fired when the `Dialog` is requested to be closed by a click outside the `Dialog` or on the buttons. | |
* | |
* @param {bool} buttonClicked Determines whether a button click triggered this request. | |
*/ | |
onRequestClose: _react2.default.PropTypes.func, | |
/** | |
* Controls whether the Dialog is opened or not. | |
*/ | |
open: _react2.default.PropTypes.bool.isRequired, | |
/** | |
* The `className` to add to the `Overlay` component that is rendered behind the `Dialog`. | |
*/ | |
overlayClassName: _react2.default.PropTypes.string, | |
/** | |
* Overrides the inline-styles of the `Overlay` component that is rendered behind the `Dialog`. | |
*/ | |
overlayStyle: _react2.default.PropTypes.object, | |
/** | |
* Determines whether the `Dialog` should be repositioned when it's contents are updated. | |
*/ | |
repositionOnUpdate: _react2.default.PropTypes.bool, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object, | |
/** | |
* The title to display on the `Dialog`. Could be number, string, element or an array containing these types. | |
*/ | |
title: _react2.default.PropTypes.node, | |
/** | |
* The `className` to add to the title's root container element. | |
*/ | |
titleClassName: _react2.default.PropTypes.string, | |
/** | |
* Overrides the inline-styles of the title's root container element. | |
*/ | |
titleStyle: _react2.default.PropTypes.object, | |
/** | |
* Changes the width of the `Dialog`. | |
*/ | |
width: (0, _deprecatedPropType2.default)(_react2.default.PropTypes.any, 'Use the contentStyle.') | |
}, | |
getDefaultProps: function getDefaultProps() { | |
return { | |
autoDetectWindowHeight: true, | |
autoScrollBodyContent: false, | |
modal: false, | |
repositionOnUpdate: true | |
}; | |
}, | |
renderLayer: function renderLayer() { | |
return _react2.default.createElement(DialogInline, this.props); | |
}, | |
render: function render() { | |
return _react2.default.createElement(_renderToLayer2.default, { render: this.renderLayer, open: true, useLayerForClickAway: false }); | |
} | |
}); | |
exports.default = Dialog; | |
module.exports = exports['default']; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 208 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = { | |
easeOutFunction: 'cubic-bezier(0.23, 1, 0.32, 1)', | |
easeInOutFunction: 'cubic-bezier(0.445, 0.05, 0.55, 0.95)', | |
easeOut: function easeOut(duration, property, delay, easeFunction) { | |
easeFunction = easeFunction || this.easeOutFunction; | |
if (property && Object.prototype.toString.call(property) === '[object Array]') { | |
var transitions = ''; | |
for (var i = 0; i < property.length; i++) { | |
if (transitions) transitions += ','; | |
transitions += this.create(duration, property[i], delay, easeFunction); | |
} | |
return transitions; | |
} else { | |
return this.create(duration, property, delay, easeFunction); | |
} | |
}, | |
create: function create(duration, property, delay, easeFunction) { | |
duration = duration || '450ms'; | |
property = property || 'all'; | |
delay = delay || '0ms'; | |
easeFunction = easeFunction || 'linear'; | |
return property + ' ' + duration + ' ' + easeFunction + ' ' + delay; | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 209 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _contextPure = __webpack_require__(210); | |
var _contextPure2 = _interopRequireDefault(_contextPure); | |
var _transitions = __webpack_require__(208); | |
var _transitions2 = _interopRequireDefault(_transitions); | |
var _children = __webpack_require__(212); | |
var _children2 = _interopRequireDefault(_children); | |
var _colorManipulator = __webpack_require__(57); | |
var _colorManipulator2 = _interopRequireDefault(_colorManipulator); | |
var _styles = __webpack_require__(5); | |
var _typography = __webpack_require__(215); | |
var _typography2 = _interopRequireDefault(_typography); | |
var _enhancedButton = __webpack_require__(216); | |
var _enhancedButton2 = _interopRequireDefault(_enhancedButton); | |
var _flatButtonLabel = __webpack_require__(240); | |
var _flatButtonLabel2 = _interopRequireDefault(_flatButtonLabel); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
function validateLabel(props, propName, componentName) { | |
if (!props.children && !props.label) { | |
return new Error('Required prop label or children was not ' + 'specified in ' + componentName + '.'); | |
} | |
} | |
var FlatButton = _react2.default.createClass({ | |
displayName: 'FlatButton', | |
propTypes: { | |
/** | |
* Color of button when mouse is not hovering over it. | |
*/ | |
backgroundColor: _react2.default.PropTypes.string, | |
/** | |
* Elements passed into the button. For example, the font | |
* icon passed into the GitHub button. | |
*/ | |
children: _react2.default.PropTypes.node, | |
/** | |
* Disables the button if set to true. | |
*/ | |
disabled: _react2.default.PropTypes.bool, | |
/** | |
* Color of button when mouse hovers over. | |
*/ | |
hoverColor: _react2.default.PropTypes.string, | |
/** | |
* URL to link to when button clicked if `linkButton` is set to true. | |
*/ | |
href: _react2.default.PropTypes.string, | |
/** | |
* Use this property to display an icon. | |
*/ | |
icon: _react2.default.PropTypes.node, | |
/** | |
* Label for the button. | |
*/ | |
label: validateLabel, | |
/** | |
* Place label before or after the passed children. | |
*/ | |
labelPosition: _react2.default.PropTypes.oneOf(['before', 'after']), | |
/** | |
* Override the inline-styles of the button's label element. | |
*/ | |
labelStyle: _react2.default.PropTypes.object, | |
/** | |
* Enables use of `href` property to provide a URL to link to if set to true. | |
*/ | |
linkButton: _react2.default.PropTypes.bool, | |
/** | |
* Called when element is focused by the keyboard. | |
*/ | |
onKeyboardFocus: _react2.default.PropTypes.func, | |
/** | |
* Called when the mouse enters the element. | |
*/ | |
onMouseEnter: _react2.default.PropTypes.func, | |
/** | |
* Called when the mouse leaves the element. | |
*/ | |
onMouseLeave: _react2.default.PropTypes.func, | |
/** | |
* Called when a touch event is started inside the element. | |
*/ | |
onTouchStart: _react2.default.PropTypes.func, | |
/** | |
* If true, colors button according to | |
* primaryTextColor from the Theme. | |
*/ | |
primary: _react2.default.PropTypes.bool, | |
/** | |
* Color for the ripple after button is clicked. | |
*/ | |
rippleColor: _react2.default.PropTypes.string, | |
/** | |
* If true, colors button according to secondaryTextColor from the theme. | |
* The primary prop has precendent if set to true. | |
*/ | |
secondary: _react2.default.PropTypes.bool, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_contextPure2.default], | |
statics: { | |
getRelevantContextKeys: function getRelevantContextKeys(muiTheme) { | |
var buttonTheme = muiTheme.button; | |
var flatButtonTheme = muiTheme.flatButton; | |
return { | |
buttonColor: flatButtonTheme.color, | |
buttonFilterColor: flatButtonTheme.buttonFilterColor, | |
buttonHeight: buttonTheme.height, | |
buttonMinWidth: buttonTheme.minWidth, | |
disabledTextColor: flatButtonTheme.disabledTextColor, | |
primaryTextColor: flatButtonTheme.primaryTextColor, | |
secondaryTextColor: flatButtonTheme.secondaryTextColor, | |
textColor: flatButtonTheme.textColor, | |
textTransform: flatButtonTheme.textTransform ? flatButtonTheme.textTransform : buttonTheme.textTransform ? buttonTheme.textTransform : 'uppercase' | |
}; | |
}, | |
getChildrenClasses: function getChildrenClasses() { | |
return [_enhancedButton2.default, _flatButtonLabel2.default]; | |
} | |
}, | |
getDefaultProps: function getDefaultProps() { | |
return { | |
disabled: false, | |
labelStyle: {}, | |
// labelPosition Should be after but we keep it like for now (prevent breaking changes) | |
labelPosition: 'before', | |
onKeyboardFocus: function onKeyboardFocus() {}, | |
onMouseEnter: function onMouseEnter() {}, | |
onMouseLeave: function onMouseLeave() {}, | |
onTouchStart: function onTouchStart() {}, | |
primary: false, | |
secondary: false | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
hovered: false, | |
isKeyboardFocused: false, | |
touch: false, | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
}, | |
_handleKeyboardFocus: function _handleKeyboardFocus(e, isKeyboardFocused) { | |
this.setState({ isKeyboardFocused: isKeyboardFocused }); | |
this.props.onKeyboardFocus(e, isKeyboardFocused); | |
}, | |
_handleMouseEnter: function _handleMouseEnter(e) { | |
//Cancel hover styles for touch devices | |
if (!this.state.touch) this.setState({ hovered: true }); | |
this.props.onMouseEnter(e); | |
}, | |
_handleMouseLeave: function _handleMouseLeave(e) { | |
this.setState({ hovered: false }); | |
this.props.onMouseLeave(e); | |
}, | |
_handleTouchStart: function _handleTouchStart(e) { | |
this.setState({ touch: true }); | |
this.props.onTouchStart(e); | |
}, | |
render: function render() { | |
var _props = this.props; | |
var children = _props.children; | |
var disabled = _props.disabled; | |
var hoverColor = _props.hoverColor; | |
var backgroundColor = _props.backgroundColor; | |
var icon = _props.icon; | |
var label = _props.label; | |
var labelStyle = _props.labelStyle; | |
var labelPosition = _props.labelPosition; | |
var primary = _props.primary; | |
var rippleColor = _props.rippleColor; | |
var secondary = _props.secondary; | |
var style = _props.style; | |
var other = _objectWithoutProperties(_props, ['children', 'disabled', 'hoverColor', 'backgroundColor', 'icon', 'label', 'labelStyle', 'labelPosition', 'primary', 'rippleColor', 'secondary', 'style']); | |
var _constructor$getRelev = this.constructor.getRelevantContextKeys(this.state.muiTheme); | |
var buttonColor = _constructor$getRelev.buttonColor; | |
var buttonHeight = _constructor$getRelev.buttonHeight; | |
var buttonMinWidth = _constructor$getRelev.buttonMinWidth; | |
var disabledTextColor = _constructor$getRelev.disabledTextColor; | |
var buttonFilterColor = _constructor$getRelev.buttonFilterColor; | |
var primaryTextColor = _constructor$getRelev.primaryTextColor; | |
var secondaryTextColor = _constructor$getRelev.secondaryTextColor; | |
var textColor = _constructor$getRelev.textColor; | |
var textTransform = _constructor$getRelev.textTransform; | |
var defaultTextColor = disabled ? disabledTextColor : primary ? primaryTextColor : secondary ? secondaryTextColor : textColor; | |
var defaultHoverColor = _colorManipulator2.default.fade(buttonFilterColor, 0.2); | |
var defaultRippleColor = buttonFilterColor; | |
var buttonHoverColor = hoverColor || defaultHoverColor; | |
var buttonRippleColor = rippleColor || defaultRippleColor; | |
var buttonBackgroundColor = backgroundColor || buttonColor; | |
var hovered = (this.state.hovered || this.state.isKeyboardFocused) && !disabled; | |
var mergedRootStyles = (0, _styles.mergeStyles)({ | |
color: defaultTextColor, | |
transition: _transitions2.default.easeOut(), | |
fontSize: _typography2.default.fontStyleButtonFontSize, | |
letterSpacing: 0, | |
textTransform: textTransform, | |
fontWeight: _typography2.default.fontWeightMedium, | |
borderRadius: 2, | |
userSelect: 'none', | |
position: 'relative', | |
overflow: 'hidden', | |
backgroundColor: hovered ? buttonHoverColor : buttonBackgroundColor, | |
lineHeight: buttonHeight + 'px', | |
minWidth: buttonMinWidth, | |
padding: 0, | |
margin: 0, | |
//This is need so that ripples do not bleed past border radius. | |
//See: http://stackoverflow.com/questions/17298739 | |
transform: 'translate3d(0, 0, 0)' | |
}, style); | |
var iconCloned = undefined; | |
var labelStyleIcon = {}; | |
if (icon) { | |
iconCloned = _react2.default.cloneElement(icon, { | |
color: mergedRootStyles.color, | |
style: { | |
verticalAlign: 'middle', | |
marginLeft: labelPosition === 'before' ? 0 : 12, | |
marginRight: labelPosition === 'before' ? 12 : 0 | |
} | |
}); | |
if (labelPosition === 'before') { | |
labelStyleIcon.paddingRight = 8; | |
} else { | |
labelStyleIcon.paddingLeft = 8; | |
} | |
} | |
var labelElement = label ? _react2.default.createElement(_flatButtonLabel2.default, { label: label, style: (0, _styles.mergeStyles)(labelStyle, labelStyleIcon) }) : undefined; | |
// Place label before or after children. | |
var childrenFragment = labelPosition === 'before' ? { | |
labelElement: labelElement, | |
iconCloned: iconCloned, | |
children: children | |
} : { | |
children: children, | |
iconCloned: iconCloned, | |
labelElement: labelElement | |
}; | |
var enhancedButtonChildren = _children2.default.create(childrenFragment); | |
return _react2.default.createElement( | |
_enhancedButton2.default, | |
_extends({}, other, { | |
disabled: disabled, | |
focusRippleColor: buttonRippleColor, | |
focusRippleOpacity: 0.3, | |
onKeyboardFocus: this._handleKeyboardFocus, | |
onMouseLeave: this._handleMouseLeave, | |
onMouseEnter: this._handleMouseEnter, | |
onTouchStart: this._handleTouchStart, | |
style: mergedRootStyles, | |
touchRippleColor: buttonRippleColor, | |
touchRippleOpacity: 0.3 | |
}), | |
enhancedButtonChildren | |
); | |
} | |
}); | |
exports.default = FlatButton; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 210 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _shallowEqual = __webpack_require__(211); | |
var _shallowEqual2 = _interopRequireDefault(_shallowEqual); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function relevantContextKeysEqual(classObject, currentContext, nextContext) { | |
//Get those keys from current object's context that we care | |
//about and check whether those keys have changed or not | |
if (classObject.getRelevantContextKeys) { | |
var currentContextKeys = classObject.getRelevantContextKeys(currentContext); | |
var nextContextKeys = classObject.getRelevantContextKeys(nextContext); | |
if (!(0, _shallowEqual2.default)(currentContextKeys, nextContextKeys)) { | |
return false; | |
} | |
} | |
//Check if children context keys changed | |
if (classObject.getChildrenClasses) { | |
var childrenArray = classObject.getChildrenClasses(); | |
for (var i = 0; i < childrenArray.length; i++) { | |
if (!relevantContextKeysEqual(childrenArray[i], currentContext, nextContext)) { | |
return false; | |
} | |
} | |
} | |
//context keys are equal | |
return true; | |
} | |
exports.default = { | |
//Don't update if state, prop, and context are equal | |
shouldComponentUpdate: function shouldComponentUpdate(nextProps, nextState, nextContext) { | |
//If either the props or state have changed, component should update | |
if (!(0, _shallowEqual2.default)(this.props, nextProps) || !(0, _shallowEqual2.default)(this.state, nextState)) { | |
return true; | |
} | |
//If current theme and next theme are both undefined, do not update | |
if (!this.context.muiTheme && !nextContext.muiTheme) { | |
return false; | |
} | |
//If both themes exist, compare keys only if current theme is not static | |
if (this.context.muiTheme && nextContext.muiTheme) { | |
return !this.context.muiTheme.static && !relevantContextKeysEqual(this.constructor, this.context.muiTheme, nextContext.muiTheme); | |
} | |
//At this point it is guaranteed that exactly one theme is undefined so simply update | |
return true; | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 211 */ | |
/***/ function(module, exports) { | |
'use strict'; | |
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol ? "symbol" : typeof obj; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
exports.default = shallowEqual; | |
function shallowEqual(objA, objB) { | |
if (objA === objB) { | |
return true; | |
} | |
if ((typeof objA === 'undefined' ? 'undefined' : _typeof(objA)) !== 'object' || objA === null || (typeof objB === 'undefined' ? 'undefined' : _typeof(objB)) !== 'object' || objB === null) { | |
return false; | |
} | |
var keysA = Object.keys(objA); | |
var keysB = Object.keys(objB); | |
if (keysA.length !== keysB.length) { | |
return false; | |
} | |
// Test for A's keys different from B. | |
var bHasOwnProperty = Object.prototype.hasOwnProperty.bind(objB); | |
for (var i = 0; i < keysA.length; i++) { | |
if (!bHasOwnProperty(keysA[i]) || objA[keysA[i]] !== objB[keysA[i]]) { | |
return false; | |
} | |
} | |
return true; | |
} | |
module.exports = exports['default']; | |
/***/ }, | |
/* 212 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactAddonsCreateFragment = __webpack_require__(213); | |
var _reactAddonsCreateFragment2 = _interopRequireDefault(_reactAddonsCreateFragment); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
exports.default = { | |
create: function create(fragments) { | |
var newFragments = {}; | |
var validChildrenCount = 0; | |
var firstKey = undefined; | |
//Only create non-empty key fragments | |
for (var key in fragments) { | |
var currentChild = fragments[key]; | |
if (currentChild) { | |
if (validChildrenCount === 0) firstKey = key; | |
newFragments[key] = currentChild; | |
validChildrenCount++; | |
} | |
} | |
if (validChildrenCount === 0) return undefined; | |
if (validChildrenCount === 1) return newFragments[firstKey]; | |
return (0, _reactAddonsCreateFragment2.default)(newFragments); | |
}, | |
extend: function extend(children, extendedProps, extendedChildren) { | |
return _react2.default.isValidElement(children) ? _react2.default.Children.map(children, function (child) { | |
var newProps = typeof extendedProps === 'function' ? extendedProps(child) : extendedProps; | |
var newChildren = typeof extendedChildren === 'function' ? extendedChildren(child) : extendedChildren ? extendedChildren : child.props.children; | |
return _react2.default.cloneElement(child, newProps, newChildren); | |
}) : children; | |
} | |
}; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 213 */ | |
/***/ function(module, exports, __webpack_require__) { | |
module.exports = __webpack_require__(214).create; | |
/***/ }, | |
/* 214 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/* WEBPACK VAR INJECTION */(function(process) {/** | |
* Copyright 2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactFragment | |
*/ | |
'use strict'; | |
var ReactChildren = __webpack_require__(166); | |
var ReactElement = __webpack_require__(99); | |
var emptyFunction = __webpack_require__(73); | |
var invariant = __webpack_require__(31); | |
var warning = __webpack_require__(83); | |
/** | |
* We used to allow keyed objects to serve as a collection of ReactElements, | |
* or nested sets. This allowed us a way to explicitly key a set a fragment of | |
* components. This is now being replaced with an opaque data structure. | |
* The upgrade path is to call React.addons.createFragment({ key: value }) to | |
* create a keyed fragment. The resulting data structure is an array. | |
*/ | |
var numericPropertyRegex = /^\d+$/; | |
var warnedAboutNumeric = false; | |
var ReactFragment = { | |
// Wrap a keyed object in an opaque proxy that warns you if you access any | |
// of its properties. | |
create: function (object) { | |
if (typeof object !== 'object' || !object || Array.isArray(object)) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'React.addons.createFragment only accepts a single object. Got: %s', object) : undefined; | |
return object; | |
} | |
if (ReactElement.isValidElement(object)) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'React.addons.createFragment does not accept a ReactElement ' + 'without a wrapper object.') : undefined; | |
return object; | |
} | |
!(object.nodeType !== 1) ? process.env.NODE_ENV !== 'production' ? invariant(false, 'React.addons.createFragment(...): Encountered an invalid child; DOM ' + 'elements are not valid children of React components.') : invariant(false) : undefined; | |
var result = []; | |
for (var key in object) { | |
if (process.env.NODE_ENV !== 'production') { | |
if (!warnedAboutNumeric && numericPropertyRegex.test(key)) { | |
process.env.NODE_ENV !== 'production' ? warning(false, 'React.addons.createFragment(...): Child objects should have ' + 'non-numeric keys so ordering is preserved.') : undefined; | |
warnedAboutNumeric = true; | |
} | |
} | |
ReactChildren.mapIntoWithKeyPrefixInternal(object[key], result, key, emptyFunction.thatReturnsArgument); | |
} | |
return result; | |
} | |
}; | |
module.exports = ReactFragment; | |
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(6))) | |
/***/ }, | |
/* 215 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _colors = __webpack_require__(56); | |
var _colors2 = _interopRequireDefault(_colors); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } | |
var Typography = function Typography() { | |
_classCallCheck(this, Typography); | |
// text colors | |
this.textFullBlack = _colors2.default.fullBlack; | |
this.textDarkBlack = _colors2.default.darkBlack; | |
this.textLightBlack = _colors2.default.lightBlack; | |
this.textMinBlack = _colors2.default.minBlack; | |
this.textFullWhite = _colors2.default.fullWhite; | |
this.textDarkWhite = _colors2.default.darkWhite; | |
this.textLightWhite = _colors2.default.lightWhite; | |
// font weight | |
this.fontWeightLight = 300; | |
this.fontWeightNormal = 400; | |
this.fontWeightMedium = 500; | |
this.fontStyleButtonFontSize = 14; | |
}; | |
exports.default = new Typography(); | |
module.exports = exports['default']; | |
/***/ }, | |
/* 216 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactAddonsPureRenderMixin = __webpack_require__(217); | |
var _reactAddonsPureRenderMixin2 = _interopRequireDefault(_reactAddonsPureRenderMixin); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _colors = __webpack_require__(56); | |
var _colors2 = _interopRequireDefault(_colors); | |
var _children = __webpack_require__(212); | |
var _children2 = _interopRequireDefault(_children); | |
var _events = __webpack_require__(33); | |
var _events2 = _interopRequireDefault(_events); | |
var _keyCode = __webpack_require__(35); | |
var _keyCode2 = _interopRequireDefault(_keyCode); | |
var _focusRipple = __webpack_require__(220); | |
var _focusRipple2 = _interopRequireDefault(_focusRipple); | |
var _touchRipple = __webpack_require__(237); | |
var _touchRipple2 = _interopRequireDefault(_touchRipple); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var styleInjected = false; | |
var listening = false; | |
var tabPressed = false; | |
function injectStyle() { | |
if (!styleInjected) { | |
// Remove inner padding and border in Firefox 4+. | |
var style = document.createElement('style'); | |
style.innerHTML = ' | |
button::-moz-focus-inner, | |
input::-moz-focus-inner { | |
border: 0; | |
padding: 0; | |
} | |
'; | |
document.body.appendChild(style); | |
styleInjected = true; | |
} | |
} | |
function listenForTabPresses() { | |
if (!listening) { | |
_events2.default.on(window, 'keydown', function (e) { | |
tabPressed = e.keyCode === _keyCode2.default.TAB; | |
}); | |
listening = true; | |
} | |
} | |
var EnhancedButton = _react2.default.createClass({ | |
displayName: 'EnhancedButton', | |
propTypes: { | |
centerRipple: _react2.default.PropTypes.bool, | |
children: _react2.default.PropTypes.node, | |
containerElement: _react2.default.PropTypes.oneOfType([_react2.default.PropTypes.string, _react2.default.PropTypes.element]), | |
disableFocusRipple: _react2.default.PropTypes.bool, | |
disableKeyboardFocus: _react2.default.PropTypes.bool, | |
disableTouchRipple: _react2.default.PropTypes.bool, | |
disabled: _react2.default.PropTypes.bool, | |
focusRippleColor: _react2.default.PropTypes.string, | |
focusRippleOpacity: _react2.default.PropTypes.number, | |
keyboardFocused: _react2.default.PropTypes.bool, | |
linkButton: _react2.default.PropTypes.bool, | |
onBlur: _react2.default.PropTypes.func, | |
onFocus: _react2.default.PropTypes.func, | |
onKeyDown: _react2.default.PropTypes.func, | |
onKeyUp: _react2.default.PropTypes.func, | |
onKeyboardFocus: _react2.default.PropTypes.func, | |
onTouchTap: _react2.default.PropTypes.func, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object, | |
tabIndex: _react2.default.PropTypes.number, | |
touchRippleColor: _react2.default.PropTypes.string, | |
touchRippleOpacity: _react2.default.PropTypes.number, | |
type: _react2.default.PropTypes.string | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_reactAddonsPureRenderMixin2.default, _stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
containerElement: 'button', | |
onBlur: function onBlur() {}, | |
onFocus: function onFocus() {}, | |
onKeyboardFocus: function onKeyboardFocus() {}, | |
onKeyDown: function onKeyDown() {}, | |
onKeyUp: function onKeyUp() {}, | |
onTouchTap: function onTouchTap() {}, | |
tabIndex: 0, | |
type: 'button' | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
isKeyboardFocused: !this.props.disabled && this.props.keyboardFocused && !this.props.disableKeyboardFocus, | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
componentDidMount: function componentDidMount() { | |
injectStyle(); | |
listenForTabPresses(); | |
}, | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: newMuiTheme }); | |
if ((nextProps.disabled || nextProps.disableKeyboardFocus) && this.state.isKeyboardFocused) { | |
this.setState({ isKeyboardFocused: false }); | |
if (nextProps.onKeyboardFocus) { | |
nextProps.onKeyboardFocus(null, false); | |
} | |
} | |
}, | |
isKeyboardFocused: function isKeyboardFocused() { | |
return this.state.isKeyboardFocused; | |
}, | |
removeKeyboardFocus: function removeKeyboardFocus(e) { | |
if (this.state.isKeyboardFocused) { | |
this.setState({ isKeyboardFocused: false }); | |
this.props.onKeyboardFocus(e, false); | |
} | |
}, | |
setKeyboardFocus: function setKeyboardFocus(e) { | |
if (!this.state.isKeyboardFocused) { | |
this.setState({ isKeyboardFocused: true }); | |
this.props.onKeyboardFocus(e, true); | |
} | |
}, | |
_cancelFocusTimeout: function _cancelFocusTimeout() { | |
if (this._focusTimeout) { | |
clearTimeout(this._focusTimeout); | |
this._focusTimeout = null; | |
} | |
}, | |
_createButtonChildren: function _createButtonChildren() { | |
var _props = this.props; | |
var centerRipple = _props.centerRipple; | |
var children = _props.children; | |
var disabled = _props.disabled; | |
var disableFocusRipple = _props.disableFocusRipple; | |
var disableKeyboardFocus = _props.disableKeyboardFocus; | |
var disableTouchRipple = _props.disableTouchRipple; | |
var focusRippleColor = _props.focusRippleColor; | |
var focusRippleOpacity = _props.focusRippleOpacity; | |
var touchRippleColor = _props.touchRippleColor; | |
var touchRippleOpacity = _props.touchRippleOpacity; | |
var isKeyboardFocused = this.state.isKeyboardFocused; | |
//Focus Ripple | |
var focusRipple = isKeyboardFocused && !disabled && !disableFocusRipple && !disableKeyboardFocus ? _react2.default.createElement(_focusRipple2.default, { | |
color: focusRippleColor, | |
muiTheme: this.state.muiTheme, | |
opacity: focusRippleOpacity, | |
show: isKeyboardFocused | |
}) : undefined; | |
//Touch Ripple | |
var touchRipple = !disabled && !disableTouchRipple ? _react2.default.createElement( | |
_touchRipple2.default, | |
{ | |
centerRipple: centerRipple, | |
color: touchRippleColor, | |
muiTheme: this.state.muiTheme, | |
opacity: touchRippleOpacity | |
}, | |
children | |
) : undefined; | |
return _children2.default.create({ | |
focusRipple: focusRipple, | |
touchRipple: touchRipple, | |
children: touchRipple ? undefined : children | |
}); | |
}, | |
_handleKeyDown: function _handleKeyDown(e) { | |
if (!this.props.disabled && !this.props.disableKeyboardFocus) { | |
if (e.keyCode === _keyCode2.default.ENTER && this.state.isKeyboardFocused) { | |
this._handleTouchTap(e); | |
} | |
} | |
this.props.onKeyDown(e); | |
}, | |
_handleKeyUp: function _handleKeyUp(e) { | |
if (!this.props.disabled && !this.props.disableKeyboardFocus) { | |
if (e.keyCode === _keyCode2.default.SPACE && this.state.isKeyboardFocused) { | |
this._handleTouchTap(e); | |
} | |
} | |
this.props.onKeyUp(e); | |
}, | |
_handleBlur: function _handleBlur(e) { | |
this._cancelFocusTimeout(); | |
this.removeKeyboardFocus(e); | |
this.props.onBlur(e); | |
}, | |
_handleFocus: function _handleFocus(e) { | |
var _this = this; | |
if (!this.props.disabled && !this.props.disableKeyboardFocus) { | |
//setTimeout is needed because the focus event fires first | |
//Wait so that we can capture if this was a keyboard focus | |
//or touch focus | |
this._focusTimeout = setTimeout(function () { | |
if (tabPressed) { | |
_this.setKeyboardFocus(e); | |
} | |
}, 150); | |
this.props.onFocus(e); | |
} | |
}, | |
_handleTouchTap: function _handleTouchTap(e) { | |
this._cancelFocusTimeout(); | |
if (!this.props.disabled) { | |
tabPressed = false; | |
this.removeKeyboardFocus(e); | |
this.props.onTouchTap(e); | |
} | |
}, | |
render: function render() { | |
var _props2 = this.props; | |
var centerRipple = _props2.centerRipple; | |
var children = _props2.children; | |
var containerElement = _props2.containerElement; | |
var disabled = _props2.disabled; | |
var disableFocusRipple = _props2.disableFocusRipple; | |
var disableKeyboardFocus = _props2.disableKeyboardFocus; | |
var disableTouchRipple = _props2.disableTouchRipple; | |
var focusRippleColor = _props2.focusRippleColor; | |
var focusRippleOpacity = _props2.focusRippleOpacity; | |
var linkButton = _props2.linkButton; | |
var touchRippleColor = _props2.touchRippleColor; | |
var touchRippleOpacity = _props2.touchRippleOpacity; | |
var onBlur = _props2.onBlur; | |
var onFocus = _props2.onFocus; | |
var onKeyUp = _props2.onKeyUp; | |
var onKeyDown = _props2.onKeyDown; | |
var onTouchTap = _props2.onTouchTap; | |
var style = _props2.style; | |
var tabIndex = _props2.tabIndex; | |
var type = _props2.type; | |
var other = _objectWithoutProperties(_props2, ['centerRipple', 'children', 'containerElement', 'disabled', 'disableFocusRipple', 'disableKeyboardFocus', 'disableTouchRipple', 'focusRippleColor', 'focusRippleOpacity', 'linkButton', 'touchRippleColor', 'touchRippleOpacity', 'onBlur', 'onFocus', 'onKeyUp', 'onKeyDown', 'onTouchTap', 'style', 'tabIndex', 'type']); | |
var mergedStyles = this.mergeStyles({ | |
border: 10, | |
background: 'none', | |
boxSizing: 'border-box', | |
display: 'inline-block', | |
font: 'inherit', | |
fontFamily: this.state.muiTheme.rawTheme.fontFamily, | |
tapHighlightColor: _colors2.default.transparent, | |
appearance: linkButton ? null : 'button', | |
cursor: disabled ? 'default' : 'pointer', | |
textDecoration: 'none', | |
outline: 'none' | |
}, style); | |
if (disabled && linkButton) { | |
return _react2.default.createElement( | |
'span', | |
_extends({}, other, { | |
style: mergedStyles | |
}), | |
children | |
); | |
} | |
var buttonProps = _extends({}, other, { | |
style: this.prepareStyles(mergedStyles), | |
disabled: disabled, | |
onBlur: this._handleBlur, | |
onFocus: this._handleFocus, | |
onTouchTap: this._handleTouchTap, | |
onKeyUp: this._handleKeyUp, | |
onKeyDown: this._handleKeyDown, | |
tabIndex: tabIndex, | |
type: type | |
}); | |
var buttonChildren = this._createButtonChildren(); | |
// Provides backward compatibity. Added to support wrapping around <a> element. | |
var targetLinkElement = buttonProps.hasOwnProperty('href') ? 'a' : 'span'; | |
return _react2.default.isValidElement(containerElement) ? _react2.default.cloneElement(containerElement, buttonProps, buttonChildren) : _react2.default.createElement(linkButton ? targetLinkElement : containerElement, buttonProps, buttonChildren); | |
} | |
}); | |
exports.default = EnhancedButton; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 217 */ | |
/***/ function(module, exports, __webpack_require__) { | |
module.exports = __webpack_require__(218); | |
/***/ }, | |
/* 218 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule ReactComponentWithPureRenderMixin | |
*/ | |
'use strict'; | |
var shallowCompare = __webpack_require__(219); | |
/** | |
* If your React component's render function is "pure", e.g. it will render the | |
* same result given the same props and state, provide this Mixin for a | |
* considerable performance boost. | |
* | |
* Most React components have pure render functions. | |
* | |
* Example: | |
* | |
* var ReactComponentWithPureRenderMixin = | |
* require('ReactComponentWithPureRenderMixin'); | |
* React.createClass({ | |
* mixins: [ReactComponentWithPureRenderMixin], | |
* | |
* render: function() { | |
* return <div className={this.props.className}>foo</div>; | |
* } | |
* }); | |
* | |
* Note: This only checks shallow equality for props and state. If these contain | |
* complex data structures this mixin may have false-negatives for deeper | |
* differences. Only mixin to components which have simple props and state, or | |
* use `forceUpdate()` when you know deep data structures have changed. | |
*/ | |
var ReactComponentWithPureRenderMixin = { | |
shouldComponentUpdate: function (nextProps, nextState) { | |
return shallowCompare(this, nextProps, nextState); | |
} | |
}; | |
module.exports = ReactComponentWithPureRenderMixin; | |
/***/ }, | |
/* 219 */ | |
/***/ function(module, exports, __webpack_require__) { | |
/** | |
* Copyright 2013-2015, Facebook, Inc. | |
* All rights reserved. | |
* | |
* This source code is licensed under the BSD-style license found in the | |
* LICENSE file in the root directory of this source tree. An additional grant | |
* of patent rights can be found in the PATENTS file in the same directory. | |
* | |
* @providesModule shallowCompare | |
*/ | |
'use strict'; | |
var shallowEqual = __webpack_require__(173); | |
/** | |
* Does a shallow comparison for props and state. | |
* See ReactComponentWithPureRenderMixin | |
*/ | |
function shallowCompare(instance, nextProps, nextState) { | |
return !shallowEqual(instance.props, nextProps) || !shallowEqual(instance.state, nextState); | |
} | |
module.exports = shallowCompare; | |
/***/ }, | |
/* 220 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactDom = __webpack_require__(62); | |
var _reactDom2 = _interopRequireDefault(_reactDom); | |
var _reactAddonsPureRenderMixin = __webpack_require__(217); | |
var _reactAddonsPureRenderMixin2 = _interopRequireDefault(_reactAddonsPureRenderMixin); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _autoPrefix = __webpack_require__(7); | |
var _autoPrefix2 = _interopRequireDefault(_autoPrefix); | |
var _colors = __webpack_require__(56); | |
var _colors2 = _interopRequireDefault(_colors); | |
var _transitions = __webpack_require__(208); | |
var _transitions2 = _interopRequireDefault(_transitions); | |
var _scaleIn = __webpack_require__(221); | |
var _scaleIn2 = _interopRequireDefault(_scaleIn); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
var pulsateDuration = 750; | |
var FocusRipple = _react2.default.createClass({ | |
displayName: 'FocusRipple', | |
propTypes: { | |
color: _react2.default.PropTypes.string, | |
innerStyle: _react2.default.PropTypes.object, | |
/** | |
* The material-ui theme applied to this component. | |
*/ | |
muiTheme: _react2.default.PropTypes.object.isRequired, | |
opacity: _react2.default.PropTypes.number, | |
show: _react2.default.PropTypes.bool, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object | |
}, | |
mixins: [_reactAddonsPureRenderMixin2.default, _stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
color: _colors2.default.darkBlack | |
}; | |
}, | |
componentDidMount: function componentDidMount() { | |
if (this.props.show) { | |
this._setRippleSize(); | |
this._pulsate(); | |
} | |
}, | |
componentDidUpdate: function componentDidUpdate() { | |
if (this.props.show) { | |
this._setRippleSize(); | |
this._pulsate(); | |
} else { | |
if (this._timeout) clearTimeout(this._timeout); | |
} | |
}, | |
_getRippleElement: function _getRippleElement(props) { | |
var color = props.color; | |
var innerStyle = props.innerStyle; | |
var opacity = props.opacity; | |
var innerStyles = this.mergeStyles({ | |
position: 'absolute', | |
height: '100%', | |
width: '100%', | |
borderRadius: '50%', | |
opacity: opacity ? opacity : 0.16, | |
backgroundColor: color, | |
transition: _transitions2.default.easeOut(pulsateDuration + 'ms', 'transform', null, _transitions2.default.easeInOutFunction) | |
}, innerStyle); | |
return _react2.default.createElement('div', { ref: 'innerCircle', style: this.prepareStyles(innerStyles) }); | |
}, | |
_pulsate: function _pulsate() { | |
if (!this.isMounted()) return; | |
var innerCircle = _reactDom2.default.findDOMNode(this.refs.innerCircle); | |
if (!innerCircle) return; | |
var startScale = 'scale(1)'; | |
var endScale = 'scale(0.85)'; | |
var currentScale = innerCircle.style.transform; | |
var nextScale = undefined; | |
currentScale = currentScale || startScale; | |
nextScale = currentScale === startScale ? endScale : startScale; | |
_autoPrefix2.default.set(innerCircle.style, 'transform', nextScale, this.props.muiTheme); | |
this._timeout = setTimeout(this._pulsate, pulsateDuration); | |
}, | |
_setRippleSize: function _setRippleSize() { | |
var el = _reactDom2.default.findDOMNode(this.refs.innerCircle); | |
var height = el.offsetHeight; | |
var width = el.offsetWidth; | |
var size = Math.max(height, width); | |
var oldTop = 0; | |
// For browsers that don't support endsWith() | |
if (el.style.top.indexOf('px', el.style.top.length - 2) !== -1) { | |
oldTop = parseInt(el.style.top); | |
} | |
el.style.height = size + 'px'; | |
el.style.top = height / 2 - size / 2 + oldTop + 'px'; | |
}, | |
render: function render() { | |
var _props = this.props; | |
var show = _props.show; | |
var style = _props.style; | |
var mergedRootStyles = this.mergeStyles({ | |
height: '100%', | |
width: '100%', | |
position: 'absolute', | |
top: 0, | |
left: 0 | |
}, style); | |
var ripple = show ? this._getRippleElement(this.props) : null; | |
return _react2.default.createElement( | |
_scaleIn2.default, | |
{ | |
maxScale: 0.85, | |
style: mergedRootStyles | |
}, | |
ripple | |
); | |
} | |
}); | |
exports.default = FocusRipple; | |
module.exports = exports['default']; | |
/***/ }, | |
/* 221 */ | |
/***/ function(module, exports, __webpack_require__) { | |
'use strict'; | |
var _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; }; | |
Object.defineProperty(exports, "__esModule", { | |
value: true | |
}); | |
var _react = __webpack_require__(3); | |
var _react2 = _interopRequireDefault(_react); | |
var _reactAddonsPureRenderMixin = __webpack_require__(217); | |
var _reactAddonsPureRenderMixin2 = _interopRequireDefault(_reactAddonsPureRenderMixin); | |
var _reactAddonsTransitionGroup = __webpack_require__(222); | |
var _reactAddonsTransitionGroup2 = _interopRequireDefault(_reactAddonsTransitionGroup); | |
var _stylePropable = __webpack_require__(4); | |
var _stylePropable2 = _interopRequireDefault(_stylePropable); | |
var _scaleInChild = __webpack_require__(236); | |
var _scaleInChild2 = _interopRequireDefault(_scaleInChild); | |
var _getMuiTheme = __webpack_require__(38); | |
var _getMuiTheme2 = _interopRequireDefault(_getMuiTheme); | |
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } | |
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; } | |
var ScaleIn = _react2.default.createClass({ | |
displayName: 'ScaleIn', | |
propTypes: { | |
childStyle: _react2.default.PropTypes.object, | |
children: _react2.default.PropTypes.node, | |
enterDelay: _react2.default.PropTypes.number, | |
maxScale: _react2.default.PropTypes.number, | |
minScale: _react2.default.PropTypes.number, | |
/** | |
* Override the inline-styles of the root element. | |
*/ | |
style: _react2.default.PropTypes.object | |
}, | |
contextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
//for passing default theme context to children | |
childContextTypes: { | |
muiTheme: _react2.default.PropTypes.object | |
}, | |
mixins: [_reactAddonsPureRenderMixin2.default, _stylePropable2.default], | |
getDefaultProps: function getDefaultProps() { | |
return { | |
enterDelay: 0 | |
}; | |
}, | |
getInitialState: function getInitialState() { | |
return { | |
muiTheme: this.context.muiTheme || (0, _getMuiTheme2.default)() | |
}; | |
}, | |
getChildContext: function getChildContext() { | |
return { | |
muiTheme: this.state.muiTheme | |
}; | |
}, | |
//to update theme inside state whenever a new theme is passed down | |
//from the parent / owner using context | |
componentWillReceiveProps: function componentWillReceiveProps(nextProps, nextContext) { | |
var newMuiTheme = nextContext.muiTheme ? nextContext.muiTheme : this.state.muiTheme; | |
this.setState({ muiTheme: ne |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment